diff options
author | Miklos Szeredi <miklos@szeredi.hu> | 2006-06-06 09:48:30 +0000 |
---|---|---|
committer | Miklos Szeredi <miklos@szeredi.hu> | 2006-06-06 09:48:30 +0000 |
commit | 9dedb707f43ea1d2e989c41e91e348b1982f06ce (patch) | |
tree | 1ec43b3ad2e3dc26c35a4757b4c38271a19416ec | |
parent | d021ce48ab5e32a1bf783b007cf656565d7eb6d8 (diff) | |
download | libfuse-9dedb707f43ea1d2e989c41e91e348b1982f06ce.tar.gz |
fix
-rw-r--r-- | ChangeLog | 10 | ||||
-rw-r--r-- | lib/helper.c | 12 |
2 files changed, 14 insertions, 8 deletions
@@ -1,3 +1,8 @@ +2006-06-05 Remy Blank <remy.blank@pobox.com> + + * lib: canonicalize mount point in fuse_helper_opt_proc() so that + unmounting succeeds even if mount point was relative. + 2006-06-04 Csaba Henk <csaba.henk@creo.hu> * lib: fix emergency umount in helper.c when malloc fails. @@ -9,11 +14,6 @@ Switch to "-pthread" from "-lpthread" as that's the preferred one on several platforms. Consulted with Terrence Cole and Miklos Szeredi - - -2006-05-16 Miklos Szeredi <miklos@szeredi.hu> - - * Test commit 2006-05-08 Miklos Szeredi <miklos@szeredi.hu> diff --git a/lib/helper.c b/lib/helper.c index 7f8ffa5..b6925d4 100644 --- a/lib/helper.c +++ b/lib/helper.c @@ -18,6 +18,7 @@ #include <unistd.h> #include <string.h> #include <limits.h> +#include <errno.h> enum { KEY_HELP, @@ -99,9 +100,14 @@ static int fuse_helper_opt_proc(void *data, const char *arg, int key, return 1; case FUSE_OPT_KEY_NONOPT: - if (!hopts->mountpoint) - return fuse_opt_add_opt(&hopts->mountpoint, arg); - else { + if (!hopts->mountpoint) { + char mountpoint[PATH_MAX]; + if (realpath(arg, mountpoint) == NULL) { + fprintf(stderr, "fuse: bad mount point `%s': %s\n", arg, strerror(errno)); + return -1; + } + return fuse_opt_add_opt(&hopts->mountpoint, mountpoint); + } else { fprintf(stderr, "fuse: invalid argument `%s'\n", arg); return -1; } |