]> code.delx.au - gnu-emacs/commitdiff
Merge from gnulib, incorporating:
authorPaul Eggert <eggert@cs.ucla.edu>
Wed, 27 Nov 2013 23:58:03 +0000 (15:58 -0800)
committerPaul Eggert <eggert@cs.ucla.edu>
Wed, 27 Nov 2013 23:58:03 +0000 (15:58 -0800)
2013-11-13 getgroups: work around _DARWIN_C_SOURCE problem
* lib/getgroups.c: Update from gnulib.

ChangeLog
lib/getgroups.c

index 3f069391c29159bf56d79d9caa47433fae6e5c4b..278c77faf878701fbf40c5774ac11d07699e4578 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2013-11-27  Paul Eggert  <eggert@cs.ucla.edu>
+
+       Merge from gnulib, incorporating:
+       2013-11-13 getgroups: work around _DARWIN_C_SOURCE problem
+       * lib/getgroups.c: Update from gnulib.
+
 2013-11-27  Glenn Morris  <rgm@gnu.org>
 
        Move ja-dic, quail, leim-list.el from leim to lisp/leim.
index e71b5439c7e5eebc44be6f3a51b29c00248b051a..482b24a788ea0fcc460af0bb961f4c6b9ac5cfd1 100644 (file)
@@ -43,6 +43,21 @@ getgroups (int n _GL_UNUSED, GETGROUPS_T *groups _GL_UNUSED)
 #  define GETGROUPS_ZERO_BUG 0
 # endif
 
+/* On OS X 10.6 and later, use the usual getgroups, not the one
+   supplied when _DARWIN_C_SOURCE is defined.  _DARWIN_C_SOURCE is
+   normally defined, since it means "conform to POSIX, but add
+   non-POSIX extensions even if that violates the POSIX namespace
+   rules", which is what we normally want.  But with getgroups there
+   is an inconsistency, and _DARWIN_C_SOURCE means "change getgroups()
+   so that it no longer works right".  The BUGS section of compat(5)
+   says that the behavior is dubious if you compile different sections
+   of a program with different _DARWIN_C_SOURCE settings, so fix only
+   the offending symbol.  */
+# ifdef __APPLE__
+int posix_getgroups (int, gid_t []) __asm ("_getgroups");
+#  define getgroups posix_getgroups
+# endif
+
 /* On at least Ultrix 4.3 and NextStep 3.2, getgroups (0, NULL) always
    fails.  On other systems, it returns the number of supplemental
    groups for the process.  This function handles that special case