From f4fc6c6be76bb4cdfb4ebda9ca7de6758f2f18d1 Mon Sep 17 00:00:00 2001 From: Guillaume Desmottes Date: Fri, 3 Aug 2012 14:00:48 +0200 Subject: factor out empathy_launch_external_app() https://bugzilla.gnome.org/show_bug.cgi?id=680778 --- libempathy-gtk/empathy-ui-utils.c | 48 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) (limited to 'libempathy-gtk/empathy-ui-utils.c') diff --git a/libempathy-gtk/empathy-ui-utils.c b/libempathy-gtk/empathy-ui-utils.c index 7c6c6a7f0..905037bf8 100644 --- a/libempathy-gtk/empathy-ui-utils.c +++ b/libempathy-gtk/empathy-ui-utils.c @@ -37,6 +37,7 @@ #include #include #include +#include #include #include @@ -1641,3 +1642,50 @@ out: g_free (filename); g_object_unref (provider); } + +static gboolean +launch_app_info (GAppInfo *app_info, + GError **error) +{ + GdkAppLaunchContext *context = NULL; + GdkDisplay *display; + GError *err = NULL; + + display = gdk_display_get_default (); + context = gdk_display_get_app_launch_context (display); + + if (!g_app_info_launch (app_info, NULL, (GAppLaunchContext *) context, + &err)) + { + DEBUG ("Failed to launch %s: %s", + g_app_info_get_display_name (app_info), err->message); + g_propagate_error (error, err); + return FALSE; + } + + tp_clear_object (&context); + return TRUE; +} + +gboolean +empathy_launch_external_app (const gchar *desktop_file, + GError **error) +{ + GDesktopAppInfo *desktop_info; + gboolean result; + + desktop_info = g_desktop_app_info_new (desktop_file); + if (desktop_info == NULL) + { + DEBUG ("%s not found", desktop_file); + + g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_FOUND, + "%s not found", desktop_file); + return FALSE; + } + + result = launch_app_info (G_APP_INFO (desktop_info), error); + g_object_unref (desktop_info); + + return result; +} -- cgit v1.2.3