diff options
author | Lars Uebernickel <lars.uebernickel@canonical.com> | 2012-12-03 17:21:39 +0000 |
---|---|---|
committer | Lars Uebernickel <lars.uebernickel@canonical.com> | 2012-12-03 17:21:39 +0000 |
commit | 4e8bff91265ee85f00793bbfd065e5832e436954 (patch) | |
tree | 3a680cdbac8c7386a069c90dccb1645a315eb302 /src | |
parent | 1563ec55ade56207e7ca6d69b1e0390d27962797 (diff) | |
download | ayatana-indicator-messages-4e8bff91265ee85f00793bbfd065e5832e436954.tar.gz ayatana-indicator-messages-4e8bff91265ee85f00793bbfd065e5832e436954.tar.bz2 ayatana-indicator-messages-4e8bff91265ee85f00793bbfd065e5832e436954.zip |
Prefix message action names with the right namespace
Diffstat (limited to 'src')
-rw-r--r-- | src/im-application-list.c | 43 |
1 files changed, 33 insertions, 10 deletions
diff --git a/src/im-application-list.c b/src/im-application-list.c index d4c5687..c41c858 100644 --- a/src/im-application-list.c +++ b/src/im-application-list.c @@ -545,14 +545,15 @@ im_application_list_message_added (Application *app, const gchar *subtitle; const gchar *body; gint64 time; - GVariant *actions; + GVariantIter *action_iter; gboolean draws_attention; GSimpleAction *action; GIcon *app_icon; gchar *app_iconstr; + GVariant *actions = NULL; - g_variant_get (message, "(&s&s&s&s&sx@aa{sv}b)", - &id, &iconstr, &title, &subtitle, &body, &time, &actions, &draws_attention); + g_variant_get (message, "(&s&s&s&s&sxaa{sv}b)", + &id, &iconstr, &title, &subtitle, &body, &time, &action_iter, &draws_attention); app_icon = g_app_info_get_icon (G_APP_INFO (app->info)); app_iconstr = app_icon ? g_icon_to_string (app_icon) : NULL; @@ -562,20 +563,22 @@ im_application_list_message_added (Application *app, g_simple_action_group_insert (app->message_actions, G_ACTION (action)); { - GVariantIter iter; GVariant *entry; GSimpleActionGroup *action_group; + GVariantBuilder actions_builder; + g_variant_builder_init (&actions_builder, G_VARIANT_TYPE ("aa{sv}")); action_group = g_simple_action_group_new (); - g_variant_iter_init (&iter, actions); - while ((entry = g_variant_iter_next_value (&iter))) + while ((entry = g_variant_iter_next_value (action_iter))) { const gchar *name; GSimpleAction *action; GVariant *label; const gchar *type = NULL; GVariant *hint; + GVariantBuilder dict_builder; + gchar *prefixed_name; if (!g_variant_lookup (entry, "name", "&s", &name)) { @@ -592,15 +595,35 @@ im_application_list_message_added (Application *app, g_signal_connect (action, "activate", G_CALLBACK (im_application_list_sub_message_activated), app); g_simple_action_group_insert (action_group, G_ACTION (action)); - g_object_unref (action); + g_variant_builder_init (&dict_builder, G_VARIANT_TYPE ("a{sv}")); + + prefixed_name = g_strjoin (".", app->id, "msg-actions", id, name, NULL); + g_variant_builder_add (&dict_builder, "{sv}", "name", g_variant_new_string (prefixed_name)); + if (label) - g_variant_unref (label); + { + g_variant_builder_add (&dict_builder, "{sv}", "label", label); + g_variant_unref (label); + } + + if (type) + g_variant_builder_add (&dict_builder, "{sv}", "parameter-type", g_variant_new_string (type)); + if (hint) - g_variant_unref (hint); + { + g_variant_builder_add (&dict_builder, "{sv}", "parameter-hint", hint); + g_variant_unref (hint); + } + + g_variant_builder_add (&actions_builder, "a{sv}", &dict_builder); + + g_object_unref (action); g_variant_unref (entry); + g_free (prefixed_name); } g_action_muxer_insert (app->message_sub_actions, id, G_ACTION_GROUP (action_group)); + actions = g_variant_builder_end (&actions_builder); g_object_unref (action_group); } @@ -608,7 +631,7 @@ im_application_list_message_added (Application *app, g_signal_emit (app->list, signals[MESSAGE_ADDED], 0, app->id, app_iconstr, id, iconstr, title, subtitle, body, actions, time, draws_attention); - g_variant_unref (actions); + g_variant_iter_free (action_iter); g_free (app_iconstr); g_object_unref (action); } |