FileSystemDock: List conflicting files on move

Fixes #24167.

(cherry picked from commit 7dc41ff310)
This commit is contained in:
Rémi Verschelde 2020-12-10 12:53:56 +01:00
parent e08af90c90
commit c509ba9ff7
No known key found for this signature in database
GPG key ID: C3336907360768E1
2 changed files with 13 additions and 10 deletions

View file

@ -1388,7 +1388,8 @@ void FileSystemDock::_move_with_overwrite() {
_move_operation_confirm(to_move_path, true);
}
bool FileSystemDock::_check_existing() {
Vector<String> FileSystemDock::_check_existing() {
Vector<String> conflicting_items;
String &p_to_path = to_move_path;
for (int i = 0; i < to_move.size(); i++) {
String ol_pth = to_move[i].path.ends_with("/") ? to_move[i].path.substr(0, to_move[i].path.length() - 1) : to_move[i].path;
@ -1398,21 +1399,24 @@ bool FileSystemDock::_check_existing() {
String old_path = (p_item.is_file || p_item.path.ends_with("/")) ? p_item.path : (p_item.path + "/");
String new_path = (p_item.is_file || p_new_path.ends_with("/")) ? p_new_path : (p_new_path + "/");
if (p_item.is_file && FileAccess::exists(new_path)) {
return false;
} else if (!p_item.is_file && DirAccess::exists(new_path)) {
return false;
if ((p_item.is_file && FileAccess::exists(new_path)) ||
(!p_item.is_file && DirAccess::exists(new_path))) {
conflicting_items.push_back(old_path);
}
}
return true;
return conflicting_items;
}
void FileSystemDock::_move_operation_confirm(const String &p_to_path, bool overwrite) {
if (!overwrite) {
to_move_path = p_to_path;
bool can_move = _check_existing();
if (!can_move) {
Vector<String> conflicting_items = _check_existing();
if (!conflicting_items.empty()) {
// Ask to do something.
overwrite_dialog->set_text(vformat(
TTR("The following files or folders conflict with items in the target location '%s':\n\n%s\n\nDo you wish to overwrite them?"),
to_move_path,
String("\n").join(conflicting_items)));
overwrite_dialog->popup_centered_minsize();
return;
}
@ -2707,7 +2711,6 @@ FileSystemDock::FileSystemDock(EditorNode *p_editor) {
rename_dialog->connect("confirmed", this, "_rename_operation_confirm");
overwrite_dialog = memnew(ConfirmationDialog);
overwrite_dialog->set_text(TTR("There is already file or folder with the same name in this location."));
overwrite_dialog->get_ok()->set_text(TTR("Overwrite"));
add_child(overwrite_dialog);
overwrite_dialog->connect("confirmed", this, "_move_with_overwrite");

View file

@ -221,7 +221,7 @@ private:
void _rename_operation_confirm();
void _duplicate_operation_confirm();
void _move_with_overwrite();
bool _check_existing();
Vector<String> _check_existing();
void _move_operation_confirm(const String &p_to_path, bool overwrite = false);
void _tree_rmb_option(int p_option);