diff options
-rw-r--r-- | lib/egg/Makefile.am | 6 | ||||
-rw-r--r-- | lib/egg/eel-app-launch-context.c | 613 | ||||
-rw-r--r-- | lib/egg/eel-app-launch-context.h | 77 | ||||
-rw-r--r-- | lib/ephy-file-helpers.c | 24 | ||||
-rw-r--r-- | src/window-commands.c | 1 |
5 files changed, 15 insertions, 706 deletions
diff --git a/lib/egg/Makefile.am b/lib/egg/Makefile.am index 9a7275373..da1d3abe6 100644 --- a/lib/egg/Makefile.am +++ b/lib/egg/Makefile.am @@ -2,15 +2,13 @@ EGGSOURCES = \ eggtreemultidnd.c \ egg-editable-toolbar.c \ egg-toolbars-model.c \ - egg-toolbar-editor.c \ - eel-app-launch-context.c + egg-toolbar-editor.c EGGHEADERS = \ eggtreemultidnd.h \ egg-editable-toolbar.h \ egg-toolbars-model.h \ - egg-toolbar-editor.h \ - eel-app-launch-context.h + egg-toolbar-editor.h noinst_HEADERS = \ $(EGGHEADERS) \ diff --git a/lib/egg/eel-app-launch-context.c b/lib/egg/eel-app-launch-context.c deleted file mode 100644 index e4cac819a..000000000 --- a/lib/egg/eel-app-launch-context.c +++ /dev/null @@ -1,613 +0,0 @@ -/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ - -/* eel-mount-operation.c - Gtk+ implementation for GAppLaunchContext - - Copyright (C) 2007 Red Hat, Inc. - - The Gnome Library is free software; you can redistribute it and/or - modify it under the terms of the GNU Library General Public License as - published by the Free Software Foundation; either version 2 of the - License, or (at your option) any later version. - - The Gnome Library is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - Library General Public License for more details. - - You should have received a copy of the GNU Library General Public - License along with the Gnome Library; see the file COPYING.LIB. If not, - write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, - Boston, MA 02111-1307, USA. - - Author: Alexander Larsson <alexl@redhat.com> -*/ - -#include <config.h> -#include "eel-app-launch-context.h" - -#include <gio/gio.h> -#include <glib.h> -#include <string.h> - -#ifdef HAVE_STARTUP_NOTIFICATION -#define SN_API_NOT_YET_FROZEN -#include <libsn/sn.h> -#include <gdk/gdk.h> -#include <gtk/gtk.h> -#endif - -G_DEFINE_TYPE (EelAppLaunchContext, eel_app_launch_context, G_TYPE_APP_LAUNCH_CONTEXT); - -struct EelAppLaunchContextPrivate { - GdkDisplay *display; - GdkScreen *screen; - guint32 timestamp; - GIcon *icon; - char *icon_name; -}; - -static void -eel_app_launch_context_finalize (GObject *object) -{ - EelAppLaunchContext *context; - EelAppLaunchContextPrivate *priv; - - context = EEL_APP_LAUNCH_CONTEXT (object); - - priv = context->priv; - - if (priv->display) { - g_object_unref (priv->display); - } - if (priv->screen) { - g_object_unref (priv->screen); - } - if (priv->icon) { - g_object_unref (priv->screen); - } - g_free (priv->icon_name); - - (*G_OBJECT_CLASS (eel_app_launch_context_parent_class)->finalize) (object); -} - -static char * -get_display (GAppLaunchContext *context, - GAppInfo *info, - GList *files) -{ - GdkDisplay *display; - EelAppLaunchContextPrivate *priv; - - priv = EEL_APP_LAUNCH_CONTEXT (context)->priv; - - if (priv->screen) { - return gdk_screen_make_display_name (priv->screen); - } - - if (priv->display) { - display = priv->display; - } else { - display = gdk_display_get_default (); - } - - return g_strdup (gdk_display_get_name (display)); -} - -#ifdef HAVE_STARTUP_NOTIFICATION -static void -sn_error_trap_push (SnDisplay *display, - Display *xdisplay) -{ - gdk_error_trap_push (); -} - -static void -sn_error_trap_pop (SnDisplay *display, - Display *xdisplay) -{ - gdk_error_trap_pop (); -} - -static char * -get_display_name (GFile *file) -{ - GFileInfo *info; - char *name, *tmp; - - /* This does sync i/o, which isn't ideal. - * It should probably use the NautilusFile machinery - */ - - name = NULL; - info = g_file_query_info (file, - G_FILE_ATTRIBUTE_STANDARD_DISPLAY_NAME, - 0, NULL, NULL); - if (info) { - name = g_strdup (g_file_info_get_display_name (info)); - g_object_unref (info); - } - - if (name == NULL) { - name = g_file_get_basename (file); - if (!g_utf8_validate (name, -1, NULL)) { - tmp = name; - name = g_uri_escape_string (name, G_URI_RESERVED_CHARS_ALLOWED_IN_PATH, TRUE); - g_free (tmp); - } - } - return name; -} - -static GIcon * -get_icon (GFile *file) -{ - GFileInfo *info; - GIcon *icon; - - icon = NULL; - info = g_file_query_info (file, - G_FILE_ATTRIBUTE_STANDARD_ICON, - 0, NULL, NULL); - if (info) { - icon = g_file_info_get_icon (info); - if (icon) { - g_object_ref (icon); - } - g_object_unref (info); - } - - return icon; - -} - -static char * -gicon_to_string (GIcon *icon) -{ - GFile *file; - const char * const *names; - - if (G_IS_FILE_ICON (icon)) { - file = g_file_icon_get_file (G_FILE_ICON (icon)); - if (file) { - return g_file_get_path (file); - } - } else if (G_IS_THEMED_ICON (icon)) { - names = g_themed_icon_get_names (G_THEMED_ICON (icon)); - if (names) { - return g_strdup (names[0]); - } - } - - return NULL; -} - -/* FIXME: This is the wrong way to do this; there should be some event - * (e.g. button press) available with a good time. A function like - * this should not be needed. - */ -static Time -slowly_and_stupidly_obtain_timestamp (Display *xdisplay) -{ - Window xwindow; - XEvent event; - - { - XSetWindowAttributes attrs; - Atom atom_name; - Atom atom_type; - char* name; - - attrs.override_redirect = True; - attrs.event_mask = PropertyChangeMask | StructureNotifyMask; - - xwindow = - XCreateWindow (xdisplay, - RootWindow (xdisplay, 0), - -100, -100, 1, 1, - 0, - CopyFromParent, - CopyFromParent, - (Visual *)CopyFromParent, - CWOverrideRedirect | CWEventMask, - &attrs); - - atom_name = XInternAtom (xdisplay, "WM_NAME", TRUE); - g_assert (atom_name != None); - atom_type = XInternAtom (xdisplay, "STRING", TRUE); - g_assert (atom_type != None); - - name = "Fake Window"; - XChangeProperty (xdisplay, - xwindow, atom_name, - atom_type, - 8, PropModeReplace, name, strlen (name)); - } - - XWindowEvent (xdisplay, - xwindow, - PropertyChangeMask, - &event); - - XDestroyWindow(xdisplay, xwindow); - - return event.xproperty.time; -} - -/* This should be fairly long, as it's confusing to users if a startup - * ends when it shouldn't (it appears that the startup failed, and - * they have to relaunch the app). Also the timeout only matters when - * there are bugs and apps don't end their own startup sequence. - * - * This timeout is a "last resort" timeout that ignores whether the - * startup sequence has shown activity or not. Metacity and the - * tasklist have smarter, and correspondingly able-to-be-shorter - * timeouts. The reason our timeout is dumb is that we don't monitor - * the sequence (don't use an SnMonitorContext) - */ -#define STARTUP_TIMEOUT_LENGTH (30 /* seconds */ * 1000) - -typedef struct -{ - GSList *contexts; - guint timeout_id; -} StartupTimeoutData; - -static void -free_startup_timeout (void *data) -{ - StartupTimeoutData *std; - - std = data; - - g_slist_foreach (std->contexts, - (GFunc) sn_launcher_context_unref, - NULL); - g_slist_free (std->contexts); - - if (std->timeout_id != 0) { - g_source_remove (std->timeout_id); - std->timeout_id = 0; - } - - g_free (std); -} - -static gboolean -startup_timeout (void *data) -{ - StartupTimeoutData *std; - GSList *tmp; - GTimeVal now; - int min_timeout; - - std = data; - - min_timeout = STARTUP_TIMEOUT_LENGTH; - - g_get_current_time (&now); - - tmp = std->contexts; - while (tmp != NULL) { - SnLauncherContext *sn_context; - GSList *next; - long tv_sec, tv_usec; - double elapsed; - - sn_context = tmp->data; - next = tmp->next; - - sn_launcher_context_get_last_active_time (sn_context, - &tv_sec, &tv_usec); - - elapsed = - ((((double)now.tv_sec - tv_sec) * G_USEC_PER_SEC + - (now.tv_usec - tv_usec))) / 1000.0; - - if (elapsed >= STARTUP_TIMEOUT_LENGTH) { - std->contexts = g_slist_remove (std->contexts, - sn_context); - sn_launcher_context_complete (sn_context); - sn_launcher_context_unref (sn_context); - } else { - min_timeout = MIN (min_timeout, (STARTUP_TIMEOUT_LENGTH - elapsed)); - } - - tmp = next; - } - - if (std->contexts == NULL) { - std->timeout_id = 0; - } else { - std->timeout_id = g_timeout_add (min_timeout, - startup_timeout, - std); - } - - /* always remove this one, but we may have reinstalled another one. */ - return FALSE; -} - -static void -add_startup_timeout (GdkScreen *screen, - SnLauncherContext *sn_context) -{ - StartupTimeoutData *data; - - data = g_object_get_data (G_OBJECT (screen), "appinfo-startup-data"); - if (data == NULL) { - data = g_new (StartupTimeoutData, 1); - data->contexts = NULL; - data->timeout_id = 0; - - g_object_set_data_full (G_OBJECT (screen), "appinfo-startup-data", - data, free_startup_timeout); - } - - sn_launcher_context_ref (sn_context); - data->contexts = g_slist_prepend (data->contexts, sn_context); - - if (data->timeout_id == 0) { - data->timeout_id = g_timeout_add (STARTUP_TIMEOUT_LENGTH, - startup_timeout, - data); - } -} - -#endif - - -static char * -get_startup_notify_id (GAppLaunchContext *context, - GAppInfo *info, - GList *files) -{ -#ifdef HAVE_STARTUP_NOTIFICATION - EelAppLaunchContextPrivate *priv; - SnLauncherContext *sn_context; - SnDisplay *sn_display; - GdkDisplay *display; - GdkScreen *screen; - int files_count; - char *name, *description, *icon_name; - const char *binary_name; - GIcon *icon; - guint32 timestamp; - char *id; - - priv = EEL_APP_LAUNCH_CONTEXT (context)->priv; - - if (priv->screen) { - screen = priv->screen; - display = gdk_screen_get_display (priv->screen); - } else if (priv->display) { - display = priv->display; - screen = gdk_display_get_default_screen (display); - } else { - display = gdk_display_get_default (); - screen = gdk_display_get_default_screen (display); - } - - sn_display = sn_display_new (gdk_display, - sn_error_trap_push, - sn_error_trap_pop); - - - sn_context = sn_launcher_context_new (sn_display, - gdk_screen_get_number (screen)); - - - files_count = g_list_length (files); - if (files_count == 1) { - name = get_display_name (files->data); - description = g_strdup_printf (_("Opening %s"), name); - } else { - name = NULL; - description = g_strdup_printf (ngettext ("Opening %d Item", - "Opening %d Items", - files_count), - files_count); - } - - if (name != NULL) { - sn_launcher_context_set_name (sn_context, name); - g_free (name); - } - - if (description != NULL) { - sn_launcher_context_set_description (sn_context, description); - g_free (description); - } - - icon_name = NULL; - if (priv->icon_name) { - icon_name = g_strdup (priv->icon_name); - } else { - icon = NULL; - - if (priv->icon != NULL) { - icon = g_object_ref (priv->icon); - } else if (files_count == 1) { - icon = get_icon (files->data); - } - - if (icon == NULL) { - icon = g_app_info_get_icon (info); - g_object_ref (icon); - } - - if (icon) { - icon_name = gicon_to_string (icon); - } - g_object_unref (icon); - } - - if (icon_name) { - sn_launcher_context_set_icon_name (sn_context, icon_name); - g_free (icon_name); - } - - - binary_name = g_app_info_get_executable (info); - sn_launcher_context_set_binary_name (sn_context, binary_name); - - timestamp = priv->timestamp; - if (timestamp == GDK_CURRENT_TIME) { - timestamp = gtk_get_current_event_time (); - } - if (timestamp == GDK_CURRENT_TIME) { - timestamp = slowly_and_stupidly_obtain_timestamp (GDK_SCREEN_XDISPLAY (screen)); - } - - sn_launcher_context_initiate (sn_context, - g_get_application_name () ? g_get_application_name () : "unknown", - binary_name, - timestamp); - - id = g_strdup (sn_launcher_context_get_startup_id (sn_context)); - - add_startup_timeout (screen, sn_context); - - sn_launcher_context_unref (sn_context); - - sn_display_unref (sn_display); - - return id; -#else - return NULL; -#endif -} - -static void -launch_failed (GAppLaunchContext *context, - const char *startup_notify_id) -{ -#ifdef HAVE_STARTUP_NOTIFICATION - EelAppLaunchContextPrivate *priv; - GdkScreen *screen; - StartupTimeoutData *data; - SnLauncherContext *sn_context; - GSList *l; - - priv = EEL_APP_LAUNCH_CONTEXT (context)->priv; - - if (priv->screen) { - screen = priv->screen; - } else if (priv->display) { - screen = gdk_display_get_default_screen (priv->display); - } else { - screen = gdk_display_get_default_screen (gdk_display_get_default ()); - } - - data = g_object_get_data (G_OBJECT (screen), "appinfo-startup-data"); - - if (data) { - for (l = data->contexts; l != NULL; l = l->next) { - sn_context = l->data; - if (strcmp (startup_notify_id, sn_launcher_context_get_startup_id (sn_context)) == 0) { - data->contexts = g_slist_remove (data->contexts, - sn_context); - sn_launcher_context_complete (sn_context); - sn_launcher_context_unref (sn_context); - break; - } - } - - if (data->contexts == NULL) { - g_source_remove (data->timeout_id); - data->timeout_id = 0; - } - } - -#endif - -} - - -static void -eel_app_launch_context_class_init (EelAppLaunchContextClass *klass) -{ - GObjectClass *gobject_class = G_OBJECT_CLASS (klass); - GAppLaunchContextClass *context_class = G_APP_LAUNCH_CONTEXT_CLASS (klass); - - g_type_class_add_private (klass, sizeof (EelAppLaunchContextPrivate)); - - gobject_class->finalize = eel_app_launch_context_finalize; - - context_class->get_display = get_display; - context_class->get_startup_notify_id = get_startup_notify_id; - context_class->launch_failed = launch_failed; -} - -static void -eel_app_launch_context_init (EelAppLaunchContext *context) -{ - context->priv = G_TYPE_INSTANCE_GET_PRIVATE (context, - EEL_TYPE_APP_LAUNCH_CONTEXT, - EelAppLaunchContextPrivate); -} - -void -eel_app_launch_context_set_display (EelAppLaunchContext *context, - GdkDisplay *display) -{ - if (context->priv->display) { - g_object_unref (context->priv->display); - context->priv->display = NULL; - } - - if (display) { - context->priv->display = g_object_ref (display); - } -} - -void -eel_app_launch_context_set_screen (EelAppLaunchContext *context, - GdkScreen *screen) -{ - if (context->priv->screen) { - g_object_unref (context->priv->screen); - context->priv->screen = NULL; - } - - if (screen) { - context->priv->screen = g_object_ref (screen); - } -} - -void -eel_app_launch_context_set_timestamp (EelAppLaunchContext *context, - guint32 timestamp) -{ - context->priv->timestamp = timestamp; -} - -void -eel_app_launch_context_set_icon (EelAppLaunchContext *context, - GIcon *icon) -{ - if (context->priv->icon) { - g_object_unref (context->priv->icon); - context->priv->icon = NULL; - } - - if (icon) { - context->priv->icon = g_object_ref (icon); - } -} - -void -eel_app_launch_context_set_icon_name (EelAppLaunchContext *context, - const char *icon_name) -{ - g_free (context->priv->icon_name); - context->priv->icon_name = g_strdup (icon_name); -} - -EelAppLaunchContext * -eel_app_launch_context_new (void) -{ - EelAppLaunchContext *context; - - context = g_object_new (eel_app_launch_context_get_type (), NULL); - return context; -} diff --git a/lib/egg/eel-app-launch-context.h b/lib/egg/eel-app-launch-context.h deleted file mode 100644 index 25db482e3..000000000 --- a/lib/egg/eel-app-launch-context.h +++ /dev/null @@ -1,77 +0,0 @@ -/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */ - -/* eel-app-launch-context.h - Gtk+ implementation for GAppLaunchContext - - Copyright (C) 2007 Red Hat, Inc. - - The Gnome Library is free software; you can redistribute it and/or - modify it under the terms of the GNU Library General Public License as - published by the Free Software Foundation; either version 2 of the - License, or (at your option) any later version. - - The Gnome Library is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - Library General Public License for more details. - - You should have received a copy of the GNU Library General Public - License along with the Gnome Library; see the file COPYING.LIB. If not, - write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, - Boston, MA 02111-1307, USA. - - Author: Alexander Larsson <alexl@redhat.com> -*/ - -#ifndef EEL_APP_LAUCH_CONTEXT_H -#define EEL_APP_LAUCH_CONTEXT_H - -#include <glib.h> -#include <gio/gio.h> -#include <gtk/gtk.h> - -G_BEGIN_DECLS - -#define EEL_TYPE_APP_LAUNCH_CONTEXT (eel_app_launch_context_get_type ()) -#define EEL_APP_LAUNCH_CONTEXT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EEL_TYPE_APP_LAUNCH_CONTEXT, EelAppLaunchContext)) -#define EEL_APP_LAUNCH_CONTEXT_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EEL_TYPE_APP_LAUNCH_CONTEXT, EelAppLaunchContextClass)) -#define EEL_IS_APP_LAUNCH_CONTEXT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EEL_TYPE_APP_LAUNCH_CONTEXT)) -#define EEL_IS_APP_LAUNCH_CONTEXT_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EEL_TYPE_APP_LAUNCH_CONTEXT)) -#define EEL_APP_LAUNCH_CONTEXT_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EEL_TYPE_APP_LAUNCH_CONTEXT, EelAppLaunchContextClass)) - -typedef struct EelAppLaunchContext EelAppLaunchContext; -typedef struct EelAppLaunchContextClass EelAppLaunchContextClass; -typedef struct EelAppLaunchContextPrivate EelAppLaunchContextPrivate; - -struct EelAppLaunchContext -{ - GAppLaunchContext parent_instance; - - EelAppLaunchContextPrivate *priv; -}; - -struct EelAppLaunchContextClass -{ - GAppLaunchContextClass parent_class; - - -}; - -GType eel_app_launch_context_get_type (void); - -EelAppLaunchContext *eel_app_launch_context_new (void); -void eel_app_launch_context_set_display (EelAppLaunchContext *context, - GdkDisplay *display); -void eel_app_launch_context_set_screen (EelAppLaunchContext *context, - GdkScreen *screen); -void eel_app_launch_context_set_timestamp (EelAppLaunchContext *context, - guint32 timestamp); -void eel_app_launch_context_set_icon (EelAppLaunchContext *context, - GIcon *icon); -void eel_app_launch_context_set_icon_name (EelAppLaunchContext *context, - const char *icon_name); - -G_END_DECLS - -#endif /* EEL_APP_LAUNCH_CONTEXT_H */ - - diff --git a/lib/ephy-file-helpers.c b/lib/ephy-file-helpers.c index ad7f65c39..b3ba240dd 100644 --- a/lib/ephy-file-helpers.c +++ b/lib/ephy-file-helpers.c @@ -27,7 +27,6 @@ #include "ephy-prefs.h" #include "eel-gconf-extensions.h" -#include "eel-app-launch-context.h" #include "ephy-debug.h" #include "ephy-string.h" @@ -35,6 +34,7 @@ #include <glib/gi18n.h> #include <gio/gio.h> #include <gio/gdesktopappinfo.h> +#include <gdk/gdk.h> #include <libgnome/gnome-init.h> #include <libxml/xmlreader.h> @@ -600,11 +600,12 @@ ephy_file_launch_application (GAppInfo *app, guint32 user_time, GtkWidget *widget) { - GAppLaunchContext *context; + GdkAppLaunchContext *context; GdkDisplay *display; GdkScreen *screen; + gboolean res; - context = G_APP_LAUNCH_CONTEXT (eel_app_launch_context_new ()); + context = gdk_app_launch_context_new (); if (widget) { display = gtk_widget_get_display (widget); @@ -616,14 +617,15 @@ ephy_file_launch_application (GAppInfo *app, screen = gdk_screen_get_default (); } - eel_app_launch_context_set_display (EEL_APP_LAUNCH_CONTEXT (context), - display); - eel_app_launch_context_set_screen (EEL_APP_LAUNCH_CONTEXT (context), - screen); - eel_app_launch_context_set_timestamp (EEL_APP_LAUNCH_CONTEXT (context), - user_time); - - return g_app_info_launch (app, files, context, NULL); + gdk_app_launch_context_set_display (context, display); + gdk_app_launch_context_set_screen (context, screen); + gdk_app_launch_context_set_timestamp (context, user_time); + + res = g_app_info_launch (app, files, + G_APP_LAUNCH_CONTEXT (context), NULL); + g_object_unref (context); + + return res; } gboolean diff --git a/src/window-commands.c b/src/window-commands.c index eb6ecf34f..65999cfb7 100644 --- a/src/window-commands.c +++ b/src/window-commands.c @@ -51,7 +51,6 @@ #include "ephy-link.h" #include "ephy-stock-icons.h" #include "ephy-string.h" -#include "eel-app-launch-context.h" #include "pdm-dialog.h" #include <string.h> |