Merge pull request #93372 from KoBeWi/instant_folders,_like_instant_noodles,_but_for_storing_files

Don't rescan filesystem when adding new directory
This commit is contained in:
Rémi Verschelde 2024-09-16 13:34:09 +02:00
commit 5b2eececfd
No known key found for this signature in database
GPG Key ID: C3336907360768E1
4 changed files with 48 additions and 1 deletions

View File

@ -3057,6 +3057,35 @@ void EditorFileSystem::move_group_file(const String &p_path, const String &p_new
}
}
void EditorFileSystem::add_new_directory(const String &p_path) {
String path = p_path.get_base_dir();
EditorFileSystemDirectory *parent = filesystem;
int base = p_path.count("/");
int max_bit = base + 1;
while (path != "res://") {
EditorFileSystemDirectory *dir = get_filesystem_path(path);
if (dir) {
parent = dir;
break;
}
path = path.get_base_dir();
base--;
}
for (int i = base; i < max_bit; i++) {
EditorFileSystemDirectory *efd = memnew(EditorFileSystemDirectory);
efd->parent = parent;
efd->name = p_path.get_slice("/", i);
parent->subdirs.push_back(efd);
if (i == base) {
parent->subdirs.sort_custom<DirectoryComparator>();
}
parent = efd;
}
}
ResourceUID::ID EditorFileSystem::_resource_saver_get_resource_id_for_path(const String &p_path, bool p_generate) {
if (!p_path.is_resource_file() || p_path.begins_with(ProjectSettings::get_singleton()->get_project_data_path())) {
// Saved externally (configuration file) or internal file, do not assign an ID.

View File

@ -224,6 +224,12 @@ class EditorFileSystem : public Node {
void increment();
};
struct DirectoryComparator {
bool operator()(const EditorFileSystemDirectory *p_a, const EditorFileSystemDirectory *p_b) const {
return p_a->name.filenocasecmp_to(p_b->name) < 0;
}
};
void _save_filesystem_cache();
void _save_filesystem_cache(EditorFileSystemDirectory *p_dir, Ref<FileAccess> p_file);
@ -364,6 +370,8 @@ public:
bool is_group_file(const String &p_path) const;
void move_group_file(const String &p_path, const String &p_new_path);
void add_new_directory(const String &p_path);
static bool _should_skip_directory(const String &p_path);
void add_import_format_support_query(Ref<EditorFileSystemImportFormatSupportQuery> p_query);

View File

@ -1318,6 +1318,15 @@ void FileSystemDock::_fs_changed() {
set_process(false);
}
void FileSystemDock::_directory_created(const String &p_path) {
if (!DirAccess::exists(p_path)) {
return;
}
EditorFileSystem::get_singleton()->add_new_directory(p_path);
_update_tree(get_uncollapsed_paths());
_update_file_list(true);
}
void FileSystemDock::_set_scanning_mode() {
button_hist_prev->set_disabled(true);
button_hist_next->set_disabled(true);
@ -4175,7 +4184,7 @@ FileSystemDock::FileSystemDock() {
make_dir_dialog = memnew(DirectoryCreateDialog);
add_child(make_dir_dialog);
make_dir_dialog->connect("dir_created", callable_mp(this, &FileSystemDock::_rescan).unbind(1));
make_dir_dialog->connect("dir_created", callable_mp(this, &FileSystemDock::_directory_created));
make_scene_dialog = memnew(SceneCreateDialog);
add_child(make_scene_dialog);

View File

@ -260,6 +260,7 @@ private:
void _toggle_file_display();
void _set_file_display(bool p_active);
void _fs_changed();
void _directory_created(const String &p_path);
void _select_file(const String &p_path, bool p_select_in_favorites = false);
void _tree_activate_file();