New module 'ioctl'.
authorBruno Haible <bruno@clisp.org>
Fri, 10 Oct 2008 02:33:25 +0000 (04:33 +0200)
committerBruno Haible <bruno@clisp.org>
Fri, 10 Oct 2008 02:33:25 +0000 (04:33 +0200)
ChangeLog
doc/posix-functions/ioctl.texi
lib/sys_socket.in.h
lib/winsock.c
m4/sys_socket_h.m4
modules/ioctl [new file with mode: 0644]
modules/sys_socket

index 09a8967..37f0bbf 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,17 @@
 2008-10-09  Bruno Haible  <bruno@clisp.org>
 
+       New module 'ioctl'.
+       * modules/ioctl: New file.
+       * lib/sys_socket.in.h (ioctl): Remove declaration.
+       * lib/winsock.c: Include <sys/ioctl.h>.
+       (rpl_ioctl): Define only of the gnulib module 'ioctl' is present.
+       * m4/sys_socket_h.m4 (gl_PREREQ_SYS_H_WINSOCK2): Require
+       gl_SYS_IOCTL_H_DEFAULTS. Set also SYS_IOCTL_H_HAVE_WINSOCK2_H.
+       * modules/sys_socket (Files): Add m4/sys_ioctl_h.m4.
+       * doc/posix-functions/ioctl.texi: Mention the new module.
+
+2008-10-09  Bruno Haible  <bruno@clisp.org>
+
        New module 'sys_ioctl'.
        * lib/sys_ioctl.in.h: New file.
        * m4/sys_ioctl_h.m4: New file.
index 86235d8..123069b 100644 (file)
@@ -4,7 +4,7 @@
 
 POSIX specification: @url{http://www.opengroup.org/susv3xsh/ioctl.html}
 
-Gnulib module: sys_socket
+Gnulib module: ioctl
 
 Portability problems fixed by Gnulib:
 @itemize
index ddc4264..ad0860c 100644 (file)
@@ -279,12 +279,6 @@ extern int rpl_listen (int, int);
       listen (s, b))
 # endif
 
-# if @HAVE_WINSOCK2_H@
-#  undef ioctl
-#  define ioctl                        rpl_ioctl
-extern int rpl_ioctl (int, int, ...);
-# endif
-
 # if @GNULIB_RECV@
 #  if @HAVE_WINSOCK2_H@
 #   undef recv
index 53b9336..2ca7813 100644 (file)
@@ -25,6 +25,9 @@
 #include <fcntl.h>
 #include <io.h>
 #include <sys/socket.h>
+#if GNULIB_IOCTL
+#include <sys/ioctl.h>
+#endif
 
 #undef socket
 #undef connect
@@ -224,6 +227,7 @@ rpl_listen (int fd, int backlog)
 }
 #endif
 
+#if GNULIB_IOCTL
 int
 rpl_ioctl (int fd, int req, ...)
 {
@@ -243,6 +247,7 @@ rpl_ioctl (int fd, int req, ...)
 
   return r;
 }
+#endif
 
 #if GNULIB_RECV
 int
index e61de7b..e60ce73 100644 (file)
@@ -1,4 +1,4 @@
-# sys_socket_h.m4 serial 9
+# sys_socket_h.m4 serial 10
 dnl Copyright (C) 2005-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,
@@ -72,6 +72,7 @@ AC_DEFUN([gl_HEADER_SYS_SOCKET],
 AC_DEFUN([gl_PREREQ_SYS_H_WINSOCK2],
 [
   AC_REQUIRE([gl_UNISTD_H_DEFAULTS])
+  AC_REQUIRE([gl_SYS_IOCTL_H_DEFAULTS])
   AC_CHECK_HEADERS_ONCE([sys/socket.h])
   if test $ac_cv_header_sys_socket_h != yes; then
     dnl We cannot use AC_CHECK_HEADERS_ONCE here, because that would make
@@ -83,6 +84,7 @@ AC_DEFUN([gl_PREREQ_SYS_H_WINSOCK2],
   if test "$ac_cv_header_winsock2_h" = yes; then
     HAVE_WINSOCK2_H=1
     UNISTD_H_HAVE_WINSOCK2_H=1
+    SYS_IOCTL_H_HAVE_WINSOCK2_H=1
   else
     HAVE_WINSOCK2_H=0
   fi
diff --git a/modules/ioctl b/modules/ioctl
new file mode 100644 (file)
index 0000000..b425dee
--- /dev/null
@@ -0,0 +1,30 @@
+Description:
+ioctl() function: issue device specific requests on files, devices, or sockets.
+
+Files:
+lib/winsock.c
+
+Depends-on:
+sys_ioctl
+sys_socket
+errno
+
+configure.ac:
+AC_REQUIRE([gl_HEADER_SYS_SOCKET])
+if test "$ac_cv_header_winsock2_h" = yes; then
+  AC_LIBOBJ([winsock])
+  gl_REPLACE_SYS_IOCTL_H
+fi
+gl_SYS_IOCTL_MODULE_INDICATOR([ioctl])
+gl_MODULE_INDICATOR([ioctl])
+
+Makefile.am:
+
+Include:
+<sys/ioctl.h>
+
+License:
+LGPLv2+
+
+Maintainer:
+Paolo Bonzini, Simon Josefsson, Bruno Haible
index 0d43570..016dedd 100644 (file)
@@ -7,6 +7,7 @@ lib/winsock.c
 m4/sys_socket_h.m4
 m4/sockpfaf.m4
 m4/unistd_h.m4
+m4/sys_ioctl_h.m4
 
 Depends-on:
 include_next