aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiklos Szeredi <miklos@szeredi.hu>2004-07-13 15:36:52 +0000
committerMiklos Szeredi <miklos@szeredi.hu>2004-07-13 15:36:52 +0000
commit2529ca23efd245afa9fb941626bb6caa5551f3f6 (patch)
tree12593a61799b2c9e8c8597ed79d43b358459ce35
parent73798f95bdc347a159e4656e3e27d8603b778018 (diff)
downloadlibfuse-2529ca23efd245afa9fb941626bb6caa5551f3f6.tar.gz
add flag to turn off hiding removed but open files
-rw-r--r--ChangeLog5
-rw-r--r--include/fuse.h4
-rw-r--r--lib/fuse.c5
-rw-r--r--lib/helper.c5
4 files changed, 17 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 7918c83..e4198f9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2004-07-13 Miklos Szeredi <miklos@szeredi.hu>
+
+ * 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 <miklos@szeredi.hu>
* 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;