Bug 561172 – gnome-open fails on local URIs with anchors
authorAlexander Larsson <alexl@redhat.com>
Tue, 3 Mar 2009 19:02:16 +0000 (19:02 +0000)
committerAlexander Larsson <alexl@src.gnome.org>
Tue, 3 Mar 2009 19:02:16 +0000 (19:02 +0000)
2009-03-03  Alexander Larsson  <alexl@redhat.com>

Bug 561172 – gnome-open fails on local URIs with anchors

        * gdesktopappinfo.c:
Don't force uris to filenames if the uri has an anchor, because
that would strip the anchor.

        * glocalvfs.c:
Strip anchor from file:// uris when creating GFile, since
g_filename_from_uri doesn't handle them.

svn path=/trunk/; revision=7953

gio/ChangeLog
gio/gdesktopappinfo.c
gio/glocalvfs.c

index d3fb320065c8662039985d03482c3259527d7b38..594f71eaffeeb61c93fc6ab538744dc4b940f4f2 100644 (file)
@@ -1,3 +1,15 @@
+2009-03-03  Alexander Larsson  <alexl@redhat.com>
+
+       Bug 561172 – gnome-open fails on local URIs with anchors
+
+        * gdesktopappinfo.c:
+       Don't force uris to filenames if the uri has an anchor, because
+       that would strip the anchor.
+
+        * glocalvfs.c:
+       Strip anchor from file:// uris when creating GFile, since
+       g_filename_from_uri doesn't handle them.
+
 2009-03-03  Alexander Larsson  <alexl@redhat.com>
 
        Bug 562613 – Missing const modifier in string parameters
index ffe1bde21e05ae1c45be01374d21394a8ca1e99c..fcd77375cfdd5ef33b32d1da37ad727d00203098 100644 (file)
@@ -567,6 +567,7 @@ expand_macro (char              macro,
   char *expanded;
   gboolean force_file_uri;
   char force_file_uri_macro;
+  char *uri;
 
   g_return_if_fail (exec != NULL);
 
@@ -602,15 +603,18 @@ expand_macro (char              macro,
     case 'n':
       if (uris)
        {
-          if (!force_file_uri)
+         uri = uris->data;
+          if (!force_file_uri ||
+             /* Pass URI if it contains an anchor */
+             strchr (uri, '#') != NULL)
             {
-              expanded = expand_macro_single (macro, uris->data);
+              expanded = expand_macro_single (macro, uri);
             }
           else
             {
-              expanded = expand_macro_single (force_file_uri_macro, uris->data);
+              expanded = expand_macro_single (force_file_uri_macro, uri);
               if (expanded == NULL)
-                expanded = expand_macro_single (macro, uris->data);
+                expanded = expand_macro_single (macro, uri);
             }
 
          if (expanded)
@@ -629,15 +633,19 @@ expand_macro (char              macro,
     case 'N':
       while (uris)
        {
-          if (!force_file_uri)
+         uri = uris->data;
+         
+          if (!force_file_uri ||
+             /* Pass URI if it contains an anchor */
+             strchr (uri, '#') != NULL)
             {
-              expanded = expand_macro_single (macro, uris->data);
+              expanded = expand_macro_single (macro, uri);
             }
           else
             {
-              expanded = expand_macro_single (force_file_uri_macro, uris->data);
+              expanded = expand_macro_single (force_file_uri_macro, uri);
               if (expanded == NULL)
-                expanded = expand_macro_single (macro, uris->data);
+                expanded = expand_macro_single (macro, uri);
             }
 
          if (expanded)
index 980e1cfdd692bc4cf4b530d8850a75b04c245fab..cd535e38a260759b6b9c58fc00d0be434bd6649a 100644 (file)
@@ -31,6 +31,7 @@
 #ifdef HAVE_PWD_H
 #include <pwd.h>
 #endif
+#include <string.h>
 
 #include "gioalias.h"
 
@@ -90,9 +91,22 @@ g_local_vfs_get_file_for_uri (GVfs       *vfs,
 {
   char *path;
   GFile *file;
+  char *stripped_uri, *hash;
+  
+  if (strchr (uri, '#') != NULL)
+    {
+      stripped_uri = g_strdup (uri);
+      hash = strchr (stripped_uri, '#');
+      *hash = 0;
+    }
+  else
+    stripped_uri = (char *)uri;
+      
+  path = g_filename_from_uri (stripped_uri, NULL, NULL);
 
-  path = g_filename_from_uri (uri, NULL, NULL);
-
+  if (stripped_uri != uri)
+    g_free (stripped_uri);
+  
   if (path != NULL)
     file = _g_local_file_new (path);
   else