[gnome-builder/wip/gtk4-port] libide/gui: robustness fixes for shortcut providers
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-builder/wip/gtk4-port] libide/gui: robustness fixes for shortcut providers
- Date: Wed, 15 Jun 2022 05:46:57 +0000 (UTC)
commit 0022236b6d89e407f1096c5d633e2a0d64e9661f
Author: Christian Hergert <chergert redhat com>
Date: Tue Jun 14 22:44:06 2022 -0700
libide/gui: robustness fixes for shortcut providers
src/libide/gui/ide-shortcut-manager.c | 31 +++++++++++++++++++++++++------
1 file changed, 25 insertions(+), 6 deletions(-)
---
diff --git a/src/libide/gui/ide-shortcut-manager.c b/src/libide/gui/ide-shortcut-manager.c
index 3893e2b5b..7a98f462f 100644
--- a/src/libide/gui/ide-shortcut-manager.c
+++ b/src/libide/gui/ide-shortcut-manager.c
@@ -78,11 +78,12 @@ ide_shortcut_manager_get_item (GListModel *model,
guint position)
{
IdeShortcutManager *self = IDE_SHORTCUT_MANAGER (model);
+ GtkShortcut *ret = NULL;
if (self->flatten)
- return g_list_model_get_item (G_LIST_MODEL (self->flatten), position);
+ ret = g_list_model_get_item (G_LIST_MODEL (self->flatten), position);
- return NULL;
+ return ret;
}
static void
@@ -139,6 +140,9 @@ ide_shortcut_manager_items_changed_cb (IdeShortcutManager *self,
guint added,
GListModel *model)
{
+ g_assert (IDE_IS_SHORTCUT_MANAGER (self));
+ g_assert (G_IS_LIST_MODEL (model));
+
g_list_model_items_changed (G_LIST_MODEL (self), position, removed, added);
}
@@ -160,7 +164,13 @@ on_provider_added_cb (IdeExtensionSetAdapter *set,
if ((model = ide_shortcut_provider_list_shortcuts (provider)))
{
- g_object_set_data (G_OBJECT (provider), "SHORTCUTS_MODEL", model);
+ IDE_TRACE_MSG ("Adding shortcut model for %s with %d items",
+ peas_plugin_info_get_module_name (plugin_info),
+ g_list_model_get_n_items (model));
+ g_object_set_data_full (G_OBJECT (provider),
+ "SHORTCUTS_MODEL",
+ g_object_ref (model),
+ g_object_unref);
g_list_store_append (self->providers_models, model);
}
@@ -183,9 +193,16 @@ on_provider_removed_cb (IdeExtensionSetAdapter *set,
g_assert (plugin_info != NULL);
g_assert (IDE_IS_SHORTCUT_PROVIDER (provider));
+ if (self->providers_models == NULL)
+ IDE_EXIT;
+
if ((model = g_object_get_data (G_OBJECT (provider), "SHORTCUTS_MODEL")))
{
- guint n_items = g_list_model_get_n_items (G_LIST_MODEL (self->providers_models));
+ guint n_items;
+
+ g_assert (G_IS_LIST_MODEL (model));
+
+ n_items = g_list_model_get_n_items (G_LIST_MODEL (self->providers_models));
for (guint i = 0; i < n_items; i++)
{
@@ -194,7 +211,7 @@ on_provider_removed_cb (IdeExtensionSetAdapter *set,
if (item == model)
{
g_list_store_remove (self->providers_models, i);
- break;
+ IDE_EXIT;
}
}
}
@@ -273,7 +290,9 @@ ide_shortcut_manager_init (IdeShortcutManager *self)
self->plugin_models = g_object_ref (plugin_models);
self->providers_models = g_list_store_new (G_TYPE_LIST_MODEL);
- g_list_store_append (self->toplevel, self->providers_models);
+ flatten = gtk_flatten_list_model_new (g_object_ref (G_LIST_MODEL (self->providers_models)));
+ g_list_store_append (self->toplevel, flatten);
+ g_object_unref (flatten);
flatten = gtk_flatten_list_model_new (g_object_ref (G_LIST_MODEL (self->plugin_models)));
g_list_store_append (self->toplevel, flatten);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]