[svn] GnuPG - r4752 - in trunk: . m4 sm

svn author wk cvs at cvs.gnupg.org
Wed Apr 23 19:23:06 CEST 2008


Author: wk
Date: 2008-04-23 19:23:04 +0200 (Wed, 23 Apr 2008)
New Revision: 4752

Added:
   trunk/m4/socklen.m4
   trunk/m4/sys_socket_h.m4
Modified:
   trunk/ChangeLog
   trunk/configure.ac
   trunk/m4/ChangeLog
   trunk/m4/Makefile.am
   trunk/sm/ChangeLog
   trunk/sm/certchain.c
Log:
Fixed a C-89 incompatibility.
Minor changes to make it build on Debian bo.
Thanks to Alain Guibert.


Modified: trunk/ChangeLog
===================================================================
--- trunk/ChangeLog	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/ChangeLog	2008-04-23 17:23:04 UTC (rev 4752)
@@ -1,3 +1,7 @@
+2008-04-23  Werner Koch  <wk at g10code.com>
+
+	* configure.ac: Call gl_HEADER_SYS_SOCKET and gl_TYPE_SOCKLEN_T.
+
 2008-04-07  Werner Koch  <wk at g10code.com>
 
 	* configure.ac (ADNSLIBS): Test for adns.

Modified: trunk/m4/ChangeLog
===================================================================
--- trunk/m4/ChangeLog	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/m4/ChangeLog	2008-04-23 17:23:04 UTC (rev 4752)
@@ -1,3 +1,8 @@
+2008-04-23  Werner Koch  <wk at g10code.com>
+
+	* socklen.m4, sys_socket_h.m4: New.  Taken from libassuan.
+	* Makefile.am (EXTRA_DIST): Add them.
+
 2008-02-15  gettextize  <bug-gnu-gettext at gnu.org>
 
 	* gettext.m4: Upgrade to gettext-0.17.

Modified: trunk/sm/ChangeLog
===================================================================
--- trunk/sm/ChangeLog	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/sm/ChangeLog	2008-04-23 17:23:04 UTC (rev 4752)
@@ -1,3 +1,8 @@
+2008-04-23  Werner Koch  <wk at g10code.com>
+
+	* certchain.c (find_up): Make correct C89 code.  Declare variable
+	at the top of the block.  Reported by Alain Guibert.
+
 2008-04-09  Werner Koch  <wk at g10code.com>
 
 	* verify.c (gpgsm_verify): Print the message hash values on error.

Modified: trunk/configure.ac
===================================================================
--- trunk/configure.ac	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/configure.ac	2008-04-23 17:23:04 UTC (rev 4752)
@@ -992,6 +992,9 @@
 AC_TYPE_SIGNAL
 AC_DECL_SYS_SIGLIST
 
+gl_HEADER_SYS_SOCKET
+gl_TYPE_SOCKLEN_T
+
 AC_ARG_ENABLE(endian-check,
               AC_HELP_STRING([--disable-endian-check],
 	      [disable the endian check and trust the OS provided macros]),

Modified: trunk/m4/Makefile.am
===================================================================
--- trunk/m4/Makefile.am	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/m4/Makefile.am	2008-04-23 17:23:04 UTC (rev 4752)
@@ -10,5 +10,9 @@
 
 EXTRA_DIST += estream.m4
 
+EXTRA_DIST += sys_socket_h.m4 socklen.m4
 
 
+
+
+

Added: trunk/m4/socklen.m4
===================================================================
--- trunk/m4/socklen.m4	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/m4/socklen.m4	2008-04-23 17:23:04 UTC (rev 4752)
@@ -0,0 +1,52 @@
+# socklen.m4 serial 4
+dnl Copyright (C) 2005, 2006 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.
+
+dnl From Albert Chin, Windows fixes from Simon Josefsson.
+
+dnl Check for socklen_t: historically on BSD it is an int, and in
+dnl POSIX 1g it is a type of its own, but some platforms use different
+dnl types for the argument to getsockopt, getpeername, etc.  So we
+dnl have to test to find something that will work.
+
+dnl On mingw32, socklen_t is in ws2tcpip.h ('int'), so we try to find
+dnl it there first.  That file is included by gnulib's socket_.h, which
+dnl all users of this module should include.  Cygwin must not include
+dnl ws2tcpip.h.
+AC_DEFUN([gl_TYPE_SOCKLEN_T],
+  [AC_REQUIRE([gl_HEADER_SYS_SOCKET])dnl
+   AC_CHECK_TYPE([socklen_t], ,
+     [AC_MSG_CHECKING([for socklen_t equivalent])
+      AC_CACHE_VAL([gl_cv_gl_cv_socklen_t_equiv],
+	[# Systems have either "struct sockaddr *" or
+	 # "void *" as the second argument to getpeername
+	 gl_cv_socklen_t_equiv=
+	 for arg2 in "struct sockaddr" void; do
+	   for t in int size_t "unsigned int" "long int" "unsigned long int"; do
+	     AC_TRY_COMPILE(
+	       [#include <sys/types.h>
+		#include <sys/socket.h>
+
+		int getpeername (int, $arg2 *, $t *);],
+	       [$t len;
+		getpeername (0, 0, &len);],
+	       [gl_cv_socklen_t_equiv="$t"])
+	     test "$gl_cv_socklen_t_equiv" != "" && break
+	   done
+	   test "$gl_cv_socklen_t_equiv" != "" && break
+	 done
+      ])
+      if test "$gl_cv_socklen_t_equiv" = ""; then
+	AC_MSG_ERROR([Cannot find a type to use in place of socklen_t])
+      fi
+      AC_MSG_RESULT([$gl_cv_socklen_t_equiv])
+      AC_DEFINE_UNQUOTED([socklen_t], [$gl_cv_socklen_t_equiv],
+	[type to use in place of socklen_t if not defined])],
+     [#include <sys/types.h>
+      #if HAVE_SYS_SOCKET_H
+      # include <sys/socket.h>
+      #elif HAVE_WS2TCPIP_H
+      # include <ws2tcpip.h>
+      #endif])])

Added: trunk/m4/sys_socket_h.m4
===================================================================
--- trunk/m4/sys_socket_h.m4	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/m4/sys_socket_h.m4	2008-04-23 17:23:04 UTC (rev 4752)
@@ -0,0 +1,23 @@
+# sys_socket_h.m4 serial 2
+dnl Copyright (C) 2005, 2006 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.
+
+dnl From Simon Josefsson.
+
+AC_DEFUN([gl_HEADER_SYS_SOCKET],
+[
+  AC_CHECK_HEADERS_ONCE([sys/socket.h])
+  if test $ac_cv_header_sys_socket_h = yes; then
+    SYS_SOCKET_H=''
+  else
+    dnl We cannot use AC_CHECK_HEADERS_ONCE here, because that would make
+    dnl the check for those headers unconditional; yet cygwin reports
+    dnl that the headers are present but cannot be compiled (since on
+    dnl cygwin, all socket information should come from sys/socket.h).
+    AC_CHECK_HEADERS([winsock2.h ws2tcpip.h])
+    SYS_SOCKET_H='sys/socket.h'
+  fi
+  AC_SUBST(SYS_SOCKET_H)
+])

Modified: trunk/sm/certchain.c
===================================================================
--- trunk/sm/certchain.c	2008-04-21 19:13:36 UTC (rev 4751)
+++ trunk/sm/certchain.c	2008-04-23 17:23:04 UTC (rev 4752)
@@ -702,12 +702,14 @@
     rc = keydb_search_subject (kh, issuer);
   if (rc == -1 && !find_next)
     {
+      int old;
+
       /* Also try to get it from the Dirmngr cache.  The function
          merely puts it into the ephemeral database.  */
       find_up_dirmngr (ctrl, kh, NULL, issuer, 0);
 
       /* Not found, let us see whether we have one in the ephemeral key DB. */
-      int old = keydb_set_ephemeral (kh, 1);
+      old = keydb_set_ephemeral (kh, 1);
       if (!old)
         {
           keydb_search_reset (kh);




More information about the Gnupg-commits mailing list