diff options
author | Matthias Clasen <mclasen@redhat.com> | 2014-11-24 22:44:44 -0500 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2014-11-24 22:44:44 -0500 |
commit | 46fd9fa4ef97265b28c5db51cbb431f45990473d (patch) | |
tree | 40cb2a72e0b25dc7a85b249971f3e64f153bcf0e | |
parent | 38cda97e0410b1edcd2cdd4092c27213f42a774e (diff) | |
download | gtk+-search-entry.tar.gz |
inspector: Use some of the new GtkSearchEntry APIsearch-entry
Avoid repetitive, manual event handling in various places
in GtkInspector.
-rw-r--r-- | gtk/inspector/object-tree.c | 9 | ||||
-rw-r--r-- | gtk/inspector/object-tree.ui | 3 | ||||
-rw-r--r-- | gtk/inspector/prop-list.c | 103 | ||||
-rw-r--r-- | gtk/inspector/prop-list.ui | 1 | ||||
-rw-r--r-- | gtk/inspector/style-prop-list.c | 106 | ||||
-rw-r--r-- | gtk/inspector/style-prop-list.ui | 2 |
6 files changed, 22 insertions, 202 deletions
diff --git a/gtk/inspector/object-tree.c b/gtk/inspector/object-tree.c index f8f1d2a396..6c481936e3 100644 --- a/gtk/inspector/object-tree.c +++ b/gtk/inspector/object-tree.c @@ -408,6 +408,14 @@ previous_match (GtkButton *button, } static void +stop_search (GtkWidget *entry, + GtkInspectorObjectTree *wt) +{ + gtk_entry_set_text (GTK_ENTRY (wt->priv->search_entry), ""); + gtk_search_bar_set_search_mode (GTK_SEARCH_BAR (wt->priv->search_bar), FALSE); +} + +static void gtk_inspector_object_tree_init (GtkInspectorObjectTree *wt) { guint signal_id; @@ -492,6 +500,7 @@ gtk_inspector_object_tree_class_init (GtkInspectorObjectTreeClass *klass) gtk_widget_class_bind_template_callback (widget_class, on_search_changed); gtk_widget_class_bind_template_callback (widget_class, next_match); gtk_widget_class_bind_template_callback (widget_class, previous_match); + gtk_widget_class_bind_template_callback (widget_class, stop_search); } typedef struct diff --git a/gtk/inspector/object-tree.ui b/gtk/inspector/object-tree.ui index 397fb3cc5c..2b93eb0609 100644 --- a/gtk/inspector/object-tree.ui +++ b/gtk/inspector/object-tree.ui @@ -30,6 +30,9 @@ <property name="visible">True</property> <property name="max-width-chars">40</property> <signal name="search-changed" handler="on_search_changed"/> + <signal name="next-match" handler="next_match"/> + <signal name="previous-match" handler="previous_match"/> + <signal name="stop-search" handler="stop_search"/> </object> </child> <child> diff --git a/gtk/inspector/prop-list.c b/gtk/inspector/prop-list.c index 771ea9c836..3c2642668e 100644 --- a/gtk/inspector/prop-list.c +++ b/gtk/inspector/prop-list.c @@ -81,116 +81,19 @@ search_close_clicked (GtkWidget *button, } static gboolean -is_keynav_event (GdkEvent *event) -{ - GdkModifierType state = 0; - guint keyval; - - if (!gdk_event_get_keyval (event, &keyval)) - return FALSE; - - gdk_event_get_state (event, &state); - - if (keyval == GDK_KEY_Tab || keyval == GDK_KEY_KP_Tab || - keyval == GDK_KEY_Up || keyval == GDK_KEY_KP_Up || - keyval == GDK_KEY_Down || keyval == GDK_KEY_KP_Down || - keyval == GDK_KEY_Left || keyval == GDK_KEY_KP_Left || - keyval == GDK_KEY_Right || keyval == GDK_KEY_KP_Right || - keyval == GDK_KEY_Home || keyval == GDK_KEY_KP_Home || - keyval == GDK_KEY_End || keyval == GDK_KEY_KP_End || - keyval == GDK_KEY_Page_Up || keyval == GDK_KEY_KP_Page_Up || - keyval == GDK_KEY_Page_Down || keyval == GDK_KEY_KP_Page_Down || - ((state & (GDK_CONTROL_MASK | GDK_MOD1_MASK)) != 0)) - return TRUE; - - /* Other navigation events should get automatically - * ignored as they will not change the content of the entry - */ - return FALSE; -} - -static void -preedit_changed_cb (GtkEntry *entry, - GtkWidget *popup, - gboolean *preedit_changed) -{ - *preedit_changed = TRUE; -} - -static gboolean key_press_event (GtkWidget *window, GdkEvent *event, GtkInspectorPropList *pl) { - gboolean handled; - gboolean preedit_changed; - guint preedit_change_id; - gboolean res; - gchar *old_text, *new_text; - if (!gtk_widget_get_mapped (GTK_WIDGET (pl))) return GDK_EVENT_PROPAGATE; - if (is_keynav_event (event) || - event->key.keyval == GDK_KEY_space || - event->key.keyval == GDK_KEY_Menu) - return GDK_EVENT_PROPAGATE; - - if (event->key.keyval == GDK_KEY_Return || - event->key.keyval == GDK_KEY_ISO_Enter || - event->key.keyval == GDK_KEY_KP_Enter) - { - GtkTreeSelection *selection; - GtkTreeModel *model; - GtkTreeIter iter; - GtkTreePath *path; - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (pl->priv->tree)); - if (gtk_tree_selection_get_selected (selection, &model, &iter)) - { - path = gtk_tree_model_get_path (model, &iter); - gtk_tree_view_row_activated (GTK_TREE_VIEW (pl->priv->tree), - path, - pl->priv->name_column); - gtk_tree_path_free (path); - - return GDK_EVENT_STOP; - } - else - return GDK_EVENT_PROPAGATE; - } - - if (event->key.keyval == GDK_KEY_Escape) - { - gtk_entry_set_text (GTK_ENTRY (pl->priv->search_entry), ""); - gtk_stack_set_visible_child_name (GTK_STACK (pl->priv->search_stack), "title"); - return GDK_EVENT_STOP; - } - - if (!gtk_widget_get_realized (pl->priv->search_entry)) - gtk_widget_realize (pl->priv->search_entry); - - handled = FALSE; - preedit_changed = FALSE; - preedit_change_id = g_signal_connect (pl->priv->search_entry, "preedit-changed", - G_CALLBACK (preedit_changed_cb), &preedit_changed); - - old_text = g_strdup (gtk_entry_get_text (GTK_ENTRY (pl->priv->search_entry))); - res = gtk_widget_event (pl->priv->search_entry, event); - new_text = g_strdup (gtk_entry_get_text (GTK_ENTRY (pl->priv->search_entry))); - - g_signal_handler_disconnect (pl->priv->search_entry, preedit_change_id); - - if ((res && g_strcmp0 (new_text, old_text) != 0) || preedit_changed) + if (gtk_search_entry_handle_event (GTK_SEARCH_ENTRY (pl->priv->search_entry), event)) { gtk_stack_set_visible_child_name (GTK_STACK (pl->priv->search_stack), "search"); - handled = TRUE; + return GDK_EVENT_STOP; } - - g_free (old_text); - g_free (new_text); - - return handled ? GDK_EVENT_STOP : GDK_EVENT_PROPAGATE; + return GDK_EVENT_PROPAGATE; } static void diff --git a/gtk/inspector/prop-list.ui b/gtk/inspector/prop-list.ui index ae7e6ec64e..6d67a736c1 100644 --- a/gtk/inspector/prop-list.ui +++ b/gtk/inspector/prop-list.ui @@ -29,6 +29,7 @@ <object class="GtkSearchEntry" id="search_entry"> <property name="visible">True</property> <property name="max-width-chars">40</property> + <signal name="stop-search" handler="search_close_clicked"/> </object> </child> <child> diff --git a/gtk/inspector/style-prop-list.c b/gtk/inspector/style-prop-list.c index 536661a009..fe31dfbdeb 100644 --- a/gtk/inspector/style-prop-list.c +++ b/gtk/inspector/style-prop-list.c @@ -68,116 +68,19 @@ search_close_clicked (GtkWidget *button, } static gboolean -is_keynav_event (GdkEvent *event) -{ - GdkModifierType state = 0; - guint keyval; - - if (!gdk_event_get_keyval (event, &keyval)) - return FALSE; - - gdk_event_get_state (event, &state); - - if (keyval == GDK_KEY_Tab || keyval == GDK_KEY_KP_Tab || - keyval == GDK_KEY_Up || keyval == GDK_KEY_KP_Up || - keyval == GDK_KEY_Down || keyval == GDK_KEY_KP_Down || - keyval == GDK_KEY_Left || keyval == GDK_KEY_KP_Left || - keyval == GDK_KEY_Right || keyval == GDK_KEY_KP_Right || - keyval == GDK_KEY_Home || keyval == GDK_KEY_KP_Home || - keyval == GDK_KEY_End || keyval == GDK_KEY_KP_End || - keyval == GDK_KEY_Page_Up || keyval == GDK_KEY_KP_Page_Up || - keyval == GDK_KEY_Page_Down || keyval == GDK_KEY_KP_Page_Down || - ((state & (GDK_CONTROL_MASK | GDK_MOD1_MASK)) != 0)) - return TRUE; - - /* Other navigation events should get automatically - * ignored as they will not change the content of the entry - */ - return FALSE; -} - -static void -preedit_changed_cb (GtkEntry *entry, - GtkWidget *popup, - gboolean *preedit_changed) -{ - *preedit_changed = TRUE; -} - -static gboolean key_press_event (GtkWidget *window, GdkEvent *event, GtkInspectorStylePropList *pl) { - gboolean handled; - gboolean preedit_changed; - guint preedit_change_id; - gboolean res; - gchar *old_text, *new_text; - if (!gtk_widget_get_mapped (GTK_WIDGET (pl))) return GDK_EVENT_PROPAGATE; - if (is_keynav_event (event) || - event->key.keyval == GDK_KEY_space || - event->key.keyval == GDK_KEY_Menu) - return GDK_EVENT_PROPAGATE; - - if (event->key.keyval == GDK_KEY_Return || - event->key.keyval == GDK_KEY_ISO_Enter || - event->key.keyval == GDK_KEY_KP_Enter) - { - GtkTreeSelection *selection; - GtkTreeModel *model; - GtkTreeIter iter; - GtkTreePath *path; - - selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (pl->priv->tree)); - if (gtk_tree_selection_get_selected (selection, &model, &iter)) - { - path = gtk_tree_model_get_path (model, &iter); - gtk_tree_view_row_activated (GTK_TREE_VIEW (pl->priv->tree), - path, - pl->priv->name_column); - gtk_tree_path_free (path); - - return GDK_EVENT_STOP; - } - else - return GDK_EVENT_PROPAGATE; - } - - if (event->key.keyval == GDK_KEY_Escape) - { - gtk_entry_set_text (GTK_ENTRY (pl->priv->search_entry), ""); - gtk_stack_set_visible_child_name (GTK_STACK (pl->priv->search_stack), "title"); - return GDK_EVENT_STOP; - } - - if (!gtk_widget_get_realized (pl->priv->search_entry)) - gtk_widget_realize (pl->priv->search_entry); - - handled = FALSE; - preedit_changed = FALSE; - preedit_change_id = g_signal_connect (pl->priv->search_entry, "preedit-changed", - G_CALLBACK (preedit_changed_cb), &preedit_changed); - - old_text = g_strdup (gtk_entry_get_text (GTK_ENTRY (pl->priv->search_entry))); - res = gtk_widget_event (pl->priv->search_entry, event); - new_text = g_strdup (gtk_entry_get_text (GTK_ENTRY (pl->priv->search_entry))); - - g_signal_handler_disconnect (pl->priv->search_entry, preedit_change_id); - - if ((res && g_strcmp0 (new_text, old_text) != 0) || preedit_changed) + if (gtk_search_entry_handle_event (GTK_SEARCH_ENTRY (pl->priv->search_entry), event)) { gtk_stack_set_visible_child_name (GTK_STACK (pl->priv->search_stack), "search"); - handled = TRUE; + return GDK_EVENT_STOP; } - - g_free (old_text); - g_free (new_text); - - return handled ? GDK_EVENT_STOP : GDK_EVENT_PROPAGATE; + return GDK_EVENT_PROPAGATE; } static void @@ -210,8 +113,6 @@ gtk_inspector_style_prop_list_init (GtkInspectorStylePropList *pl) NULL, (GDestroyNotify) gtk_tree_iter_free); - g_signal_connect (pl, "hierarchy-changed", G_CALLBACK (hierarchy_changed), NULL); - for (i = 0; i < _gtk_css_style_property_get_n_properties (); i++) { GtkCssStyleProperty *prop; @@ -284,6 +185,7 @@ gtk_inspector_style_prop_list_class_init (GtkInspectorStylePropListClass *klass) gtk_widget_class_bind_template_child_private (widget_class, GtkInspectorStylePropList, object_title); gtk_widget_class_bind_template_child_private (widget_class, GtkInspectorStylePropList, name_column); gtk_widget_class_bind_template_callback (widget_class, search_close_clicked); + gtk_widget_class_bind_template_callback (widget_class, hierarchy_changed); } static gchar * diff --git a/gtk/inspector/style-prop-list.ui b/gtk/inspector/style-prop-list.ui index 5105cbfbb6..1ba50994f3 100644 --- a/gtk/inspector/style-prop-list.ui +++ b/gtk/inspector/style-prop-list.ui @@ -11,6 +11,7 @@ </object> <template class="GtkInspectorStylePropList" parent="GtkBox"> <property name="orientation">vertical</property> + <signal name="hierarchy-changed" handler="hierarchy_changed"/> <child> <object class="GtkStack" id="search_stack"> <property name="visible">True</property> @@ -27,6 +28,7 @@ <object class="GtkSearchEntry" id="search_entry"> <property name="visible">True</property> <property name="max-width-chars">40</property> + <signal name="stop-search" handler="search_close_clicked"/> </object> </child> <child> |