X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fxgethostname.c;h=5d5a07c76000b25d49378a9f841ef9563ce87e4d;hb=43593319b31e6b0175b8eec4433bac744959822d;hp=5178784baca5bffa889d7db3078a65f0b3f405e0;hpb=a83f0239e5027272c6f5b38fa2d06e96675d81dc;p=gnulib.git diff --git a/lib/xgethostname.c b/lib/xgethostname.c index 5178784ba..5d5a07c76 100644 --- a/lib/xgethostname.c +++ b/lib/xgethostname.c @@ -1,10 +1,12 @@ /* xgethostname.c -- return current hostname with unlimited length - Copyright (C) 1992, 1996, 2000, 2001, 2003 Free Software Foundation, Inc. - This program is free software; you can redistribute it and/or modify + Copyright (C) 1992, 1996, 2000-2001, 2003-2006, 2009-2013 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. + the Free Software Foundation; either version 3 of the License, 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 @@ -12,73 +14,60 @@ 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. */ + along with this program. If not, see . */ /* written by Jim Meyering */ -#ifdef HAVE_CONFIG_H -# include -#endif +#include -#include -#include +/* Specification. */ +#include "xgethostname.h" +#include #include -#ifndef errno -extern int errno; -#endif +#include -#include "error.h" #include "xalloc.h" -#ifndef ENAMETOOLONG -# define ENAMETOOLONG 9999 -#endif - -#ifndef EXIT_FAILURE -# define EXIT_FAILURE 1 -#endif - -int gethostname (); - #ifndef INITIAL_HOSTNAME_LENGTH # define INITIAL_HOSTNAME_LENGTH 34 #endif /* Return the current hostname in malloc'd storage. If malloc fails, exit. - Upon any other failure, return NULL. */ + Upon any other failure, return NULL and set errno. */ char * -xgethostname () +xgethostname (void) { - char *hostname; - size_t size; + char *hostname = NULL; + size_t size = INITIAL_HOSTNAME_LENGTH; - size = INITIAL_HOSTNAME_LENGTH; - /* Use size + 1 here rather than size to work around the bug - in SunOS 5.5's gethostname whereby it NUL-terminates HOSTNAME - even when the name is longer than the supplied buffer. */ - hostname = xmalloc (size + 1); while (1) { - int k = size - 1; - int err; - + /* Use SIZE_1 here rather than SIZE to work around the bug in + SunOS 5.5's gethostname whereby it NUL-terminates HOSTNAME + even when the name is as long as the supplied buffer. */ + size_t size_1; + + hostname = x2realloc (hostname, &size); + size_1 = size - 1; + hostname[size_1 - 1] = '\0'; errno = 0; - hostname[k] = '\0'; - err = gethostname (hostname, size); - if (err >= 0 && hostname[k] == '\0') - break; - else if (err < 0 && errno != ENAMETOOLONG && errno != 0) - { - int saved_errno = errno; - free (hostname); - errno = saved_errno; - return NULL; - } - size *= 2; - hostname = xrealloc (hostname, size + 1); + + if (gethostname (hostname, size_1) == 0) + { + if (! hostname[size_1 - 1]) + break; + } + else if (errno != 0 && errno != ENAMETOOLONG && errno != EINVAL + /* OSX/Darwin does this when the buffer is not large enough */ + && errno != ENOMEM) + { + int saved_errno = errno; + free (hostname); + errno = saved_errno; + return NULL; + } } return hostname;