autoconf
autoheader
- ./configure --with-acl-support --with-xattr-support
+ ./configure --enable-acl-support --enable-xattr-support
make proto
make
+AC_CHECK_HEADERS(attr/xattr.h)
+AC_MSG_CHECKING(whether to support extended attributes)
-+AC_ARG_WITH(xattr-support,
-+[ --with-xattr-support Include extended attribute support (default=no)],
++AC_ARG_ENABLE(xattr-support,
++AC_HELP_STRING([--enable-xattr-support], [Include extended attribute support (default=no)]),
+[ case "$withval" in
+ yes)
+ case "$host_os" in
--- orig/flist.c 2005-07-29 02:49:06
+++ flist.c 2005-05-12 22:55:41
-@@ -976,6 +976,8 @@ static struct file_struct *send_file_nam
+@@ -970,6 +970,8 @@ static struct file_struct *send_file_nam
return NULL;
if (MAKE_ACL(file, fname) < 0)
return NULL;
maybe_emit_filelist_progress(flist->count + flist_count_offset);
-@@ -985,9 +987,11 @@ static struct file_struct *send_file_nam
+@@ -979,9 +981,11 @@ static struct file_struct *send_file_nam
flist->files[flist->count++] = file;
send_file_entry(file, f, base_flags);
SEND_ACL(file, f);
}
return file;
}
-@@ -1334,6 +1338,7 @@ struct file_list *recv_file_list(int f)
+@@ -1328,6 +1332,7 @@ struct file_list *recv_file_list(int f)
file = receive_file_entry(flist, flags, f);
RECEIVE_ACL(file, f);
if (S_ISREG(file->mode))
stats.total_size += file->length;
-@@ -1358,6 +1363,7 @@ struct file_list *recv_file_list(int f)
+@@ -1352,6 +1357,7 @@ struct file_list *recv_file_list(int f)
clean_flist(flist, relative_paths, 1);
SORT_FILE_ACL_INDEX_LISTS();
/* Note that this field may not have type ino_t. It depends
* on the complicated interaction between largefile feature
-@@ -291,6 +295,7 @@ void usage(enum logcode F)
+@@ -290,6 +294,7 @@ void usage(enum logcode F)
rprintf(F," -K, --keep-dirlinks treat symlinked dir on receiver as dir\n");
rprintf(F," -p, --perms preserve permissions\n");
rprintf(F," -A, --acls preserve ACLs (implies --perms)\n");
{"times", 't', POPT_ARG_VAL, &preserve_times, 1, 0, 0 },
{"no-times", 0, POPT_ARG_VAL, &preserve_times, 0, 0, 0 },
{"no-t", 0, POPT_ARG_VAL, &preserve_times, 0, 0, 0 },
-@@ -943,6 +951,17 @@ int parse_arguments(int *argc, const cha
+@@ -954,6 +962,17 @@ int parse_arguments(int *argc, const cha
return 0;
#endif /* SUPPORT_ACLS */
default:
/* A large opt value means that set_refuse_options()
-@@ -1359,6 +1378,8 @@ void server_options(char **args,int *arg
+@@ -1378,6 +1397,8 @@ void server_options(char **args,int *arg
argstr[x++] = 'H';
if (preserve_acls)
argstr[x++] = 'A';
enum logcode code = daemon_log_format_has_i || dry_run
--- orig/rsync.h 2005-07-29 02:25:55
+++ rsync.h 2005-05-12 23:19:46
-@@ -684,6 +684,38 @@ struct stats {
+@@ -688,6 +688,38 @@ struct stats {
#endif /* SUPPORT_ACLS */
#include "smb_acls.h"
/* We have replacement versions of these if they're missing. */
--- orig/rsync.yo 2004-07-03 20:11:58
+++ rsync.yo 2005-03-03 01:33:53
-@@ -319,6 +319,7 @@ to the detailed description below for a
+@@ -317,6 +317,7 @@ to the detailed description below for a
-K, --keep-dirlinks treat symlinked dir on receiver as dir
-p, --perms preserve permissions
-A, --acls preserve ACLs (implies -p) [local option]