mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-07 19:30:12 +00:00
inspector: Don't select 'randomly'
While rescanning the object tree, we were emitting ::object-selected signals, possibly causing wild blinking in the application window. Don't do that. https://bugzilla.gnome.org/show_bug.cgi?id=760572
This commit is contained in:
parent
0d298ea75b
commit
dc5c82e29c
@ -1114,6 +1114,24 @@ gtk_inspector_object_tree_append_object (GtkInspectorObjectTree *wt,
|
|||||||
object_forall (object, child_callback, &data);
|
object_forall (object, child_callback, &data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
block_selection_changed (GtkInspectorObjectTree *wt)
|
||||||
|
{
|
||||||
|
GtkTreeSelection *selection;
|
||||||
|
|
||||||
|
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (wt->priv->tree));
|
||||||
|
g_signal_handlers_block_by_func (selection, on_selection_changed, wt);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
unblock_selection_changed (GtkInspectorObjectTree *wt)
|
||||||
|
{
|
||||||
|
GtkTreeSelection *selection;
|
||||||
|
|
||||||
|
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (wt->priv->tree));
|
||||||
|
g_signal_handlers_unblock_by_func (selection, on_selection_changed, wt);
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
select_object_internal (GtkInspectorObjectTree *wt,
|
select_object_internal (GtkInspectorObjectTree *wt,
|
||||||
GObject *object,
|
GObject *object,
|
||||||
@ -1130,10 +1148,10 @@ select_object_internal (GtkInspectorObjectTree *wt,
|
|||||||
path = gtk_tree_model_get_path (GTK_TREE_MODEL (wt->priv->model), &iter);
|
path = gtk_tree_model_get_path (GTK_TREE_MODEL (wt->priv->model), &iter);
|
||||||
gtk_tree_view_expand_to_path (GTK_TREE_VIEW (wt->priv->tree), path);
|
gtk_tree_view_expand_to_path (GTK_TREE_VIEW (wt->priv->tree), path);
|
||||||
if (!activate)
|
if (!activate)
|
||||||
g_signal_handlers_block_by_func (selection, on_selection_changed, wt);
|
block_selection_changed (wt);
|
||||||
gtk_tree_selection_select_iter (selection, &iter);
|
gtk_tree_selection_select_iter (selection, &iter);
|
||||||
if (!activate)
|
if (!activate)
|
||||||
g_signal_handlers_unblock_by_func (selection, on_selection_changed, wt);
|
unblock_selection_changed (wt);
|
||||||
|
|
||||||
gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (wt->priv->tree), path, NULL, TRUE, 0.5, 0);
|
gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (wt->priv->tree), path, NULL, TRUE, 0.5, 0);
|
||||||
if (activate)
|
if (activate)
|
||||||
@ -1162,6 +1180,8 @@ gtk_inspector_object_tree_scan (GtkInspectorObjectTree *wt,
|
|||||||
GdkScreen *screen;
|
GdkScreen *screen;
|
||||||
GObject *selected;
|
GObject *selected;
|
||||||
|
|
||||||
|
block_selection_changed (wt);
|
||||||
|
|
||||||
selected = gtk_inspector_object_tree_get_selected (wt);
|
selected = gtk_inspector_object_tree_get_selected (wt);
|
||||||
|
|
||||||
clear_store (wt);
|
clear_store (wt);
|
||||||
@ -1191,6 +1211,8 @@ gtk_inspector_object_tree_scan (GtkInspectorObjectTree *wt,
|
|||||||
|
|
||||||
if (selected)
|
if (selected)
|
||||||
select_object_internal (wt, selected, FALSE);
|
select_object_internal (wt, selected, FALSE);
|
||||||
|
|
||||||
|
unblock_selection_changed (wt);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
Loading…
Reference in New Issue
Block a user