[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
declare gethostname in unistd.h
From: |
Bruno Haible |
Subject: |
declare gethostname in unistd.h |
Date: |
Sun, 19 Oct 2008 17:32:24 +0200 |
User-agent: |
KMail/1.5.4 |
Hi Simon,
Here's a proposed patch so that on platforms where gethostname() is missing
and substituted by gnulib, it is declared in <unistd.h>. OK to commit?
Note that this does not resolve the issue with mingw. On mingw, <winsock2.h>
declares gethostname() also - but it requires linking with -lws2_32, right?
How should the gnulib module handle this?
1. Should gnulib's replacement call the winsock2 gethostname()?
2. Should this be done through immediate linking, or dynamic linking?
Bruno
2008-10-19 Bruno Haible <address@hidden>
Add gethostname() declaration to <unistd.h>.
* lib/unistd.in.h (gethostname): New declaration.
* lib/gethostname.c: Include <unistd.h>.
* m4/gethostname.m4 (gl_FUNC_GETHOSTNAME): Require
gl_UNISTD_H_DEFAULTS. Set HAVE_GETHOSTNAME.
* m4/unistd_h.m4 (gl_UNISTD_H_DEFAULTS): Initialize GNULIB_GETHOSTNAME
and HAVE_GETHOSTNAME.
* modules/gethostname (Depends-on): Add unistd.
(configure.ac): Invoke gl_UNISTD_MODULE_INDICATOR.
(Include): Specify <unistd.h>.
* modules/unistd (Makefile.am): Substitute GNULIB_GETHOSTNAME and
HAVE_GETHOSTNAME.
* tests/test-gethostname.c: Include <unistd.h> first.
--- lib/unistd.in.h.orig 2008-10-19 17:24:06.000000000 +0200
+++ lib/unistd.in.h 2008-10-19 17:15:04.000000000 +0200
@@ -272,6 +272,26 @@
#endif
+#if @GNULIB_GETHOSTNAME@
+/* Return the standard host name of the machine.
+ WARNING! The host name may or may not be fully qualified.
+
+ Put up to LEN bytes of the host name into NAME.
+ Null terminate it if the name is shorter than LEN.
+ If the host name is longer than LEN, set errno = EINVAL and return -1.
+ Return 0 if successful, otherwise set errno and return -1. */
+# if address@hidden@
+extern int gethostname(char *name, size_t len);
+# endif
+#elif defined GNULIB_POSIXCHECK
+# undef gethostname
+# define gethostname(n,l) \
+ (GL_LINK_WARNING ("gethostname is unportable - " \
+ "use gnulib module gethostname for portability"), \
+ gethostname (n, l))
+#endif
+
+
#if @GNULIB_GETLOGIN_R@
/* Copies the user's login name to NAME.
The array pointed to by NAME has room for SIZE bytes.
--- lib/gethostname.c.orig 2008-10-19 17:24:06.000000000 +0200
+++ lib/gethostname.c 2008-10-19 17:17:31.000000000 +0200
@@ -19,6 +19,9 @@
#include <config.h>
+/* Specification. */
+#include <unistd.h>
+
#ifdef HAVE_UNAME
# include <sys/utsname.h>
#endif
--- m4/gethostname.m4.orig 2008-10-19 17:24:06.000000000 +0200
+++ m4/gethostname.m4 2008-10-19 17:21:01.000000000 +0200
@@ -1,13 +1,15 @@
-# gethostname.m4 serial 2
-dnl Copyright (C) 2002 Free Software Foundation, Inc.
+# gethostname.m4 serial 3
+dnl Copyright (C) 2002, 2008 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it,
dnl with or without modifications, as long as this notice is preserved.
AC_DEFUN([gl_FUNC_GETHOSTNAME],
[
+ AC_REQUIRE([gl_UNISTD_H_DEFAULTS])
AC_REPLACE_FUNCS(gethostname)
if test $ac_cv_func_gethostname = no; then
+ HAVE_GETHOSTNAME=0
gl_PREREQ_GETHOSTNAME
fi
])
--- m4/unistd_h.m4.orig 2008-10-19 17:24:06.000000000 +0200
+++ m4/unistd_h.m4 2008-10-19 17:15:51.000000000 +0200
@@ -1,4 +1,4 @@
-# unistd_h.m4 serial 15
+# unistd_h.m4 serial 16
dnl Copyright (C) 2006-2008 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it,
@@ -43,6 +43,7 @@
GNULIB_GETCWD=0; AC_SUBST([GNULIB_GETCWD])
GNULIB_GETDOMAINNAME=0; AC_SUBST([GNULIB_GETDOMAINNAME])
GNULIB_GETDTABLESIZE=0; AC_SUBST([GNULIB_GETDTABLESIZE])
+ GNULIB_GETHOSTNAME=0; AC_SUBST([GNULIB_GETHOSTNAME])
GNULIB_GETLOGIN_R=0; AC_SUBST([GNULIB_GETLOGIN_R])
GNULIB_GETPAGESIZE=0; AC_SUBST([GNULIB_GETPAGESIZE])
GNULIB_GETUSERSHELL=0; AC_SUBST([GNULIB_GETUSERSHELL])
@@ -59,6 +60,7 @@
HAVE_FTRUNCATE=1; AC_SUBST([HAVE_FTRUNCATE])
HAVE_GETDOMAINNAME=1; AC_SUBST([HAVE_GETDOMAINNAME])
HAVE_GETDTABLESIZE=1; AC_SUBST([HAVE_GETDTABLESIZE])
+ HAVE_GETHOSTNAME=1; AC_SUBST([HAVE_GETHOSTNAME])
HAVE_GETPAGESIZE=1; AC_SUBST([HAVE_GETPAGESIZE])
HAVE_GETUSERSHELL=1; AC_SUBST([HAVE_GETUSERSHELL])
HAVE_READLINK=1; AC_SUBST([HAVE_READLINK])
--- modules/gethostname.orig 2008-10-19 17:24:06.000000000 +0200
+++ modules/gethostname 2008-10-19 17:22:01.000000000 +0200
@@ -6,13 +6,16 @@
m4/gethostname.m4
Depends-on:
+unistd
configure.ac:
gl_FUNC_GETHOSTNAME
+gl_UNISTD_MODULE_INDICATOR([gethostname])
Makefile.am:
Include:
+<unistd.h>
License:
LGPL
--- modules/unistd.orig 2008-10-19 17:24:06.000000000 +0200
+++ modules/unistd 2008-10-19 17:16:27.000000000 +0200
@@ -35,6 +35,7 @@
-e 's|@''GNULIB_GETCWD''@|$(GNULIB_GETCWD)|g' \
-e 's|@''GNULIB_GETDOMAINNAME''@|$(GNULIB_GETDOMAINNAME)|g' \
-e 's|@''GNULIB_GETDTABLESIZE''@|$(GNULIB_GETDTABLESIZE)|g' \
+ -e 's|@''GNULIB_GETHOSTNAME''@|$(GNULIB_GETHOSTNAME)|g' \
-e 's|@''GNULIB_GETLOGIN_R''@|$(GNULIB_GETLOGIN_R)|g' \
-e 's|@''GNULIB_GETPAGESIZE''@|$(GNULIB_GETPAGESIZE)|g' \
-e 's|@''GNULIB_GETUSERSHELL''@|$(GNULIB_GETUSERSHELL)|g' \
@@ -50,6 +51,7 @@
-e 's|@''HAVE_FTRUNCATE''@|$(HAVE_FTRUNCATE)|g' \
-e 's|@''HAVE_GETDOMAINNAME''@|$(HAVE_GETDOMAINNAME)|g' \
-e 's|@''HAVE_GETDTABLESIZE''@|$(HAVE_GETDTABLESIZE)|g' \
+ -e 's|@''HAVE_GETHOSTNAME''@|$(HAVE_GETHOSTNAME)|g' \
-e 's|@''HAVE_GETPAGESIZE''@|$(HAVE_GETPAGESIZE)|g' \
-e 's|@''HAVE_GETUSERSHELL''@|$(HAVE_GETUSERSHELL)|g' \
-e 's|@''HAVE_READLINK''@|$(HAVE_READLINK)|g' \
--- tests/test-gethostname.c.orig 2008-10-19 17:24:06.000000000 +0200
+++ tests/test-gethostname.c 2008-10-19 17:11:10.000000000 +0200
@@ -17,10 +17,11 @@
#include <config.h>
+#include <unistd.h>
+
#include <stdio.h>
#include <string.h>
#include <errno.h>
-#include <unistd.h>
#define NOHOSTNAME "magic-gnulib-test-string"
- declare gethostname in unistd.h,
Bruno Haible <=
- Prev by Date:
mark atexit, memchr, memcmp, memcpy, memmove, memset, raise, rmdir, strcspn, strpbrk as obsolete
- Next by Date:
declare lstat in sys/stat.h
- Previous by thread:
mark atexit, memchr, memcmp, memcpy, memmove, memset, raise, rmdir, strcspn, strpbrk as obsolete
- Next by thread:
Re: declare gethostname in unistd.h
- Index(es):