[gnome-shell] shell-app: Update app menu if necessary
- From: Florian MÃllner <fmuellner src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell] shell-app: Update app menu if necessary
- Date: Tue, 19 Jun 2012 15:58:33 +0000 (UTC)
commit c303c6b5c1376a7c4dbe78ebcd30c90987d6e92e
Author: Florian MÃllner <fmuellner gnome org>
Date: Thu May 17 18:18:53 2012 +0200
shell-app: Update app menu if necessary
Currently we assume that GTK_UNIQUE_BUS_NAME is shared between all
windows of an application. This assumption does not hold true for
applications that specify G_APPLICATION_NON_UNIQUE, so make sure
to update the menu as necessary.
https://bugzilla.gnome.org/show_bug.cgi?id=676238
src/shell-app.c | 26 ++++++++++++++++----------
src/shell-app.h | 1 +
src/shell-window-tracker.c | 5 ++++-
3 files changed, 21 insertions(+), 11 deletions(-)
---
diff --git a/src/shell-app.c b/src/shell-app.c
index d452fd3..7046154 100644
--- a/src/shell-app.c
+++ b/src/shell-app.c
@@ -42,6 +42,7 @@ typedef struct {
/* See GApplication documentation */
GDBusMenuModel *remote_menu;
GActionMuxer *muxer;
+ char * unique_bus_name;
} ShellAppRunningState;
/**
@@ -95,7 +96,6 @@ enum {
static guint shell_app_signals[LAST_SIGNAL] = { 0 };
static void create_running_state (ShellApp *app);
-static void setup_running_state (ShellApp *app, MetaWindow *window);
static void unref_running_state (ShellAppRunningState *state);
G_DEFINE_TYPE (ShellApp, shell_app, G_TYPE_OBJECT)
@@ -975,7 +975,7 @@ _shell_app_add_window (ShellApp *app,
g_signal_connect (window, "unmanaged", G_CALLBACK(shell_app_on_unmanaged), app);
g_signal_connect (window, "notify::user-time", G_CALLBACK(shell_app_on_user_time_changed), app);
- setup_running_state (app, window);
+ shell_app_update_app_menu (app, window);
if (app->state != SHELL_APP_STATE_STARTING)
shell_app_state_transition (app, SHELL_APP_STATE_RUNNING);
@@ -1221,12 +1221,14 @@ create_running_state (ShellApp *app)
app->running_state->muxer = g_action_muxer_new ();
}
-static void
-setup_running_state (ShellApp *app,
- MetaWindow *window)
+void
+shell_app_update_app_menu (ShellApp *app,
+ MetaWindow *window)
{
- /* We assume that 'gtk-unique-bus-name', gtk-application-object-path'
- * and 'gtk-app-menu-object-path' are the same for all windows which
+ const gchar *unique_bus_name;
+
+ /* We assume that 'gtk-application-object-path' and
+ * 'gtk-app-menu-object-path' are the same for all windows which
* have it set.
*
* It could be possible, however, that the first window we see
@@ -1235,23 +1237,27 @@ setup_running_state (ShellApp *app,
* all the rest (until the app is stopped and restarted).
*/
- if (app->running_state->remote_menu == NULL)
+ unique_bus_name = meta_window_get_gtk_unique_bus_name (window);
+
+ if (app->running_state->remote_menu == NULL ||
+ g_strcmp0 (app->running_state->unique_bus_name, unique_bus_name) != 0)
{
const gchar *application_object_path;
const gchar *app_menu_object_path;
- const gchar *unique_bus_name;
GDBusConnection *session;
GDBusActionGroup *actions;
application_object_path = meta_window_get_gtk_application_object_path (window);
app_menu_object_path = meta_window_get_gtk_app_menu_object_path (window);
- unique_bus_name = meta_window_get_gtk_unique_bus_name (window);
if (application_object_path == NULL || app_menu_object_path == NULL || unique_bus_name == NULL)
return;
session = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, NULL);
g_assert (session != NULL);
+ g_clear_pointer (&app->running_state->unique_bus_name, g_free);
+ app->running_state->unique_bus_name = g_strdup (unique_bus_name);
+ g_clear_object (&app->running_state->remote_menu);
app->running_state->remote_menu = g_dbus_menu_model_get (session, unique_bus_name, app_menu_object_path);
actions = g_dbus_action_group_get (session, unique_bus_name, application_object_path);
g_action_muxer_insert (app->running_state->muxer, "app", G_ACTION_GROUP (actions));
diff --git a/src/shell-app.h b/src/shell-app.h
index 7e14c69..6bf707a 100644
--- a/src/shell-app.h
+++ b/src/shell-app.h
@@ -82,6 +82,7 @@ int shell_app_compare_by_name (ShellApp *app, ShellApp *other);
int shell_app_compare (ShellApp *app, ShellApp *other);
void shell_app_update_window_actions (ShellApp *app, MetaWindow *window);
+void shell_app_update_app_menu (ShellApp *app, MetaWindow *window);
G_END_DECLS
diff --git a/src/shell-window-tracker.c b/src/shell-window-tracker.c
index 2e2ca48..b97f542 100644
--- a/src/shell-window-tracker.c
+++ b/src/shell-window-tracker.c
@@ -357,7 +357,10 @@ update_focus_app (ShellWindowTracker *self)
new_focus_app = new_focus_win ? shell_window_tracker_get_window_app (self, new_focus_win) : NULL;
if (new_focus_app)
- shell_app_update_window_actions (new_focus_app, new_focus_win);
+ {
+ shell_app_update_window_actions (new_focus_app, new_focus_win);
+ shell_app_update_app_menu (new_focus_app, new_focus_win);
+ }
set_focus_app (self, new_focus_app);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]