forked from AuroraMiddleware/gtk
Log to recent-files when confirming the file chooser
To make life easier for users, when apps don't properly update the recently-used list after choosing a file, we now do that directly from the file chooser. Signed-off-by: Federico Mena Quintero <federico@gnome.org>
This commit is contained in:
parent
685a688470
commit
6b0ab20bc7
@ -8435,18 +8435,46 @@ location_popup_on_paste_handler (GtkFileChooserDefault *impl)
|
||||
}
|
||||
|
||||
/* Implementation for GtkFileChooserEmbed::should_respond() */
|
||||
static void
|
||||
add_selection_to_recent_list (GtkFileChooserDefault *impl)
|
||||
{
|
||||
GSList *files;
|
||||
GSList *l;
|
||||
|
||||
files = gtk_file_chooser_default_get_files (GTK_FILE_CHOOSER (impl));
|
||||
|
||||
for (l = files; l; l = l->next)
|
||||
{
|
||||
GFile *file = l->data;
|
||||
char *uri;
|
||||
|
||||
uri = g_file_get_uri (file);
|
||||
if (uri)
|
||||
{
|
||||
gtk_recent_manager_add_item (impl->recent_manager, uri);
|
||||
g_free (uri);
|
||||
}
|
||||
}
|
||||
|
||||
g_slist_foreach (files, (GFunc) g_object_unref, NULL);
|
||||
g_slist_free (files);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
{
|
||||
GtkFileChooserDefault *impl;
|
||||
GtkWidget *toplevel;
|
||||
GtkWidget *current_focus;
|
||||
gboolean retval;
|
||||
|
||||
impl = GTK_FILE_CHOOSER_DEFAULT (chooser_embed);
|
||||
|
||||
toplevel = gtk_widget_get_toplevel (GTK_WIDGET (impl));
|
||||
g_assert (GTK_IS_WINDOW (toplevel));
|
||||
|
||||
retval = FALSE;
|
||||
|
||||
current_focus = gtk_window_get_focus (GTK_WINDOW (toplevel));
|
||||
|
||||
if (current_focus == impl->browse_files_tree_view)
|
||||
@ -8481,14 +8509,20 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
g_assert (impl->action >= GTK_FILE_CHOOSER_ACTION_OPEN && impl->action <= GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER);
|
||||
|
||||
if (impl->operation_mode == OPERATION_MODE_SEARCH)
|
||||
return search_should_respond (impl);
|
||||
{
|
||||
retval = search_should_respond (impl);
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (impl->operation_mode == OPERATION_MODE_RECENT)
|
||||
{
|
||||
if (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE)
|
||||
goto save_entry;
|
||||
else
|
||||
return recent_should_respond (impl);
|
||||
{
|
||||
retval = recent_should_respond (impl);
|
||||
goto out;
|
||||
}
|
||||
}
|
||||
|
||||
selection_check (impl, &num_selected, &all_files, &all_folders);
|
||||
@ -8506,7 +8540,8 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
return FALSE;
|
||||
|
||||
case RESPOND:
|
||||
return TRUE;
|
||||
retval = TRUE;
|
||||
goto out;
|
||||
|
||||
case RESPOND_OR_SWITCH:
|
||||
g_assert (num_selected == 1);
|
||||
@ -8517,17 +8552,25 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
return FALSE;
|
||||
}
|
||||
else if (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE)
|
||||
return should_respond_after_confirm_overwrite (impl,
|
||||
get_display_name_from_file_list (impl),
|
||||
impl->current_folder);
|
||||
{
|
||||
retval = should_respond_after_confirm_overwrite (impl,
|
||||
get_display_name_from_file_list (impl),
|
||||
impl->current_folder);
|
||||
goto out;
|
||||
}
|
||||
else
|
||||
return TRUE;
|
||||
{
|
||||
retval = TRUE;
|
||||
goto out;
|
||||
}
|
||||
|
||||
case ALL_FILES:
|
||||
return all_files;
|
||||
retval = all_files;
|
||||
goto out;
|
||||
|
||||
case ALL_FOLDERS:
|
||||
return all_folders;
|
||||
retval = all_folders;
|
||||
goto out;
|
||||
|
||||
case SAVE_ENTRY:
|
||||
goto save_entry;
|
||||
@ -8541,7 +8584,6 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
GFile *file;
|
||||
gboolean is_well_formed, is_empty, is_file_part_empty;
|
||||
gboolean is_folder;
|
||||
gboolean retval;
|
||||
GtkFileChooserEntry *entry;
|
||||
GError *error;
|
||||
|
||||
@ -8599,7 +8641,6 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
impl->action == GTK_FILE_CHOOSER_ACTION_SAVE)
|
||||
{
|
||||
change_folder_and_display_error (impl, file, TRUE);
|
||||
retval = FALSE;
|
||||
}
|
||||
else if (impl->action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER ||
|
||||
impl->action == GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER)
|
||||
@ -8612,7 +8653,6 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
else
|
||||
{
|
||||
g_assert_not_reached ();
|
||||
retval = FALSE;
|
||||
}
|
||||
}
|
||||
else
|
||||
@ -8640,14 +8680,12 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
data);
|
||||
|
||||
set_busy_cursor (impl, TRUE);
|
||||
retval = FALSE;
|
||||
|
||||
if (error != NULL)
|
||||
g_error_free (error);
|
||||
}
|
||||
|
||||
g_object_unref (file);
|
||||
return retval;
|
||||
}
|
||||
else if (impl->toplevel_last_focus_widget == impl->browse_files_tree_view)
|
||||
{
|
||||
@ -8675,9 +8713,13 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed)
|
||||
goto save_entry;
|
||||
else
|
||||
goto file_list;
|
||||
|
||||
g_assert_not_reached ();
|
||||
return FALSE;
|
||||
|
||||
out:
|
||||
|
||||
if (retval)
|
||||
add_selection_to_recent_list (impl);
|
||||
|
||||
return retval;
|
||||
}
|
||||
|
||||
/* Implementation for GtkFileChooserEmbed::initial_focus() */
|
||||
|
Loading…
Reference in New Issue
Block a user