From 4c3f86499f8dfe344fb5f92b805e8c090290a79e Mon Sep 17 00:00:00 2001 From: Matt Colyer Date: Thu, 7 Aug 2008 00:00:12 -0700 Subject: Added cleanup when closing a file, probably needs a bit more throughness but its a start. Added a missing unlock call so you can read a file more than once.--- src/ifuse.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) (limited to 'src/ifuse.c') diff --git a/src/ifuse.c b/src/ifuse.c index a56289d..3d921fd 100644 --- a/src/ifuse.c +++ b/src/ifuse.c @@ -112,10 +112,25 @@ static int ifuse_read(const char *path, char *buf, size_t size, off_t offset, } bytes = afc_read_file(afc, file, buf, size); - return bytes; } +static int ifuse_release(const char *path, struct fuse_file_info *fi){ + AFCFile *file; + AFClient *afc = fuse_get_context()->private_data; + + file = g_hash_table_lookup(file_handles, &(fi->fh)); + if (!file){ + return -ENOENT; + } + afc_close_file(afc, file); + + free(file); + g_hash_table_remove(file_handles, &(fi->fh)); + + return 0; +} + void *ifuse_init(struct fuse_conn_info *conn) { char *response = (char*)malloc(sizeof(char) * 2048); int bytes = 0, port = 0, i = 0; @@ -171,6 +186,7 @@ static struct fuse_operations ifuse_oper = { .readdir = ifuse_readdir, .open = ifuse_open, .read = ifuse_read, + .release = ifuse_release, .init = ifuse_init, .destroy = ifuse_cleanup }; -- cgit v1.1-32-gdbae