X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fxgethostname.c;h=1139a1b19c2703492951147671652f56c4bc249d;hb=5760692e30d0575cc224b9b19f0fcb8ff77d28ac;hp=f00d7bd5f53e35682b3abeef675ab8e94e00c4cc;hpb=a38bc613499aee7806cecf6615af4ad2a09def61;p=gnulib.git diff --git a/lib/xgethostname.c b/lib/xgethostname.c index f00d7bd5f..1139a1b19 100644 --- a/lib/xgethostname.c +++ b/lib/xgethostname.c @@ -1,10 +1,46 @@ +/* xgethostname.c -- return current hostname with unlimited length + Copyright (C) 1992, 1996 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2, or (at your option) + any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +/* written by Jim Meyering */ + +#ifdef HAVE_CONFIG_H +# include +#endif + #include +#include +#ifndef errno +extern int errno; +#endif + +#include "error.h" + +#ifndef EXIT_FAILURE +# define EXIT_FAILURE 1 +#endif + int gethostname (); char *xmalloc (); char *xrealloc (); -#define INITIAL_HOSTNAME_LENGTH 33 +#ifndef INITIAL_HOSTNAME_LENGTH +# define INITIAL_HOSTNAME_LENGTH 34 +#endif char * xgethostname () @@ -14,13 +50,23 @@ xgethostname () int err; size = INITIAL_HOSTNAME_LENGTH; + hostname = xmalloc (size); while (1) { - hostname = xmalloc (size); - hostname[size - 1] = '\0'; + /* 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[k] = '\0'; err = gethostname (hostname, size); - if (err || hostname[size - 1] == '\0') + if (err == 0 && hostname[k] == '\0') break; +#ifdef ENAMETOOLONG + else if (err != 0 && errno != ENAMETOOLONG && errno != 0) + error (EXIT_FAILURE, errno, "gethostname"); +#endif size *= 2; hostname = xrealloc (hostname, size); }