changeset 10146:3c71b6fb6b10

Extend ACL support tests to support OSF/1, MacOS X, HP-UX, AIX.
author Bruno Haible <bruno@clisp.org>
date Mon, 02 Jun 2008 13:01:53 +0200
parents 1c6dc066fe6d
children b6cf6bba0c9d
files ChangeLog m4/acl.m4 modules/acl-tests
diffstat 3 files changed, 102 insertions(+), 50 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog	Mon Jun 02 11:32:02 2008 +0200
+++ b/ChangeLog	Mon Jun 02 13:01:53 2008 +0200
@@ -1,3 +1,12 @@
+2008-06-01  Bruno Haible  <bruno@clisp.org>
+
+	* m4/acl.m4 (gl_FUNC_ACL): Separate the POSIX-like and the Solaris
+	tests. Test for libpacl, needed for OSF/1. Test for extended ACLs,
+	needed for MacOS X. Test for HP-UX API. Test for newer and older AIX
+	APIs.
+	* modules/acl-tests (configure.ac): Remove tests now contained in
+	m4/acl.m4.
+
 2008-06-02  Jim Meyering  <meyering@redhat.com>
 
 	announce-gen: use a better key-server host name
--- a/m4/acl.m4	Mon Jun 02 11:32:02 2008 +0200
+++ b/m4/acl.m4	Mon Jun 02 13:01:53 2008 +0200
@@ -1,5 +1,5 @@
 # acl.m4 - check for access control list (ACL) primitives
-# serial 7
+# serial 8
 
 # Copyright (C) 2002, 2004-2008 Free Software Foundation, Inc.
 # This file is free software; the Free Software Foundation
@@ -18,43 +18,100 @@
   use_acl=0
   AC_REQUIRE([AC_C_INLINE])
   if test "x$enable_acl" != "xno"; then
-    dnl Prerequisites of lib/acl.c.
-    AC_CHECK_HEADERS(sys/acl.h)
+    dnl On all platforms, the ACL related API is declared in <sys/acl.h>.
+    AC_CHECK_HEADERS([sys/acl.h])
     if test $ac_cv_header_sys_acl_h = yes; then
       ac_save_LIBS=$LIBS
-      AC_CHECK_FUNCS([acl])
-      use_acl=1
-      AC_SEARCH_LIBS([acl_trivial], [sec],
-	[test "$ac_cv_search_acl_trivial" = "none required" ||
-	 LIB_ACL=$ac_cv_search_acl_trivial
-	 AC_CHECK_FUNCS([acl_trivial])],
-	[AC_CHECK_FUNCS([acl_trivial])
-	 if test $ac_cv_func_acl_trivial != yes; then
-	   dnl -lacl is needed on Linux, -lpacl is needed on OSF/1.
-	   AC_SEARCH_LIBS([acl_get_file], [acl pacl],
-	     [test "$ac_cv_search_acl_get_file" = "none required" ||
-	      LIB_ACL=$ac_cv_search_acl_get_file
-	      AC_CHECK_FUNCS(
-		[acl_get_file acl_get_fd acl_set_file acl_set_fd \
-		 acl_free acl_from_mode acl_from_text \
-		 acl_delete_def_file acl_extended_file \
-		 acl_delete_fd_np acl_delete_file_np \
-		 acl_copy_ext_native acl_create_entry_np \
-		 acl_to_short_text acl_free_text])
-	      if test $ac_cv_func_acl_get_file = yes; then
-		# If the acl_get_file bug is detected, disable all ACL support.
-		gl_ACL_GET_FILE( , [use_acl=0])
-	      fi
-	      if test $use_acl = 1; then
-		AC_CHECK_HEADERS([acl/libacl.h])
-		if test $ac_cv_func_acl_get_file = yes &&
-		   test $ac_cv_func_acl_free = yes; then
-		  AC_REPLACE_FUNCS([acl_entries])
-		fi
-	      else
-		LIB_ACL=
-	      fi])
-	 fi])
+
+      dnl Test for POSIX-draft-like API (Linux, FreeBSD, MacOS X, IRIX, Tru64).
+      dnl -lacl is needed on Linux, -lpacl is needed on OSF/1.
+      if test $use_acl = 0; then
+	AC_SEARCH_LIBS([acl_get_file], [acl pacl],
+	  [if test "$ac_cv_search_acl_get_file" != "none required"; then
+	     LIB_ACL=$ac_cv_search_acl_get_file
+           fi
+	   AC_CHECK_FUNCS(
+	     [acl_get_file acl_get_fd acl_set_file acl_set_fd \
+	      acl_free acl_from_mode acl_from_text \
+	      acl_delete_def_file acl_extended_file \
+	      acl_delete_fd_np acl_delete_file_np \
+	      acl_copy_ext_native acl_create_entry_np \
+	      acl_to_short_text acl_free_text])
+	   # If the acl_get_file bug is detected, don't enable the ACL support.
+	   gl_ACL_GET_FILE([use_acl=1], [])
+	   if test $use_acl = 1; then
+	     dnl On Linux, additional API is declared in <acl/libacl.h>.
+	     AC_CHECK_HEADERS([acl/libacl.h])
+	     AC_REPLACE_FUNCS([acl_entries])
+	     AC_CACHE_CHECK([for ACL_FIRST_ENTRY],
+	       [gl_cv_acl_ACL_FIRST_ENTRY],
+	       [AC_COMPILE_IFELSE(
+[[#include <sys/types.h>
+#include <sys/acl.h>
+int type = ACL_FIRST_ENTRY;]],
+		  [gl_cv_acl_ACL_FIRST_ENTRY=yes],
+		  [gl_cv_acl_ACL_FIRST_ENTRY=no])])
+	     if test $gl_cv_acl_ACL_FIRST_ENTRY = yes; then
+	       AC_DEFINE([HAVE_ACL_FIRST_ENTRY], 1,
+		 [Define to 1 if the constant ACL_FIRST_ENTRY exists.])
+	     fi
+	     dnl On MacOS X, other types of ACLs are supported.
+	     AC_CACHE_CHECK([for ACL_TYPE_EXTENDED],
+	       [gl_cv_acl_ACL_TYPE_EXTENDED],
+	       [AC_COMPILE_IFELSE(
+[[#include <sys/types.h>
+#include <sys/acl.h>
+int type = ACL_TYPE_EXTENDED;]],
+		  [gl_cv_acl_ACL_TYPE_EXTENDED=yes],
+		  [gl_cv_acl_ACL_TYPE_EXTENDED=no])])
+	     if test $gl_cv_acl_ACL_TYPE_EXTENDED = yes; then
+	       AC_DEFINE([HAVE_ACL_TYPE_EXTENDED], 1,
+		 [Define to 1 if the ACL type ACL_TYPE_EXTENDED exists.])
+	     fi
+	   else
+	     LIB_ACL=
+	   fi
+	  ])
+      fi
+
+      dnl Test for Solaris API (Solaris, Cygwin).
+      if test $use_acl = 0; then
+	AC_CHECK_FUNCS([acl])
+	if test $ac_cv_func_acl = yes; then
+	  AC_SEARCH_LIBS([acl_trivial], [sec],
+	    [if test "$ac_cv_search_acl_trivial" != "none required"; then
+	       LIB_ACL=$ac_cv_search_acl_trivial
+	     fi
+	    ])
+	  AC_CHECK_FUNCS([acl_trivial])
+	  use_acl=1
+	fi
+      fi
+
+      dnl Test for HP-UX API.
+      if test $use_acl = 0 || test "$ac_cv_func_acl" = yes; then
+	AC_CHECK_FUNCS([getacl])
+	if test $ac_cv_func_getacl = yes; then
+	  use_acl=1
+	fi
+      fi
+
+      dnl Test for AIX API (AIX 5.3 or newer).
+      if test $use_acl = 0; then
+	AC_CHECK_FUNCS([aclx_get])
+	if test $ac_cv_func_aclx_get = yes; then
+	  use_acl=1
+	fi
+      fi
+
+      dnl Test for older AIX API.
+      if test $use_acl = 0 || test "$ac_cv_func_aclx_get" = yes; then
+	AC_CHECK_FUNCS([statacl])
+	if test $ac_cv_func_statacl = yes; then
+	  use_acl=1
+	fi
+      fi
+
       LIBS=$ac_save_LIBS
     fi
     if test "x$enable_acl$use_acl" = "xyes0"; then
--- a/modules/acl-tests	Mon Jun 02 11:32:02 2008 +0200
+++ b/modules/acl-tests	Mon Jun 02 13:01:53 2008 +0200
@@ -14,20 +14,6 @@
 xalloc
 
 configure.ac:
-AC_REQUIRE([gl_FUNC_ACL])
-save_LIBS="$LIBS"
-LIBS="$LIB_ACL $LIBS"
-dnl Test for functions present on Linux, FreeBSD, MacOS X, IRIX, Tru64.
-AC_CHECK_FUNCS([acl_get_file])
-dnl Test for functions present on Solaris, Cygwin.
-AC_CHECK_FUNCS([acl])
-dnl Test for functions present on HP-UX.
-AC_CHECK_FUNCS([getacl])
-dnl Test for functions present on AIX.
-AC_CHECK_FUNCS([aclx_get])
-dnl Test for functions present on older AIX.
-AC_CHECK_FUNCS([statacl])
-LIBS="$save_LIBS"
 
 Makefile.am:
 TESTS += test-file-has-acl.sh test-set-mode-acl.sh test-copy-acl.sh