diff options
author | max <max@FreeBSD.org> | 1997-01-06 22:09:34 +0800 |
---|---|---|
committer | max <max@FreeBSD.org> | 1997-01-06 22:09:34 +0800 |
commit | 1641bd79c1a7f3dbe3a5a7f916b1d19422aa6802 (patch) | |
tree | 03d688eba3b99761823d0e65a01e01aface903aa /net/gnu-finger | |
parent | 149f2a25bd267b9b1f74b6e182cbaaa87df0ee47 (diff) | |
download | freebsd-ports-gnome-1641bd79c1a7f3dbe3a5a7f916b1d19422aa6802.tar.gz freebsd-ports-gnome-1641bd79c1a7f3dbe3a5a7f916b1d19422aa6802.tar.zst freebsd-ports-gnome-1641bd79c1a7f3dbe3a5a7f916b1d19422aa6802.zip |
Previous modification to treat ttyv? as console introduced bug and this
change should correct it.
Added some comment about the modification this patch is making.
Instead of hardcode utmp location, use _UTMP_PATH.
Submitted by: sanpei@yy.cs.keio.ac.jp
Diffstat (limited to 'net/gnu-finger')
-rw-r--r-- | net/gnu-finger/files/patch-ab | 55 |
1 files changed, 37 insertions, 18 deletions
diff --git a/net/gnu-finger/files/patch-ab b/net/gnu-finger/files/patch-ab index 0fb89a315769..8aaf2aca7777 100644 --- a/net/gnu-finger/files/patch-ab +++ b/net/gnu-finger/files/patch-ab @@ -1,5 +1,5 @@ ---- lib/os.c.orig Fri Oct 23 06:01:10 1992 -+++ lib/os.c Mon Jan 6 17:47:01 1997 +--- lib/os.c.orig Mon Jan 6 22:09:06 1997 ++++ lib/os.c Mon Jan 6 22:08:34 1997 @@ -26,6 +26,8 @@ #include <sys/acct.h> #include <time.h> @@ -14,7 +14,7 @@ /* Where the utmp file is located. */ #ifndef HAVE_GETUTENT +#ifdef __FreeBSD__ -+#define UTMP_FILE "/var/run/utmp" ++#define UTMP_FILE _PATH_UTMP +#else #define UTMP_FILE "/etc/utmp" #endif @@ -22,7 +22,29 @@ /* A non-null value is the address of the utmp entry which contains the information for the user using the console. */ -@@ -485,6 +491,7 @@ +@@ -288,6 +294,21 @@ + { + idle = current_time - get_last_access (utmplist[i]->ut_line); + ++#ifdef __FreeBSD__ ++ /* ++ * GNU finger lists two information of one user for one machine, ++ * (1. about login console, 2. tty which has smallest idling time.) ++ * In listing algorithm, GNU finger server program [fingerd] uses ++ * `console' string in tty. ++ * ++ * But FreeBSD uses `ttyv[0-3]' as console name. ++ * ++ * So this patch is to translate `ttyv?' string to `console' ++ */ ++ if (strstr (utmplist[i]->ut_line, "ttyv") != NULL) { ++ strcpy (utmplist[i]->ut_line, "console"); ++ } ++#endif + if (idle < 0) + idle = 0; + +@@ -485,6 +506,7 @@ UTMP **result; int result_size = 0; @@ -30,11 +52,19 @@ #ifndef HAVE_GETUTENT file = open (UTMP_FILE, O_RDONLY); -@@ -529,6 +536,19 @@ +@@ -528,6 +550,26 @@ + if (!UT (entry, ut_name)[0]) continue; #endif /* sun */ - ++ +#ifdef __FreeBSD__ ++ /* ++ * From src/usr.bin/login/login.c CVS log, after 2.2 source tree, ++ * login.c write numerical address to ut_host. ++ * (1.12 comment of login.c) ++ * ++ * So this patch is to translate numerical address to hostname. ++ */ + if (UT(entry, ut_host)[0]) { + if (isdigit(UT(entry, ut_host)[0]) && + (long)(l = inet_addr(UT(entry, ut_host))) != -1 && @@ -46,17 +76,6 @@ + } /* IP addr */ + } /* UTMP */ +#endif -+ + for (i = 0; result[i]; i++) { - /* If the same person is logged in more than once, we are -@@ -552,6 +572,9 @@ - finding the tty location. `v0' is what X window terminals - use for the console login window. */ - if ((strcmp (result[i]->ut_line, "console") == 0) || -+#ifdef __FreeBSD__ -+ (strstr (result[i]->ut_line, "ttyv") != NULL) || -+#endif - (strcmp (result[i]->ut_line, "v0") == 0)) - { - console_user = result[i]; |