Implement sokoke_show_uri on top of explorer for win32
This commit is contained in:
parent
6ad713c6d5
commit
f4b2111b40
1 changed files with 67 additions and 0 deletions
|
@ -276,6 +276,73 @@ sokoke_show_uri (GdkScreen* screen,
|
||||||
#if HAVE_HILDON
|
#if HAVE_HILDON
|
||||||
HildonURIAction* action = hildon_uri_get_default_action_by_uri (uri, NULL);
|
HildonURIAction* action = hildon_uri_get_default_action_by_uri (uri, NULL);
|
||||||
return hildon_uri_open (uri, action, error);
|
return hildon_uri_open (uri, action, error);
|
||||||
|
|
||||||
|
#elif defined (G_OS_WIN32)
|
||||||
|
|
||||||
|
const gchar* fallbacks [] = { "explorer" };
|
||||||
|
gsize i;
|
||||||
|
GAppInfo *app_info;
|
||||||
|
GFile *file;
|
||||||
|
gchar *free_uri;
|
||||||
|
|
||||||
|
g_return_val_if_fail (uri != NULL, FALSE);
|
||||||
|
g_return_val_if_fail (!error || !*error, FALSE);
|
||||||
|
g_return_val_if_fail (GDK_IS_SCREEN (screen) || !screen, FALSE);
|
||||||
|
|
||||||
|
file = g_file_new_for_uri (uri);
|
||||||
|
app_info = g_file_query_default_handler (file, NULL, error);
|
||||||
|
|
||||||
|
if (app_info != NULL)
|
||||||
|
{
|
||||||
|
GdkAppLaunchContext *context;
|
||||||
|
gboolean result;
|
||||||
|
GList l;
|
||||||
|
|
||||||
|
context = gdk_app_launch_context_new ();
|
||||||
|
gdk_app_launch_context_set_screen (context, screen);
|
||||||
|
gdk_app_launch_context_set_timestamp (context, timestamp);
|
||||||
|
|
||||||
|
l.data = (char *)file;
|
||||||
|
l.next = l.prev = NULL;
|
||||||
|
result = g_app_info_launch (app_info, &l, (GAppLaunchContext*)context, error);
|
||||||
|
|
||||||
|
g_object_unref (context);
|
||||||
|
g_object_unref (app_info);
|
||||||
|
g_object_unref (file);
|
||||||
|
|
||||||
|
if (result)
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
g_object_unref (file);
|
||||||
|
|
||||||
|
free_uri = g_filename_from_uri (uri, NULL, NULL);
|
||||||
|
if (free_uri)
|
||||||
|
{
|
||||||
|
gchar *quoted = g_shell_quote (free_uri);
|
||||||
|
uri = quoted;
|
||||||
|
g_free (free_uri);
|
||||||
|
free_uri = quoted;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < G_N_ELEMENTS (fallbacks); i++)
|
||||||
|
{
|
||||||
|
gchar* command = g_strconcat (fallbacks[i], " ", uri, NULL);
|
||||||
|
gboolean result = g_spawn_command_line_async (command, error);
|
||||||
|
g_free (command);
|
||||||
|
if (result)
|
||||||
|
{
|
||||||
|
g_free (free_uri);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
if (error)
|
||||||
|
*error = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (free_uri);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
const gchar* fallbacks [] = { "xdg-open", "exo-open", "gnome-open" };
|
const gchar* fallbacks [] = { "xdg-open", "exo-open", "gnome-open" };
|
||||||
|
|
Loading…
Reference in a new issue