diff options
author | Giovanni Campagna <gcampagna@src.gnome.org> | 2014-01-06 14:05:59 +0100 |
---|---|---|
committer | Giovanni Campagna <gcampagna@src.gnome.org> | 2014-01-06 16:36:45 +0100 |
commit | f7c5dfdeef65948371c0211ab253eea5edeae695 (patch) | |
tree | e91263e1ec1fa1da68151548f412dca1628a2db9 | |
parent | d28ca4cdce0dd6f103af4e6227af985558c32e56 (diff) | |
download | gtk+-f7c5dfdeef65948371c0211ab253eea5edeae695.tar.gz |
bloatpad: fix the action associated with the notification
Notifications can only be associated with application actions,
but clear is a window action. Introduce a "clear-all" action
that forwards to clear on all windows.
https://bugzilla.gnome.org/show_bug.cgi?id=721633
-rw-r--r-- | examples/bloatpad.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/examples/bloatpad.c b/examples/bloatpad.c index 66ae90daa9..fc2415e69d 100644 --- a/examples/bloatpad.c +++ b/examples/bloatpad.c @@ -138,6 +138,18 @@ activate_clear (GSimpleAction *action, } static void +activate_clear_all (GSimpleAction *action, + GVariant *parameter, + gpointer user_data) +{ + GtkApplication *app = GTK_APPLICATION (user_data); + GList *iter; + + for (iter = gtk_application_get_windows (app); iter; iter = iter->next) + g_action_group_activate_action (iter->data, "clear", NULL); +} + +static void text_buffer_changed_cb (GtkTextBuffer *buffer, BloatPad *app) { @@ -170,7 +182,7 @@ text_buffer_changed_cb (GtkTextBuffer *buffer, GNotification *n; n = g_notification_new ("Three lines of text"); g_notification_set_body (n, "Keep up the good work!"); - g_notification_add_button (n, "Start over", "app.clear"); + g_notification_add_button (n, "Start over", "app.clear-all"); g_application_send_notification (G_APPLICATION (app), "three-lines", n); g_object_unref (n); } @@ -450,7 +462,8 @@ static GActionEntry app_entries[] = { { "about", about_activated, NULL, NULL, NULL }, { "quit", quit_activated, NULL, NULL, NULL }, { "edit-accels", edit_accels }, - { "time-active", NULL, NULL, "false", time_active_changed } + { "time-active", NULL, NULL, "false", time_active_changed }, + { "clear-all", activate_clear_all } }; static void |