[nautilus/wip/antoniof/gtk4-preparation-file-chooser-api: 4/5] file-operations: Prevent overriding source on move
- From: António Fernandes <antoniof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [nautilus/wip/antoniof/gtk4-preparation-file-chooser-api: 4/5] file-operations: Prevent overriding source on move
- Date: Sun, 26 Dec 2021 01:57:32 +0000 (UTC)
commit 2bc4acff66e9c969c8f86a70676f457adc8896e7
Author: António Fernandes <antoniof gnome org>
Date: Sat Dec 25 22:01:19 2021 +0000
file-operations: Prevent overriding source on move
This had been fixed but only for the fallback implementation, as per
100781f806b922cf6b959ec663a196a47b6eb71e
As a result, when moving a file/folder to its current location, the
default implementation still tries g_file_move(), which obviously
fails with a conflict, then presents the user the conflict dialog.
Then:
- for a file, if the user chooses "Replace", then g_file_move()
proceeds to replace the file with itself, which is... useless at best.
- for a folder, if the user chooses "Merge", g_file_move() still
fails because it doesn't support merging, so we try the fallback
implementation which, finally, warns the user that this is not allowed.
So, the first case is useless and the second case asks the user if
they want to perform an action which is not allowed anyway.
This issue is reproducible using the "Move to..." action.
So, copy the fix to the g_file_move() path. It's probably an oversight
of the original fix that it was done for only one path.
src/nautilus-file-operations.c | 45 ++++++++++++++++++++++++++++++++++++++++++
1 file changed, 45 insertions(+)
---
diff --git a/src/nautilus-file-operations.c b/src/nautilus-file-operations.c
index 72ae0d2c8..73893d7f4 100644
--- a/src/nautilus-file-operations.c
+++ b/src/nautilus-file-operations.c
@@ -6274,6 +6274,51 @@ move_file_prepare (CopyMoveJob *move_job,
goto out;
}
+ /* Don't allow moving over the source or one of the parents of the source.
+ */
+ if (test_dir_is_parent (src, dest))
+ {
+ int response;
+
+ if (job->skip_all_error)
+ {
+ goto out;
+ }
+
+ /* the run_warning() frees all strings passed in automatically */
+ primary = move_job->is_move ? g_strdup (_("You cannot move a file over itself."))
+ : g_strdup (_("You cannot copy a file over itself."));
+ secondary = g_strdup (_("The source file would be overwritten by the destination."));
+
+ response = run_warning (job,
+ primary,
+ secondary,
+ NULL,
+ files_left > 1,
+ CANCEL, SKIP_ALL, SKIP,
+ NULL);
+
+ if (response == 0 || response == GTK_RESPONSE_DELETE_EVENT)
+ {
+ abort_job (job);
+ }
+ else if (response == 1) /* skip all */
+ {
+ job->skip_all_error = TRUE;
+ }
+ else if (response == 2) /* skip */
+ {
+ /* do nothing */
+ }
+ else
+ {
+ g_assert_not_reached ();
+ }
+
+ goto out;
+ }
+
+
retry:
flags = G_FILE_COPY_NOFOLLOW_SYMLINKS | G_FILE_COPY_NO_FALLBACK_FOR_MOVE;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]