diff options
author | Benjamin Otte <otte@redhat.com> | 2013-03-05 13:09:10 +0100 |
---|---|---|
committer | Benjamin Otte <otte@redhat.com> | 2013-03-05 13:09:10 +0100 |
commit | dc331ccb171151d737112d8dc55b25709271d2c7 (patch) | |
tree | a9664e5aa7fc5d663c4d7120a7acc9eea4fcb145 /gtk/gtkentrycompletion.c | |
parent | 173317e9ce6d8ccb3fe9371e270aea38cd76c3ef (diff) | |
download | gtk+-dc331ccb171151d737112d8dc55b25709271d2c7.tar.gz |
entrycompletion: Don't reconnect signals all the time
We block signal handlers areound GtkEntry signal emission and if those
signals get used to call functions on the completion that cause a
reconnection of the signals, then the reconnected signals will not be
blocked anymore (so they might get emitted?) and unblocking the old
signal id will later cause warnings.
Fixes spurious warnings in gtk/tests/filechooser tests.
Diffstat (limited to 'gtk/gtkentrycompletion.c')
-rw-r--r-- | gtk/gtkentrycompletion.c | 71 |
1 files changed, 33 insertions, 38 deletions
diff --git a/gtk/gtkentrycompletion.c b/gtk/gtkentrycompletion.c index e4968dfbda..b0bf1c8695 100644 --- a/gtk/gtkentrycompletion.c +++ b/gtk/gtkentrycompletion.c @@ -1929,12 +1929,6 @@ gtk_entry_completion_set_inline_completion (GtkEntryCompletion *completion, { completion->priv->inline_completion = inline_completion; - if (completion->priv->entry) - { - disconnect_completion_signals (completion); - connect_completion_signals (completion); - } - g_object_notify (G_OBJECT (completion), "inline-completion"); } } @@ -1979,12 +1973,6 @@ gtk_entry_completion_set_popup_completion (GtkEntryCompletion *completion, { completion->priv->popup_completion = popup_completion; - if (completion->priv->entry) - { - disconnect_completion_signals (completion); - connect_completion_signals (completion); - } - g_object_notify (G_OBJECT (completion), "popup-completion"); } } @@ -2218,6 +2206,9 @@ gtk_entry_completion_key_press (GtkWidget *widget, gint matches, actions = 0; GtkEntryCompletion *completion = GTK_ENTRY_COMPLETION (user_data); + if (!completion->priv->popup_completion) + return FALSE; + if (event->keyval == GDK_KEY_Return || event->keyval == GDK_KEY_KP_Enter || event->keyval == GDK_KEY_ISO_Enter || @@ -2500,6 +2491,9 @@ gtk_entry_completion_changed (GtkWidget *widget, GtkEntry *entry = GTK_ENTRY (widget); GdkDevice *device; + if (!completion->priv->popup_completion) + return; + /* (re)install completion timeout */ if (completion->priv->completion_timeout) g_source_remove (completion->priv->completion_timeout); @@ -2545,13 +2539,14 @@ static void clear_completion_callback (GtkEntry *entry, GParamSpec *pspec) { + GtkEntryCompletion *completion = gtk_entry_get_completion (entry); + + if (!completion->priv->inline_completion) + return; + if (pspec->name == I_("cursor-position") || pspec->name == I_("selection-bound")) - { - GtkEntryCompletion *completion = gtk_entry_get_completion (entry); - - completion->priv->has_completion = FALSE; - } + completion->priv->has_completion = FALSE; } static gboolean @@ -2559,6 +2554,9 @@ accept_completion_callback (GtkEntry *entry) { GtkEntryCompletion *completion = gtk_entry_get_completion (entry); + if (!completion->priv->inline_completion) + return FALSE; + if (completion->priv->has_completion) gtk_editable_set_position (GTK_EDITABLE (entry), gtk_entry_buffer_get_length (gtk_entry_get_buffer (entry))); @@ -2573,6 +2571,9 @@ completion_insert_text_callback (GtkEntry *entry, gint position, GtkEntryCompletion *completion) { + if (!completion->priv->inline_completion) + return; + /* idle to update the selection based on the file list */ if (completion->priv->check_completion_idle == NULL) { @@ -2588,27 +2589,21 @@ completion_insert_text_callback (GtkEntry *entry, static void connect_completion_signals (GtkEntryCompletion *completion) { - if (completion->priv->popup_completion) - { - completion->priv->changed_id = - g_signal_connect (completion->priv->entry, "changed", - G_CALLBACK (gtk_entry_completion_changed), completion); - g_signal_connect (completion->priv->entry, "key-press-event", - G_CALLBACK (gtk_entry_completion_key_press), completion); - } - - if (completion->priv->inline_completion) - { - completion->priv->insert_text_id = - g_signal_connect (completion->priv->entry, "insert-text", - G_CALLBACK (completion_insert_text_callback), completion); - g_signal_connect (completion->priv->entry, "notify", - G_CALLBACK (clear_completion_callback), completion); - g_signal_connect (completion->priv->entry, "activate", - G_CALLBACK (accept_completion_callback), completion); - g_signal_connect (completion->priv->entry, "focus-out-event", - G_CALLBACK (accept_completion_callback), completion); - } + completion->priv->changed_id = + g_signal_connect (completion->priv->entry, "changed", + G_CALLBACK (gtk_entry_completion_changed), completion); + g_signal_connect (completion->priv->entry, "key-press-event", + G_CALLBACK (gtk_entry_completion_key_press), completion); + + completion->priv->insert_text_id = + g_signal_connect (completion->priv->entry, "insert-text", + G_CALLBACK (completion_insert_text_callback), completion); + g_signal_connect (completion->priv->entry, "notify", + G_CALLBACK (clear_completion_callback), completion); + g_signal_connect (completion->priv->entry, "activate", + G_CALLBACK (accept_completion_callback), completion); + g_signal_connect (completion->priv->entry, "focus-out-event", + G_CALLBACK (accept_completion_callback), completion); } static void |