Blame SOURCES/bsd-finger-0.17-usagi-ipv6.patch

d77ab8
diff -uNr bsd-finger-0.17/CVS/Entries bsd-finger/CVS/Entries
d77ab8
--- bsd-finger-0.17/CVS/Entries	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/CVS/Entries	Fri Mar  9 00:00:29 2001
d77ab8
@@ -0,0 +1,11 @@
d77ab8
+/.cvsignore/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/BUGS/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/ChangeLog/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/MCONFIG.in/1.3/Sat Jan 27 04:14:52 2001//
d77ab8
+/MRULES/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/Makefile/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/README/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/configure/1.5/Sat Jan 27 04:14:52 2001//
d77ab8
+/version.h/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+D/finger////
d77ab8
+D/fingerd////
d77ab8
diff -uNr bsd-finger-0.17/CVS/Repository bsd-finger/CVS/Repository
d77ab8
--- bsd-finger-0.17/CVS/Repository	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/CVS/Repository	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+usagi/src/bsd-finger
d77ab8
diff -uNr bsd-finger-0.17/CVS/Root bsd-finger/CVS/Root
d77ab8
--- bsd-finger-0.17/CVS/Root	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/CVS/Root	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+:pserver:anoncvs@anoncvs.linux-ipv6.org:/cvsroot/usagi
d77ab8
diff -uNr bsd-finger-0.17/configure bsd-finger/configure
d77ab8
--- bsd-finger-0.17/configure	Sat Jul 29 21:00:27 2000
d77ab8
+++ bsd-finger/configure	Sat Jan 27 06:14:52 2001
d77ab8
@@ -25,6 +25,7 @@
d77ab8
     --daemonmode=mode     Mode for daemon binaries [same as binmode]
d77ab8
     --manmode=mode        Mode for manual pages [644]
d77ab8
     --with-c-compiler=cc  Program for compiling C source [guessed]
d77ab8
+    --enable-ipv6         Enable IPv6 support
d77ab8
 EOF
d77ab8
 	exit 0;;
d77ab8
 	--verbose) ;;
d77ab8
@@ -40,6 +41,11 @@
d77ab8
 	--daemonmode=*) DAEMONMODE=`echo $1 | sed 's/^[^=]*=//'` ;;
d77ab8
 	--manmode=*) MANMODE=`echo $1 | sed 's/^[^=]*=//'` ;;
d77ab8
 	--with-c-compiler=*) CC=`echo $1 | sed 's/^[^=]*=//'` ;;
d77ab8
+
d77ab8
+	--disable-ipv6) ENABLE_IPV6=no;;
d77ab8
+	--enable-ipv6=*) ENABLE_IPV6=`echo $1 | sed 's/^[^=]*=//'`;;
d77ab8
+	--enable-ipv6) ENABLE_IPV6=yes;;
d77ab8
+
d77ab8
 	*) echo "Unrecognized option: $1"; exit 1;;
d77ab8
 esac 
d77ab8
 shift
d77ab8
@@ -148,6 +154,42 @@
d77ab8
 
d77ab8
 LDFLAGS=
d77ab8
 LIBS=
d77ab8
+
d77ab8
+rm -f __conftest*
d77ab8
+
d77ab8
+##################################################
d77ab8
+## Enable IPv6
d77ab8
+echo -n "Whether to enable IPv6 support... "
d77ab8
+if [ x"$ENABLE_IPV6" = x"yes" ]; then
d77ab8
+    echo yes
d77ab8
+    CFLAGS="$CFLAGS -DINET6"
d77ab8
+else
d77ab8
+    echo no
d77ab8
+fi
d77ab8
+
d77ab8
+rm -f __conftest*
d77ab8
+
d77ab8
+## Search IPv6 Library / Headers
d77ab8
+if [ x"$ENABLE_IPV6" = x"yes" ]; then
d77ab8
+    echo -n "Search for IPv6 library... "
d77ab8
+    inet6libdirs="/usr/local/v6/lib /usr/local/lib /usr /usr/inet6/lib"
d77ab8
+    inet6libs="inet6"
d77ab8
+    inet6found=no
d77ab8
+    for inet6libdir in $inet6libdirs; do
d77ab8
+        for inet6lib in $inet6libs; do
d77ab8
+            if [ -d $inet6libdir ] && [ -f $inet6libdir/lib$inet6lib.a ]; then
d77ab8
+                inet6found=yes
d77ab8
+                break 2
d77ab8
+            fi
d77ab8
+        done
d77ab8
+    done
d77ab8
+    if [ x"$inet6found" = x"yes" ]; then
d77ab8
+        echo "$inet6libdir/lib$inet6lib.a"
d77ab8
+        LIBS="$LIBS -L$inet6libdir -l$inet6lib"
d77ab8
+    else
d77ab8
+        echo "not found"
d77ab8
+    fi
d77ab8
+fi
d77ab8
 
d77ab8
 rm -f __conftest*
d77ab8
 
d77ab8
diff -uNr bsd-finger-0.17/finger/CVS/Entries bsd-finger/finger/CVS/Entries
d77ab8
--- bsd-finger-0.17/finger/CVS/Entries	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/finger/CVS/Entries	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1,11 @@
d77ab8
+/.cvsignore/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/Makefile/1.4/Sat Jan 27 05:57:07 2001//
d77ab8
+/display.c/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/finger.1/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/finger.c/1.3/Sun Feb 11 09:33:52 2001//
d77ab8
+/finger.h/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/lprint.c/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/net.c/1.3/Fri Jan 26 18:08:21 2001//
d77ab8
+/sprint.c/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/util.c/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+D
d77ab8
diff -uNr bsd-finger-0.17/finger/CVS/Repository bsd-finger/finger/CVS/Repository
d77ab8
--- bsd-finger-0.17/finger/CVS/Repository	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/finger/CVS/Repository	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+usagi/src/bsd-finger/finger
d77ab8
diff -uNr bsd-finger-0.17/finger/CVS/Root bsd-finger/finger/CVS/Root
d77ab8
--- bsd-finger-0.17/finger/CVS/Root	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/finger/CVS/Root	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+:pserver:anoncvs@anoncvs.linux-ipv6.org:/cvsroot/usagi
d77ab8
diff -uNr bsd-finger-0.17/finger/Makefile bsd-finger/finger/Makefile
d77ab8
--- bsd-finger-0.17/finger/Makefile	Sun Dec 12 20:04:52 1999
d77ab8
+++ bsd-finger/finger/Makefile	Sat Jan 27 07:57:07 2001
d77ab8
@@ -10,7 +10,9 @@
d77ab8
 finger.o: ../version.h
d77ab8
 
d77ab8
 install: finger
d77ab8
+	install -d $(INSTALLROOT)$(BINDIR)
d77ab8
 	install -s -m$(BINMODE) finger $(INSTALLROOT)$(BINDIR)
d77ab8
+	install -d $(INSTALLROOT)$(MANDIR)/man1
d77ab8
 	install -m$(MANMODE) finger.1 $(INSTALLROOT)$(MANDIR)/man1
d77ab8
 
d77ab8
 clean:
d77ab8
diff -uNr bsd-finger-0.17/finger/finger.1 bsd-finger/finger/finger.1
d77ab8
--- bsd-finger-0.17/finger/finger.1	Mon Jul 31 02:56:57 2000
d77ab8
+++ bsd-finger/finger/finger.1	Fri Nov  3 21:18:15 2000
d77ab8
@@ -30,7 +30,7 @@
d77ab8
 .\" SUCH DAMAGE.
d77ab8
 .\"
d77ab8
 .\"	from: @(#)finger.1	6.14 (Berkeley) 7/27/91
d77ab8
-.\"	$Id: finger.1,v 1.18 2000/07/30 23:56:57 dholland Exp $
d77ab8
+.\"	$Id: finger.1,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $
d77ab8
 .\"
d77ab8
 .Dd August 15, 1999
d77ab8
 .Dt FINGER 1
d77ab8
diff -uNr bsd-finger-0.17/finger/finger.c bsd-finger/finger/finger.c
d77ab8
--- bsd-finger-0.17/finger/finger.c	Sat Dec 18 18:41:51 1999
d77ab8
+++ bsd-finger/finger/finger.c	Sun Feb 11 11:33:52 2001
d77ab8
@@ -1,3 +1,5 @@
d77ab8
+/* $USAGI$ */
d77ab8
+
d77ab8
 /*
d77ab8
  * Copyright (c) 1989 The Regents of the University of California.
d77ab8
  * All rights reserved.
d77ab8
@@ -46,7 +48,7 @@
d77ab8
  * from: @(#)finger.c	5.22 (Berkeley) 6/29/90 
d77ab8
  */
d77ab8
 char finger_rcsid[] = \
d77ab8
-  "$Id: finger.c,v 1.15 1999/12/18 16:41:51 dholland Exp $";
d77ab8
+  "$Id: finger.c,v 1.3 2001/02/11 09:33:52 yoshfuji Exp $";
d77ab8
 
d77ab8
 /*
d77ab8
  * Finger prints out information about users.  It is not portable since
d77ab8
@@ -74,7 +76,11 @@
d77ab8
 #include <time.h>
d77ab8
 #include <getopt.h>
d77ab8
 #include "finger.h"
d77ab8
+#ifdef _USAGI
d77ab8
+#include "version.h"
d77ab8
+#else
d77ab8
 #include "../version.h"
d77ab8
+#endif
d77ab8
 
d77ab8
 static void loginlist(void);
d77ab8
 static void userlist(int argc, char *argv[]);
d77ab8
@@ -92,8 +98,12 @@
d77ab8
 
d77ab8
 int main(int argc, char *argv[]) {
d77ab8
 	int ch;
d77ab8
-	struct sockaddr_in sin;
d77ab8
-	socklen_t slen = sizeof(sin);
d77ab8
+#ifdef INET6
d77ab8
+	struct sockaddr_storage sa;
d77ab8
+#else
d77ab8
+	struct sockaddr sa;
d77ab8
+#endif
d77ab8
+	socklen_t slen = sizeof(sa);
d77ab8
 
d77ab8
 	while ((ch = getopt(argc, argv, "lmps")) != EOF) {
d77ab8
 		switch(ch) {
d77ab8
@@ -119,7 +129,7 @@
d77ab8
 	argc -= optind;
d77ab8
 	argv += optind;
d77ab8
 
d77ab8
-	if (getsockname(STDOUT_FILENO, (struct sockaddr *)&sin, &slen)==0) {
d77ab8
+	if (getsockname(STDOUT_FILENO, (struct sockaddr *)&sa, &slen)==0) {
d77ab8
 		/*
d77ab8
 		 * stdout is a socket. must be a network finger request,
d77ab8
 		 * so emit CRs with our LFs at the ends of lines.
d77ab8
@@ -136,7 +146,7 @@
d77ab8
 	 * Also check stdin for nofinger processing, because of older
d77ab8
 	 * fingerds that make stdout a pipe for CRLF handling.
d77ab8
 	 */
d77ab8
-	if (getsockname(STDIN_FILENO, (struct sockaddr *)&sin, &slen)==0) {
d77ab8
+	if (getsockname(STDIN_FILENO, (struct sockaddr *)&sa, &slen)==0) {
d77ab8
 		enable_nofinger = 1;
d77ab8
 	}	
d77ab8
 
d77ab8
diff -uNr bsd-finger-0.17/finger/finger.h bsd-finger/finger/finger.h
d77ab8
--- bsd-finger-0.17/finger/finger.h	Tue Sep 14 13:51:11 1999
d77ab8
+++ bsd-finger/finger/finger.h	Fri Nov  3 21:18:15 2000
d77ab8
@@ -34,7 +34,7 @@
d77ab8
  * SUCH DAMAGE.
d77ab8
  *
d77ab8
  *	from: @(#)finger.h	5.5 (Berkeley) 6/1/90
d77ab8
- *	$Id: finger.h,v 1.7 1999/09/14 10:51:11 dholland Exp $
d77ab8
+ *	$Id: finger.h,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $
d77ab8
  */
d77ab8
 
d77ab8
 #include <pwd.h>
d77ab8
diff -uNr bsd-finger-0.17/finger/lprint.c bsd-finger/finger/lprint.c
d77ab8
--- bsd-finger-0.17/finger/lprint.c	Tue Sep 14 13:51:11 1999
d77ab8
+++ bsd-finger/finger/lprint.c	Fri Nov  3 21:18:15 2000
d77ab8
@@ -38,7 +38,7 @@
d77ab8
  * from: @(#)lprint.c	5.13 (Berkeley) 10/31/90
d77ab8
  */
d77ab8
 char lprint_rcsid[] = 
d77ab8
-  "$Id: lprint.c,v 1.11 1999/09/14 10:51:11 dholland Exp $";
d77ab8
+  "$Id: lprint.c,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $";
d77ab8
 
d77ab8
 #include <stdio.h>
d77ab8
 #include <ctype.h>
d77ab8
diff -uNr bsd-finger-0.17/finger/net.c bsd-finger/finger/net.c
d77ab8
--- bsd-finger-0.17/finger/net.c	Tue Sep 14 13:51:11 1999
d77ab8
+++ bsd-finger/finger/net.c	Fri Jan 26 20:08:21 2001
d77ab8
@@ -1,3 +1,5 @@
d77ab8
+/* $USAGI: net.c,v 1.2 2000/11/17 08:00:44 yoshfuji Exp $ */
d77ab8
+
d77ab8
 /*
d77ab8
  * Copyright (c) 1989 The Regents of the University of California.
d77ab8
  * All rights reserved.
d77ab8
@@ -36,7 +38,7 @@
d77ab8
 
d77ab8
 #ifndef lint
d77ab8
 /*static char sccsid[] = "from: @(#)net.c	5.5 (Berkeley) 6/1/90";*/
d77ab8
-char net_rcsid[] = "$Id: net.c,v 1.9 1999/09/14 10:51:11 dholland Exp $";
d77ab8
+char net_rcsid[] = "$Id: net.c,v 1.3 2001/01/26 18:08:21 yoshfuji Exp $";
d77ab8
 #endif /* not lint */
d77ab8
 
d77ab8
 #include <sys/types.h>
d77ab8
@@ -53,18 +55,53 @@
d77ab8
 
d77ab8
 void netfinger(const char *name) {
d77ab8
 	register FILE *fp;
d77ab8
-	struct in_addr defaddr;
d77ab8
 	register int c, sawret, ateol;
d77ab8
+#ifdef INET6
d77ab8
+	struct addrinfo hints, *res0, *res;
d77ab8
+	int gai;
d77ab8
+#else
d77ab8
+	struct in_addr defaddr;
d77ab8
 	struct hostent *hp, def;
d77ab8
 	struct servent *sp;
d77ab8
 	struct sockaddr_in sn;
d77ab8
+	char *alist[1];
d77ab8
+#endif
d77ab8
 	int s;
d77ab8
-	char *alist[1], *host;
d77ab8
+	char *host;
d77ab8
 
d77ab8
 	host = strrchr(name, '@');
d77ab8
 	if (!host) return;
d77ab8
 	*host++ = '\0';
d77ab8
 
d77ab8
+#ifdef INET6
d77ab8
+	memset(&hints, 0, sizeof(hints));
d77ab8
+	hints.ai_family = PF_UNSPEC;
d77ab8
+	hints.ai_socktype = SOCK_STREAM;
d77ab8
+	gai = getaddrinfo(host, "finger", &hints, &res0);
d77ab8
+	if (gai) {
d77ab8
+		eprintf("finger: %s: host '%s', service '%s'\n",
d77ab8
+			gai_strerror(gai), host, "finger");
d77ab8
+		return;
d77ab8
+	}
d77ab8
+	s = -1;
d77ab8
+	errno = 0;
d77ab8
+	for (res=res0; res; res=res->ai_next) {
d77ab8
+		s = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
d77ab8
+		if (s < 0)
d77ab8
+			continue;
d77ab8
+		if (connect(s, res->ai_addr, res->ai_addrlen) < 0){
d77ab8
+			close(s);
d77ab8
+			s = -1;
d77ab8
+			continue;
d77ab8
+		}
d77ab8
+		break;
d77ab8
+	}
d77ab8
+	freeaddrinfo(res0);
d77ab8
+	if (s < 0) {
d77ab8
+		eprintf("finger: cannot create socket / connet host\n");
d77ab8
+		return;
d77ab8
+	}
d77ab8
+#else
d77ab8
 	memset(&sn, 0, sizeof(sn));
d77ab8
 
d77ab8
 	sp = getservbyname("finger", "tcp");
d77ab8
@@ -106,6 +143,7 @@
d77ab8
 		close(s);
d77ab8
 		return;
d77ab8
 	}
d77ab8
+#endif
d77ab8
 
d77ab8
 	/* -l flag for remote fingerd  */
d77ab8
 	if (lflag) write(s, "/W ", 3);
d77ab8
diff -uNr bsd-finger-0.17/finger/sprint.c bsd-finger/finger/sprint.c
d77ab8
--- bsd-finger-0.17/finger/sprint.c	Sun Dec 12 20:59:33 1999
d77ab8
+++ bsd-finger/finger/sprint.c	Fri Nov  3 21:18:15 2000
d77ab8
@@ -36,7 +36,7 @@
d77ab8
 
d77ab8
 #ifndef lint
d77ab8
 /*static char sccsid[] = "from: @(#)sprint.c	5.8 (Berkeley) 12/4/90";*/
d77ab8
-char sprint_rcsid[] = "$Id: sprint.c,v 1.10 1999/12/12 18:59:33 dholland Exp $";
d77ab8
+char sprint_rcsid[] = "$Id: sprint.c,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $";
d77ab8
 #endif /* not lint */
d77ab8
 
d77ab8
 #include <sys/types.h>
d77ab8
diff -uNr bsd-finger-0.17/finger/util.c bsd-finger/finger/util.c
d77ab8
--- bsd-finger-0.17/finger/util.c	Wed Sep 29 01:53:58 1999
d77ab8
+++ bsd-finger/finger/util.c	Fri Nov  3 21:18:15 2000
d77ab8
@@ -36,7 +36,7 @@
d77ab8
 
d77ab8
 #ifndef lint
d77ab8
 /*static char sccsid[] = "from: @(#)util.c	5.14 (Berkeley) 1/17/91";*/
d77ab8
-char util_rcsid[] = "$Id: util.c,v 1.18 1999/09/28 22:53:58 netbug Exp $";
d77ab8
+char util_rcsid[] = "$Id: util.c,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $";
d77ab8
 #endif /* not lint */
d77ab8
 
d77ab8
 #include <sys/types.h>
d77ab8
diff -uNr bsd-finger-0.17/fingerd/CVS/Entries bsd-finger/fingerd/CVS/Entries
d77ab8
--- bsd-finger-0.17/fingerd/CVS/Entries	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/fingerd/CVS/Entries	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1,6 @@
d77ab8
+/.cvsignore/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/Makefile/1.4/Sat Jan 27 05:57:07 2001//
d77ab8
+/fingerd.8/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+/fingerd.c/1.5/Sun Feb 11 09:33:52 2001//
d77ab8
+/pathnames.h/1.1.1.1/Fri Nov  3 19:18:15 2000//
d77ab8
+D
d77ab8
diff -uNr bsd-finger-0.17/fingerd/CVS/Repository bsd-finger/fingerd/CVS/Repository
d77ab8
--- bsd-finger-0.17/fingerd/CVS/Repository	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/fingerd/CVS/Repository	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+usagi/src/bsd-finger/fingerd
d77ab8
diff -uNr bsd-finger-0.17/fingerd/CVS/Root bsd-finger/fingerd/CVS/Root
d77ab8
--- bsd-finger-0.17/fingerd/CVS/Root	Thu Jan  1 02:00:00 1970
d77ab8
+++ bsd-finger/fingerd/CVS/Root	Mon Feb 19 06:50:43 2001
d77ab8
@@ -0,0 +1 @@
d77ab8
+:pserver:anoncvs@anoncvs.linux-ipv6.org:/cvsroot/usagi
d77ab8
diff -uNr bsd-finger-0.17/fingerd/Makefile bsd-finger/fingerd/Makefile
d77ab8
--- bsd-finger-0.17/fingerd/Makefile	Sun Dec 12 20:04:57 1999
d77ab8
+++ bsd-finger/fingerd/Makefile	Sat Jan 27 07:57:07 2001
d77ab8
@@ -9,7 +9,9 @@
d77ab8
 fingerd.o: pathnames.h ../version.h
d77ab8
 
d77ab8
 install: fingerd
d77ab8
+	install -d $(INSTALLROOT)$(SBINDIR)
d77ab8
 	install -s -m$(DAEMONMODE) fingerd $(INSTALLROOT)$(SBINDIR)/in.fingerd
d77ab8
+	install -d $(INSTALLROOT)$(MANDIR)/man8
d77ab8
 	install -m$(MANMODE) fingerd.8 $(INSTALLROOT)$(MANDIR)/man8/in.fingerd.8
d77ab8
 	ln -sf in.fingerd.8 $(INSTALLROOT)$(MANDIR)/man8/fingerd.8
d77ab8
 
d77ab8
diff -uNr bsd-finger-0.17/fingerd/fingerd.8 bsd-finger/fingerd/fingerd.8
d77ab8
--- bsd-finger-0.17/fingerd/fingerd.8	Mon Jul 31 02:56:57 2000
d77ab8
+++ bsd-finger/fingerd/fingerd.8	Fri Nov  3 21:18:15 2000
d77ab8
@@ -30,7 +30,7 @@
d77ab8
 .\" SUCH DAMAGE.
d77ab8
 .\"
d77ab8
 .\"     from: @(#)fingerd.8	6.4 (Berkeley) 3/16/91
d77ab8
-.\"	$Id: fingerd.8,v 1.18 2000/07/30 23:56:57 dholland Exp $
d77ab8
+.\"	$Id: fingerd.8,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $
d77ab8
 .\"
d77ab8
 .Dd August 29, 1996
d77ab8
 .Dt FINGERD 8
d77ab8
diff -uNr bsd-finger-0.17/fingerd/fingerd.c bsd-finger/fingerd/fingerd.c
d77ab8
--- bsd-finger-0.17/fingerd/fingerd.c	Sun Dec 12 20:46:28 1999
d77ab8
+++ bsd-finger/fingerd/fingerd.c	Sun Feb 11 11:33:52 2001
d77ab8
@@ -1,3 +1,5 @@
d77ab8
+/* $USAGI: fingerd.c,v 1.3 2000/11/17 08:13:01 yoshfuji Exp $ */
d77ab8
+
d77ab8
 /*
d77ab8
  * Copyright (c) 1983 The Regents of the University of California.
d77ab8
  * All rights reserved.
d77ab8
@@ -39,7 +41,7 @@
d77ab8
  * from: @(#)fingerd.c	5.6 (Berkeley) 6/1/90"
d77ab8
  */
d77ab8
 char rcsid[] = 
d77ab8
-  "$Id: fingerd.c,v 1.23 1999/12/12 18:46:28 dholland Exp $";
d77ab8
+  "$Id: fingerd.c,v 1.5 2001/02/11 09:33:52 yoshfuji Exp $";
d77ab8
 
d77ab8
 #include <pwd.h>
d77ab8
 #include <grp.h>
d77ab8
@@ -57,7 +59,11 @@
d77ab8
 #include <sys/wait.h>
d77ab8
 
d77ab8
 #include "pathnames.h"
d77ab8
+#ifdef _USAGI
d77ab8
+#include "version.h"
d77ab8
+#else
d77ab8
 #include "../version.h"
d77ab8
+#endif
d77ab8
 
d77ab8
 #define	ENTRIES	50
d77ab8
 #define WS " \t\r\n"
d77ab8
@@ -111,7 +117,11 @@
d77ab8
 	int k, nusers;
d77ab8
 	char *s, *t;
d77ab8
 	const char *fingerpath = NULL;
d77ab8
-	struct sockaddr_in sn;
d77ab8
+#ifdef INET6
d77ab8
+	struct sockaddr_storage sn;
d77ab8
+#else
d77ab8
+	struct sockaddr sn;
d77ab8
+#endif
d77ab8
 	socklen_t sval = sizeof(sn);
d77ab8
 
d77ab8
 
d77ab8
@@ -182,18 +192,35 @@
d77ab8
 
d77ab8
 	if (welcome) {
d77ab8
 		char buf[256];
d77ab8
+#ifdef INET6
d77ab8
+		struct addrinfo hints, *res0;
d77ab8
+#else
d77ab8
 		struct hostent *hp;
d77ab8
+#endif
d77ab8
 		struct utsname utsname;
d77ab8
+		const char *cname = buf;
d77ab8
 
d77ab8
 		uname(&utsname);
d77ab8
 		gethostname(buf, sizeof(buf));
d77ab8
+#ifdef INET6
d77ab8
+		memset(&hints, 0, sizeof(hints));
d77ab8
+		hints.ai_family = PF_UNSPEC;
d77ab8
+		hints.ai_flags = AI_CANONNAME;
d77ab8
+		if (getaddrinfo(buf, NULL, &hints, &res0)) {
d77ab8
+			/* paranoia: dns spoofing? */
d77ab8
+			cname = res0->ai_canonname;
d77ab8
+		}
d77ab8
+#else
d77ab8
 		if ((hp = gethostbyname(buf))) {
d77ab8
 			/* paranoia: dns spoofing? */
d77ab8
-			strncpy(buf, hp->h_name, sizeof(buf));
d77ab8
-			buf[sizeof(buf)-1] = 0;
d77ab8
+			cname = hp->h_name;
d77ab8
 		}
d77ab8
+#endif
d77ab8
 		printf("\r\nWelcome to %s version %s at %s !\r\n\n",
d77ab8
-				utsname.sysname, utsname.release, buf);
d77ab8
+				utsname.sysname, utsname.release, cname);
d77ab8
+#ifdef INET6
d77ab8
+		freeaddrinfo(res0);
d77ab8
+#endif
d77ab8
 		fflush(stdout);
d77ab8
 		switch (fork()) {
d77ab8
 		 case -1: /* fork failed, oh well */
d77ab8
diff -uNr bsd-finger-0.17/fingerd/pathnames.h bsd-finger/fingerd/pathnames.h
d77ab8
--- bsd-finger-0.17/fingerd/pathnames.h	Sun Jul 14 02:21:42 1996
d77ab8
+++ bsd-finger/fingerd/pathnames.h	Fri Nov  3 21:18:15 2000
d77ab8
@@ -31,7 +31,7 @@
d77ab8
  * SUCH DAMAGE.
d77ab8
  *
d77ab8
  *	from: @(#)pathnames.h	5.3 (Berkeley) 6/1/90
d77ab8
- *	$Id: pathnames.h,v 1.3 1996/07/13 23:21:42 dholland Exp $
d77ab8
+ *	$Id: pathnames.h,v 1.1.1.1 2000/11/03 19:18:15 mk Exp $
d77ab8
  */
d77ab8
 
d77ab8
 /*