From 8ac5f1983ed2f63a51662be60bb85f66ed2033e1 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Wed, 12 Oct 2022 00:05:44 -0400 Subject: [PATCH 1/2] filechooserentry: Add a set_text api This function prevents the completion popup from coming up when setting the entry text. --- gtk/gtkfilechooserentry.c | 17 +++++++++++++++++ gtk/gtkfilechooserentry.h | 2 ++ 2 files changed, 19 insertions(+) diff --git a/gtk/gtkfilechooserentry.c b/gtk/gtkfilechooserentry.c index 62d751fa86..1d5c66c435 100644 --- a/gtk/gtkfilechooserentry.c +++ b/gtk/gtkfilechooserentry.c @@ -1017,3 +1017,20 @@ _gtk_file_chooser_entry_set_file_filter (GtkFileChooserEntry *chooser_entry, { chooser_entry->current_filter = filter; } + +void +gtk_file_chooser_entry_set_text (GtkFileChooserEntry *entry, + const char *text) +{ + GtkEntryCompletion *completion; + gboolean popup; + + completion = gtk_entry_get_completion (GTK_ENTRY (entry)); + popup = gtk_entry_completion_get_popup_completion (completion); + + gtk_entry_completion_set_popup_completion (completion, FALSE); + + gtk_editable_set_text (GTK_EDITABLE (entry), text); + + gtk_entry_completion_set_popup_completion (completion, popup); +} diff --git a/gtk/gtkfilechooserentry.h b/gtk/gtkfilechooserentry.h index 6ee277f8f7..f7fd7428ec 100644 --- a/gtk/gtkfilechooserentry.h +++ b/gtk/gtkfilechooserentry.h @@ -44,6 +44,8 @@ gboolean _gtk_file_chooser_entry_get_is_folder (GtkFileChooserEnt void _gtk_file_chooser_entry_select_filename (GtkFileChooserEntry *chooser_entry); void _gtk_file_chooser_entry_set_file_filter (GtkFileChooserEntry *chooser_entry, GtkFileFilter *filter); +void gtk_file_chooser_entry_set_text (GtkFileChooserEntry *entry, + const char *text); G_END_DECLS From fa3c8ed5f9a9a9679dd8e65b4988bb605a58bf47 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Wed, 12 Oct 2022 00:06:21 -0400 Subject: [PATCH 2/2] filechooser: Stop using entrycompletion api The file chooser entry now has an api for this. --- gtk/gtkfilechooserwidget.c | 28 +++++----------------------- 1 file changed, 5 insertions(+), 23 deletions(-) diff --git a/gtk/gtkfilechooserwidget.c b/gtk/gtkfilechooserwidget.c index 8b00a40e65..3cd9a18942 100644 --- a/gtk/gtkfilechooserwidget.c +++ b/gtk/gtkfilechooserwidget.c @@ -4771,19 +4771,11 @@ update_chooser_entry (GtkFileChooserWidget *impl) if (change_entry && !impl->auto_selecting_first_row) { -G_GNUC_BEGIN_IGNORE_DEPRECATIONS - - GtkEntryCompletion *completion = gtk_entry_get_completion (GTK_ENTRY (impl->location_entry)); - - if (completion) - gtk_entry_completion_set_popup_completion (completion, FALSE); g_signal_handlers_block_by_func (impl->location_entry, G_CALLBACK (location_entry_changed_cb), impl); - gtk_editable_set_text (GTK_EDITABLE (impl->location_entry), impl->browse_files_last_selected_name); - g_signal_handlers_unblock_by_func (impl->location_entry, G_CALLBACK (location_entry_changed_cb), impl); - if (completion) - gtk_entry_completion_set_popup_completion (completion, TRUE); -G_GNUC_END_IGNORE_DEPRECATIONS + gtk_file_chooser_entry_set_text (GTK_FILE_CHOOSER_ENTRY (impl->location_entry), impl->browse_files_last_selected_name); + + g_signal_handlers_unblock_by_func (impl->location_entry, G_CALLBACK (location_entry_changed_cb), impl); if (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE) _gtk_file_chooser_entry_select_filename (GTK_FILE_CHOOSER_ENTRY (impl->location_entry)); @@ -5124,22 +5116,12 @@ gtk_file_chooser_widget_set_current_name (GtkFileChooser *chooser, const char *name) { GtkFileChooserWidget *impl = GTK_FILE_CHOOSER_WIDGET (chooser); - GtkEntryCompletion *completion; g_return_if_fail (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE); pending_select_files_free (impl); -G_GNUC_BEGIN_IGNORE_DEPRECATIONS - - completion = gtk_entry_get_completion (GTK_ENTRY (impl->location_entry)); - gtk_entry_completion_set_popup_completion (completion, FALSE); - - gtk_editable_set_text (GTK_EDITABLE (impl->location_entry), name); - - gtk_entry_completion_set_popup_completion (completion, TRUE); - -G_GNUC_END_IGNORE_DEPRECATIONS + gtk_file_chooser_entry_set_text (GTK_FILE_CHOOSER_ENTRY (impl->location_entry), name); } static char * @@ -7122,7 +7104,7 @@ static void location_set_user_text (GtkFileChooserWidget *impl, const char *path) { - gtk_editable_set_text (GTK_EDITABLE (impl->location_entry), path); + gtk_file_chooser_entry_set_text (GTK_FILE_CHOOSER_ENTRY (impl->location_entry), path); gtk_editable_set_position (GTK_EDITABLE (impl->location_entry), -1); }