From: Miklos Szeredi Date: Tue, 13 Jul 2004 15:36:52 +0000 (+0000) Subject: add flag to turn off hiding removed but open files X-Git-Tag: fuse_1_9~32 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=2529ca23efd245afa9fb941626bb6caa5551f3f6;p=qemu-gpiodev%2Flibfuse.git add flag to turn off hiding removed but open files --- diff --git a/ChangeLog b/ChangeLog index 7918c83..e4198f9 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2004-07-13 Miklos Szeredi + + * Add FUSE_HARD_REMOVE flag, and '-i' option to fuse main, which + disable the "hide if open" behavior of unlink/rename. + 2004-07-12 Miklos Szeredi * Fix bug in do_open() in libfuse: open count was incremented diff --git a/include/fuse.h b/include/fuse.h index 7bb5a5a..782a51c 100644 --- a/include/fuse.h +++ b/include/fuse.h @@ -144,6 +144,10 @@ struct fuse_context { /** Enable debuging output */ #define FUSE_DEBUG (1 << 1) +/** If a file is removed but it's still open, don't hide the file but + remove it immediately */ +#define FUSE_HARD_REMOVE (1 << 2) + #ifdef __cplusplus extern "C" { #endif diff --git a/lib/fuse.c b/lib/fuse.c index 6689bf3..cebca07 100644 --- a/lib/fuse.c +++ b/lib/fuse.c @@ -814,7 +814,7 @@ static void do_unlink(struct fuse *f, struct fuse_in_header *in, char *name) if (path != NULL) { res = -ENOSYS; if (f->op.unlink) { - if (is_open(f, in->ino, name)) + if (!(f->flags & FUSE_HARD_REMOVE) && is_open(f, in->ino, name)) res = hide_node(f, path, in->ino, name); else { res = f->op.unlink(path); @@ -894,7 +894,8 @@ static void do_rename(struct fuse *f, struct fuse_in_header *in, res = -ENOSYS; if (f->op.rename) { res = 0; - if (is_open(f, newdir, newname)) + if (!(f->flags & FUSE_HARD_REMOVE) && + is_open(f, newdir, newname)) res = hide_node(f, newpath, newdir, newname); if (res == 0) { res = f->op.rename(oldpath, newpath); diff --git a/lib/helper.c b/lib/helper.c index e639d68..d597c46 100644 --- a/lib/helper.c +++ b/lib/helper.c @@ -30,6 +30,7 @@ static void usage(char *progname) " -d enable debug output (implies -f)\n" " -f foreground operation\n" " -s disable multithreaded operation\n" + " -i immediate removal (don't delay until last release)\n" " -h print help\n" "\n" "Fusermount options:\n" @@ -134,6 +135,10 @@ void fuse_main(int argc, char *argv[], const struct fuse_operations *op) background = 0; break; + case 'i': + flags |= FUSE_HARD_REMOVE; + break; + case 'f': background = 0; break;