(xgethostname): Work around bug in SunOS5.5's gethostname.
authorJim Meyering <jim@meyering.net>
Thu, 21 Nov 1996 02:38:40 +0000 (02:38 +0000)
committerJim Meyering <jim@meyering.net>
Thu, 21 Nov 1996 02:38:40 +0000 (02:38 +0000)
lib/xgethostname.c

index 7038ea42cec5d45b18d2152c3c908c3e1256daee..79da0ec9c2722dc0a77bfe6786b1d85c54a175aa 100644 (file)
@@ -39,7 +39,7 @@ char *xmalloc ();
 char *xrealloc ();
 
 #ifndef INITIAL_HOSTNAME_LENGTH
-# define INITIAL_HOSTNAME_LENGTH 33
+# define INITIAL_HOSTNAME_LENGTH 34
 #endif
 
 char *
@@ -53,10 +53,15 @@ xgethostname ()
   hostname = xmalloc (size);
   while (1)
     {
+      /* Use size - 2 here rather than size - 1 to work around the bug
+        in SunOS5.5's gethostname whereby it NUL-terminates HOSTNAME
+        even when the name is longer than the supplied buffer.  */
+      int k = size - 2;
+
       errno = 0;
-      hostname[size - 1] = '\0';
+      hostname[k] = '\0';
       err = gethostname (hostname, size);
-      if (err == 0 && hostname[size - 1] == '\0')
+      if (err == 0 && hostname[k] == '\0')
        break;
 #ifdef ENAMETOOLONG
       else if (err != 0 && errno != ENAMETOOLONG && errno != 0)