Mercurial > gnulib
changeset 17962:58658f2c2c44
acl: On Linux, check for acls without libacl
On Linux, use the getxattr syscall instead of the acl_extended_file libacl
library function to check for the presence of acls, avoiding a library
dependency.
* lib/file-has-acl.c: Include xattr headers if we have them.
(file_has_acl): On Linux, use getxattr().
* m4/acl.m4 (gl_FUNC_ACL): Define LIB_HAS_ACL as the libraries to link with for
file_has_acl(). Check for xattr headers and getxattr().
* modules/acl: Add a dep on the stdbool module which was already needed.
Add the new reduced dependency LIB_HAS_ACL reference.
author | Andreas Gruenbacher <andreas.gruenbacher@gmail.com> |
---|---|
date | Sun, 12 Apr 2015 16:36:37 +0200 |
parents | 19e7a05866b5 |
children | d4fc0c72ed64 |
files | ChangeLog NEWS lib/file-has-acl.c m4/acl.m4 modules/acl |
diffstat | 5 files changed, 68 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog Sun Apr 12 16:36:36 2015 +0200 +++ b/ChangeLog Sun Apr 12 16:36:37 2015 +0200 @@ -1,3 +1,13 @@ +2015-04-15 Andreas Gruenbacher <andreas.gruenbacher@gmail.com> + + acl: On Linux, check for acls without libacl + On Linux, use the getxattr syscall instead of the acl_extended_file libacl + library function to check for the presence of acls, avoiding a library. + * lib/file-has-acl.c: Include xattr headers if we have them. + (file_has_acl): On Linux, use getxattr(). + * m4/acl.m4 (gl_FUNC_ACL): Define LIB_HAS_ACL as the libraries to link with for + file_has_acl(). Check for xattr headers and getxattr(). + 2015-04-14 Ángel González <keisial@gmail.com> tempname: avoid unused parameter warnings (trivial)
--- a/NEWS Sun Apr 12 16:36:36 2015 +0200 +++ b/NEWS Sun Apr 12 16:36:37 2015 +0200 @@ -3,6 +3,11 @@ Date Modules Changes +2015-04-15 acl If your project only uses the file_has_acl() + detection routine, then the requirements are + potentially reduced by using $LIB_HAS_ACL rather + than $LIB_ACL. + 2013-04-24 gettext If your project uses 'gettextize --intl' it is now your responsibility to put -I$(top_builddir)/intl into the Makefile.am for gnulib.
--- a/lib/file-has-acl.c Sun Apr 12 16:36:36 2015 +0200 +++ b/lib/file-has-acl.c Sun Apr 12 16:36:37 2015 +0200 @@ -29,6 +29,13 @@ #include "acl-internal.h" +#if HAVE_SYS_XATTR_H +# include <sys/xattr.h> +#endif + +#if HAVE_LINUX_XATTR_H +# include <linux/xattr.h> +#endif /* Return 1 if NAME has a nontrivial access control list, 0 if NAME only has no or a base access control list, and -1 (setting errno) @@ -41,7 +48,33 @@ #if USE_ACL if (! S_ISLNK (sb->st_mode)) { -# if HAVE_ACL_GET_FILE + +# if HAVE_GETXATTR && defined XATTR_NAME_POSIX_ACL_ACCESS && defined XATTR_NAME_POSIX_ACL_DEFAULT + + ssize_t ret; + + ret = getxattr (name, XATTR_NAME_POSIX_ACL_ACCESS, NULL, 0); + if (ret < 0) + { + if (errno != ENODATA) + return -1; + } + else if (ret > 0) + return 1; + if (S_ISDIR (sb->st_mode)) + { + ret = getxattr (name, XATTR_NAME_POSIX_ACL_DEFAULT, NULL, 0); + if (ret < 0) + { + if (errno != ENODATA) + return -1; + } + else if (ret > 0) + return 1; + } + return 0; + +# elif HAVE_ACL_GET_FILE /* POSIX 1003.1e (draft 17 -- abandoned) specific version. */ /* Linux, FreeBSD, Mac OS X, IRIX, Tru64 */
--- a/m4/acl.m4 Sun Apr 12 16:36:36 2015 +0200 +++ b/m4/acl.m4 Sun Apr 12 16:36:37 2015 +0200 @@ -16,6 +16,7 @@ AC_CHECK_FUNCS_ONCE([fchmod]) LIB_ACL= + LIB_HAS_ACL= use_acl=0 if test "x$enable_acl" != "xno"; then dnl On all platforms, the ACL related API is declared in <sys/acl.h>. @@ -124,6 +125,21 @@ LIBS=$ac_save_LIBS fi + + dnl On Linux, testing if a file has an acl can be done with the getxattr + dnl syscall which doesn't require linking against additional libraries. + use_xattrs=0 + AC_CHECK_HEADERS([sys/xattr.h linux/xattr.h]) + if test $ac_cv_header_sys_xattr_h = yes && test $ac_cv_header_linux_xattr_h = yes; then + AC_CHECK_FUNCS([getxattr]) + if test $ac_cv_func_getxattr = yes; then + use_xattrs=1 + fi + fi + if test use_xattrs = 0; then + LIB_HAS_ACL=$LIB_ACL + fi + if test "x$enable_acl$use_acl" = "xyes0"; then AC_MSG_ERROR([ACLs enabled but support not detected]) elif test "x$enable_acl$use_acl" = "xauto0"; then @@ -132,6 +148,7 @@ fi fi AC_SUBST([LIB_ACL]) + AC_SUBST([LIB_HAS_ACL]) AC_DEFINE_UNQUOTED([USE_ACL], [$use_acl], [Define to nonzero if you want access control list support.]) USE_ACL=$use_acl