X-Git-Url: https://git.rrq.au/?a=blobdiff_plain;ds=sidebyside;f=fuse_xattrs.c;h=48e136b0796ea94ea840912d2138452002ffbc8f;hb=717036c0ae228c0ea13a6bdf6b473fbb981d91dd;hp=610ad4a13ec1a19dd51730dd60215d697f408c69;hpb=b0063ac38ae833b543d7301f34ed19e559f7fe49;p=rrq%2Ffuse_xattrs.git diff --git a/fuse_xattrs.c b/fuse_xattrs.c index 610ad4a..48e136b 100644 --- a/fuse_xattrs.c +++ b/fuse_xattrs.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include @@ -35,6 +36,10 @@ static int xmp_setxattr(const char *path, const char *name, const char *value, size_t size, int flags) { + if (xattrs_config.show_sidecar == 0 && filename_is_sidecar(path) == 1) { + return -ENOENT; + } + if (get_namespace(name) != USER) { debug_print("Only user namespace is supported. name=%s\n", name); return -ENOTSUP; @@ -66,6 +71,10 @@ static int xmp_setxattr(const char *path, const char *name, const char *value, s static int xmp_getxattr(const char *path, const char *name, char *value, size_t size) { + if (xattrs_config.show_sidecar == 0 && filename_is_sidecar(path) == 1) { + return -ENOENT; + } + if (get_namespace(name) != USER) { debug_print("Only user namespace is supported. name=%s\n", name); return -ENOTSUP; @@ -85,6 +94,10 @@ static int xmp_getxattr(const char *path, const char *name, char *value, size_t static int xmp_listxattr(const char *path, char *list, size_t size) { + if (xattrs_config.show_sidecar == 0 && filename_is_sidecar(path) == 1) { + return -ENOENT; + } + if (size > XATTR_LIST_MAX) { debug_print("The size of the list of attribute names for this file exceeds the system-imposed limit.\n"); return -E2BIG; @@ -100,6 +113,10 @@ static int xmp_listxattr(const char *path, char *list, size_t size) static int xmp_removexattr(const char *path, const char *name) { + if (xattrs_config.show_sidecar == 0 && filename_is_sidecar(path) == 1) { + return -ENOENT; + } + if (get_namespace(name) != USER) { debug_print("Only user namespace is supported. name=%s\n", name); return -ENOTSUP; @@ -151,20 +168,6 @@ static struct fuse_operations xmp_oper = { }; -enum { - KEY_HELP, - KEY_VERSION, -}; - - -static struct fuse_opt xattrs_opts[] = { - FUSE_OPT_KEY("-V", KEY_VERSION), - FUSE_OPT_KEY("--version", KEY_VERSION), - FUSE_OPT_KEY("-h", KEY_HELP), - FUSE_OPT_KEY("--help", KEY_HELP), - FUSE_OPT_END -}; - int is_directory(const char *path) { struct stat statbuf; if (stat(path, &statbuf) != 0) { @@ -222,6 +225,23 @@ const char *sanitized_source_directory(const char *path) { return absolute_path; } +enum { + KEY_HELP, + KEY_VERSION, +}; + +#define FUSE_XATTRS_OPT(t, p, v) { t, offsetof(struct xattrs_config, p), v } + +static struct fuse_opt xattrs_opts[] = { + FUSE_XATTRS_OPT("show_sidecar", show_sidecar, 1), + + FUSE_OPT_KEY("-V", KEY_VERSION), + FUSE_OPT_KEY("--version", KEY_VERSION), + FUSE_OPT_KEY("-h", KEY_HELP), + FUSE_OPT_KEY("--help", KEY_HELP), + FUSE_OPT_END +}; + static int xattrs_opt_proc(void *data, const char *arg, int key, struct fuse_args *outargs) { (void) data; @@ -243,6 +263,7 @@ static int xattrs_opt_proc(void *data, const char *arg, int key, " -V --version print version\n" "\n" "FUSE XATTRS options:\n" + " -o show_sidecar don't hide sidecar files\n" "\n", outargs->argv[0]); fuse_opt_add_arg(outargs, "-ho");