fix
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 @@
         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;
         }