aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-ui-utils.c
diff options
context:
space:
mode:
Diffstat (limited to 'libempathy-gtk/empathy-ui-utils.c')
-rw-r--r--libempathy-gtk/empathy-ui-utils.c26
1 files changed, 11 insertions, 15 deletions
diff --git a/libempathy-gtk/empathy-ui-utils.c b/libempathy-gtk/empathy-ui-utils.c
index f5c8d3589..4389da9af 100644
--- a/libempathy-gtk/empathy-ui-utils.c
+++ b/libempathy-gtk/empathy-ui-utils.c
@@ -1303,38 +1303,34 @@ empathy_get_toplevel_window (GtkWidget *widget)
static gchar *
fixup_url (const gchar *url)
{
- gchar *real_url;
-
if (!g_str_has_prefix (url, "http://") &&
!strstr (url, ":/") &&
!strstr (url, "@")) {
- real_url = g_strdup_printf ("http://%s", url);
+ return g_strdup_printf ("http://%s", url);
} else {
- real_url = g_strdup (url);
+ return NULL;
}
-
- return real_url;
}
void
empathy_url_show (const char *url)
{
- gchar *real_url;
- gboolean res;
- GError *err;
+ gchar *real_url;
+ gboolean res;
+ GError *error;
real_url = fixup_url (url);
+ if (real_url) {
+ url = real_url;
+ }
/* FIXME: this does not work for multihead, we should use
* GdkAppLaunchContext for that, when we can depend on GTK+ trunk
*/
- res = g_app_info_launch_default_for_uri (real_url,
- NULL,
- &err);
+ res = g_app_info_launch_default_for_uri (url, NULL, &error);
if (!res) {
empathy_debug (DEBUG_DOMAIN, "Couldn't show URL %s: %s",
- real_url,
- err->message);
- g_error_free (err);
+ url, error->message);
+ g_clear_error (error);
}
g_free (real_url);