diff options
author | Christian Brabandt <cb@256bit.org> | 2023-09-30 12:49:18 +0200 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2023-09-30 12:49:18 +0200 |
commit | e085dfda5d8dde064b0332464040959479696d1c (patch) | |
tree | b9d30e78eb9335de6f2db790f888f0a9bd9514d7 /src/configure.ac | |
parent | 1f025b01e29be6fce907d0379602b45031d6998f (diff) |
patch 9.0.1962: No support for writing extended attributesv9.0.1962
Problem: No support for writing extended attributes
Solution: Add extended attribute support for linux
It's been a long standing issue, that if you write a file with extended
attributes and backupcopy is set to no, the file will loose the extended
attributes.
So this patch adds support for retrieving the extended attributes and
copying it to the new file. It currently only works on linux, mainly
because I don't know the different APIs for other systems (BSD, MacOSX and
Solaris). On linux, this should be supported since Kernel 2.4 or
something, so this should be pretty safe to use now.
Enable the extended attribute support with normal builds.
I also added it explicitly to the :version output as well as make it
able to check using `:echo has("xattr")`, to have users easily check
that this is available.
In contrast to the similar support for SELINUX and SMACK support (which
also internally uses extended attributes), I have made this a FEAT_XATTR
define, instead of the similar HAVE_XATTR.
Add a test and change CI to include relevant packages so that CI can
test that extended attributes are correctly written.
closes: #306
closes: #13203
Signed-off-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/configure.ac')
-rw-r--r-- | src/configure.ac | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/configure.ac b/src/configure.ac index bfdcfea4d2..e21e23490a 100644 --- a/src/configure.ac +++ b/src/configure.ac @@ -513,6 +513,18 @@ if test "x$found_smack" = "x"; then fi fi +dnl enable xattr support +AC_MSG_CHECKING(--enable-xattr argument) +AC_ARG_ENABLE(xattr, + [ --disable-xattr Do not check for XATTR support.], + , enable_xattr="yes") +if test "$enable_xattr" = "yes"; then + AC_MSG_RESULT(yes) + AC_CHECK_HEADER([attr/xattr.h], [AC_DEFINE(HAVE_XATTR)]) +else + AC_MSG_RESULT(no) +fi + dnl Check user requested features. AC_MSG_CHECKING(--with-features argument) |