aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiklos Szeredi <miklos@szeredi.hu>2006-06-06 09:48:30 +0000
committerMiklos Szeredi <miklos@szeredi.hu>2006-06-06 09:48:30 +0000
commit9dedb707f43ea1d2e989c41e91e348b1982f06ce (patch)
tree1ec43b3ad2e3dc26c35a4757b4c38271a19416ec
parentd021ce48ab5e32a1bf783b007cf656565d7eb6d8 (diff)
downloadlibfuse-9dedb707f43ea1d2e989c41e91e348b1982f06ce.tar.gz
fix
-rw-r--r--ChangeLog10
-rw-r--r--lib/helper.c12
2 files changed, 14 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index d8369ec..05af353 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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;
}