changeset 9557:81a0ee2e4e00

Ensure that 'glob' stays under LGPLv2+.
author Bruno Haible <bruno@clisp.org>
date Mon, 31 Dec 2007 11:51:57 +0100
parents fb91bcae1096
children c487592d112a
files ChangeLog lib/glob.c m4/glob.m4 modules/glob
diffstat 4 files changed, 30 insertions(+), 6 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2007-12-25  Bruno Haible  <bruno@clisp.org>
+
+	Fixup after 2007-10-17 commit. Ensure that 'glob' stays under LGPLv2+.
+	* lib/glob.c: Don't include openat.h.
+	(link_exists2_p): Add back the code that deals with the
+	!GLOB_ALTDIRFUNC case.
+	(link_exists_p) [!_LIBC && !HAVE_FSTATAT]: Just call link_exists2_p and
+	let it do the filename concatenation.
+	* m4/glob.m4 (gl_PREREQ_GLOB): Add check for fstatat.
+	* modules/glob (Depends-on): Remove openat.
+
 2007-12-31  Bruno Haible  <bruno@clisp.org>
 
 	* modules/dirfd (License): Change to LGPLv2+.
--- a/lib/glob.c
+++ b/lib/glob.c
@@ -147,7 +147,6 @@
 
 #ifndef _LIBC
 # include "dirfd.h"
-# include "openat.h"
 #endif
 
 #ifdef _SC_GETPW_R_SIZE_MAX
@@ -1218,13 +1217,17 @@
 #endif /* !GLOB_ONLY_P */
 
 
+#if !defined _LIBC || !defined GLOB_ONLY_P
 /* We put this in a separate function mainly to allow the memory
    allocated with alloca to be recycled.  */
-#if !defined _LIBC || !defined GLOB_ONLY_P
 static int
 __attribute_noinline__
 link_exists2_p (const char *dir, size_t dirlen, const char *fname,
-		glob_t *pglob)
+		glob_t *pglob
+# if !defined _LIBC && !HAVE_FSTATAT
+		, int flags
+# endif
+		)
 {
   size_t fnamelen = strlen (fname);
   char *fullname = __alloca (dirlen + 1 + fnamelen + 1);
@@ -1233,6 +1236,13 @@
   mempcpy (mempcpy (mempcpy (fullname, dir, dirlen), "/", 1),
 	   fname, fnamelen + 1);
 
+# if !defined _LIBC && !HAVE_FSTATAT
+  if (__builtin_expect ((flags & GLOB_ALTDIRFUNC) == 0, 1))
+    {
+      struct_stat64 st64;
+      return __stat64 (fullname, &st64) == 0;
+    }
+# endif
   return (*pglob->gl_stat) (fullname, &st) == 0;
 }
 
@@ -1241,6 +1251,7 @@
 link_exists_p (int dfd, const char *dir, size_t dirlen, const char *fname,
 	       glob_t *pglob, int flags)
 {
+# if defined _LIBC || HAVE_FSTATAT
   if (__builtin_expect (flags & GLOB_ALTDIRFUNC, 0))
     return link_exists2_p (dir, dirlen, fname, pglob);
   else
@@ -1248,6 +1259,9 @@
       struct_stat64 st64;
       return __fxstatat64 (_STAT_VER, dfd, fname, &st64, 0) == 0;
     }
+# else
+  return link_exists2_p (dir, dirlen, fname, pglob, flags);
+# endif
 }
 #endif
 
--- a/m4/glob.m4
+++ b/m4/glob.m4
@@ -1,4 +1,4 @@
-# glob.m4 serial 9
+# glob.m4 serial 10
 dnl Copyright (C) 2005-2007 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
@@ -82,5 +82,5 @@
     HAVE_SYS_CDEFS_H=0
   fi
   AC_SUBST([HAVE_SYS_CDEFS_H])
-  AC_CHECK_FUNCS_ONCE([getlogin_r getpwnam_r])dnl
+  AC_CHECK_FUNCS_ONCE([fstatat getlogin_r getpwnam_r])dnl
 ])
--- a/modules/glob
+++ b/modules/glob
@@ -16,7 +16,6 @@
 fnmatch
 getlogin_r
 mempcpy
-openat
 strdup
 sys_stat
 unistd