aboutsummaryrefslogtreecommitdiffstats
path: root/src/window-commands.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/window-commands.c')
-rw-r--r--src/window-commands.c68
1 files changed, 11 insertions, 57 deletions
diff --git a/src/window-commands.c b/src/window-commands.c
index 6f88248f5..0f89e32b7 100644
--- a/src/window-commands.c
+++ b/src/window-commands.c
@@ -644,19 +644,6 @@ window_cmd_view_zoom_normal (GtkAction *action,
ephy_window_set_zoom (window, 1.0);
}
-static GnomeVFSMimeApplication *
-get_editor_application (void)
-{
- GnomeVFSMimeApplication *app;
-
- app = gnome_vfs_mime_get_default_application ("text/plain");
- if (app == NULL)
- {
- g_warning ("Cannot find a text editor.");
- }
- return app;
-}
-
static void
editor_open_uri (const char *address)
{
@@ -668,12 +655,18 @@ editor_open_uri (const char *address)
uris = g_list_append (uris, canonical);
- app = get_editor_application ();
+ app = gnome_vfs_mime_get_default_application ("text/plain");
if (app)
{
gnome_vfs_mime_application_launch (app, uris);
gnome_vfs_mime_application_free (app);
}
+ else
+ {
+ /* FIXME We should really warn the user here */
+
+ g_warning ("Cannot find a text editor.");
+ }
g_free (canonical);
g_list_free (uris);
@@ -692,48 +685,6 @@ save_source_completed_cb (EphyEmbedPersist *persist)
editor_open_uri (dest);
}
-static gboolean
-editor_can_open_uri (char *address)
-{
- GnomeVFSMimeApplication *app;
- GnomeVFSURI *uri;
- const char *scheme;
- gboolean result = FALSE;
-
- app = get_editor_application ();
-
- uri = gnome_vfs_uri_new (address);
- scheme = uri ? gnome_vfs_uri_get_scheme (uri) : NULL;
-
- /* Open directly only read/write protocols, otherwise
- you just get extra network overhead without any advantage */
- if (scheme && strcmp (scheme, "file") != 0)
- {
- scheme = NULL;
- }
-
- if (scheme && app && app->supported_uri_schemes)
- {
- if (g_list_find_custom (app->supported_uri_schemes,
- scheme, (GCompareFunc) strcmp))
- {
- result = TRUE;
- }
- }
-
- if (uri)
- {
- gnome_vfs_uri_unref (uri);
- }
-
- if (app)
- {
- gnome_vfs_mime_application_free (app);
- }
-
- return result;
-}
-
static void
save_temp_source (EphyEmbed *embed)
{
@@ -778,13 +729,15 @@ window_cmd_view_page_source (GtkAction *action,
{
EphyEmbed *embed;
char *address;
+ char *scheme;
embed = ephy_window_get_active_embed (window);
g_return_if_fail (embed != NULL);
address = ephy_embed_get_location (embed, TRUE);
+ scheme = gnome_vfs_get_uri_scheme (address);
- if (editor_can_open_uri (address))
+ if (strcmp (scheme, "file") == 0)
{
editor_open_uri (address);
}
@@ -793,6 +746,7 @@ window_cmd_view_page_source (GtkAction *action,
save_temp_source (embed);
}
+ g_free (scheme);
g_free (address);
}