summaryrefslogtreecommitdiffstats
path: root/editor/editor_file_system.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-08-26 22:45:04 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-08-26 22:45:04 +0200
commitb78da13e2a7aa21cb0d3c1996954776287ffc7b1 (patch)
treeb55b3a374e198b5b10eca4f4ccc9539fb2942a7b /editor/editor_file_system.cpp
parent8dad1ba482cf214b850e9d59942fb85bc2490e51 (diff)
parent1b0c5cbc01b43b837a658fdd25373a773b3dbdc4 (diff)
downloadredot-engine-b78da13e2a7aa21cb0d3c1996954776287ffc7b1.tar.gz
Merge pull request #93064 from Hilderin/fix-fileSystem-dock-wont-show-any-file-folders
Fix FileSystem dock won't show any file folders (v2)
Diffstat (limited to 'editor/editor_file_system.cpp')
-rw-r--r--editor/editor_file_system.cpp77
1 files changed, 63 insertions, 14 deletions
diff --git a/editor/editor_file_system.cpp b/editor/editor_file_system.cpp
index 4d5749d949..22ff7a4509 100644
--- a/editor/editor_file_system.cpp
+++ b/editor/editor_file_system.cpp
@@ -228,15 +228,18 @@ EditorFileSystem::ScannedDirectory::~ScannedDirectory() {
}
void EditorFileSystem::_first_scan_filesystem() {
+ EditorProgress ep = EditorProgress("first_scan_filesystem", TTR("Project initialization"), 5);
Ref<DirAccess> d = DirAccess::create(DirAccess::ACCESS_RESOURCES);
first_scan_root_dir = memnew(ScannedDirectory);
first_scan_root_dir->full_path = "res://";
HashSet<String> existing_class_names;
+ ep.step(TTR("Scanning file structure..."), 0, true);
nb_files_total = _scan_new_dir(first_scan_root_dir, d);
// This loads the global class names from the scripts and ensures that even if the
// global_script_class_cache.cfg was missing or invalid, the global class names are valid in ScriptServer.
+ ep.step(TTR("Loading global class names..."), 1, true);
_first_scan_process_scripts(first_scan_root_dir, existing_class_names);
// Removing invalid global class to prevent having invalid paths in ScriptServer.
@@ -245,8 +248,13 @@ void EditorFileSystem::_first_scan_filesystem() {
// Now that all the global class names should be loaded, create autoloads and plugins.
// This is done after loading the global class names because autoloads and plugins can use
// global class names.
+ ep.step(TTR("Creating autoload scripts..."), 3, true);
ProjectSettingsEditor::get_singleton()->init_autoloads();
+
+ ep.step(TTR("Initializing plugins..."), 4, true);
EditorNode::get_singleton()->init_plugins();
+
+ ep.step(TTR("Starting file scan..."), 5, true);
}
void EditorFileSystem::_first_scan_process_scripts(const ScannedDirectory *p_scan_dir, HashSet<String> &p_existing_class_names) {
@@ -650,6 +658,12 @@ bool EditorFileSystem::_update_scan_actions() {
Vector<String> reimports;
Vector<String> reloads;
+ EditorProgress *ep = nullptr;
+ if (scan_actions.size() > 1) {
+ ep = memnew(EditorProgress("_update_scan_actions", TTR("Scanning actions..."), scan_actions.size()));
+ }
+
+ int step_count = 0;
for (const ItemAction &ia : scan_actions) {
switch (ia.action) {
case ItemAction::ACTION_NONE: {
@@ -781,8 +795,14 @@ bool EditorFileSystem::_update_scan_actions() {
} break;
}
+
+ if (ep) {
+ ep->step(ia.file, step_count++, false);
+ }
}
+ memdelete_notnull(ep);
+
if (_scan_extensions()) {
//needs editor restart
//extensions also may provide filetypes to be imported, so they must run before importing
@@ -872,8 +892,6 @@ void EditorFileSystem::scan() {
scan_total = 0;
s.priority = Thread::PRIORITY_LOW;
thread.start(_thread_func, this, s);
- //tree->hide();
- //progress->show();
}
}
@@ -1022,9 +1040,8 @@ void EditorFileSystem::_process_file_system(const ScannedDirectory *p_scan_dir,
}
} else {
- fi->type = ResourceFormatImporter::get_singleton()->get_resource_type(path);
- fi->uid = ResourceFormatImporter::get_singleton()->get_resource_uid(path);
- fi->import_group_file = ResourceFormatImporter::get_singleton()->get_import_group_file(path);
+ // Using get_resource_import_info() to prevent calling 3 times ResourceFormatImporter::_get_path_and_type.
+ ResourceFormatImporter::get_singleton()->get_resource_import_info(path, fi->type, fi->uid, fi->import_group_file);
fi->script_class_name = _get_global_script_class(fi->type, path, &fi->script_class_extends, &fi->script_class_icon_path);
fi->modified_time = 0;
fi->import_modified_time = 0;
@@ -1830,10 +1847,21 @@ void EditorFileSystem::_update_script_classes() {
update_script_mutex.lock();
+ EditorProgress *ep = nullptr;
+ if (update_script_paths.size() > 1) {
+ ep = memnew(EditorProgress("update_scripts_classes", TTR("Registering global classes..."), update_script_paths.size()));
+ }
+
+ int step_count = 0;
for (const KeyValue<String, ScriptInfo> &E : update_script_paths) {
_register_global_class_script(E.key, E.key, E.value.type, E.value.script_class_name, E.value.script_class_extends, E.value.script_class_icon_path);
+ if (ep) {
+ ep->step(E.value.script_class_name, step_count++, false);
+ }
}
+ memdelete_notnull(ep);
+
update_script_paths.clear();
update_script_mutex.unlock();
@@ -1858,6 +1886,12 @@ void EditorFileSystem::_update_script_documentation() {
update_script_mutex.lock();
+ EditorProgress *ep = nullptr;
+ if (update_script_paths_documentation.size() > 1) {
+ ep = memnew(EditorProgress("update_script_paths_documentation", TTR("Updating scripts documentation"), update_script_paths_documentation.size()));
+ }
+
+ int step_count = 0;
for (const String &path : update_script_paths_documentation) {
int index = -1;
EditorFileSystemDirectory *efd = find_file(path, &index);
@@ -1880,8 +1914,14 @@ void EditorFileSystem::_update_script_documentation() {
}
}
}
+
+ if (ep) {
+ ep->step(efd->files[index]->file, step_count++, false);
+ }
}
+ memdelete_notnull(ep);
+
update_script_paths_documentation.clear();
update_script_mutex.unlock();
}
@@ -1916,7 +1956,7 @@ void EditorFileSystem::_update_scene_groups() {
EditorProgress *ep = nullptr;
if (update_scene_paths.size() > 20) {
- ep = memnew(EditorProgress("update_scene_groups", TTR("Update Scene Groups"), update_scene_paths.size()));
+ ep = memnew(EditorProgress("update_scene_groups", TTR("Updating Scene Groups"), update_scene_paths.size()));
}
int step_count = 0;
@@ -1938,7 +1978,7 @@ void EditorFileSystem::_update_scene_groups() {
}
if (ep) {
- ep->step(TTR("Updating Scene Groups..."), step_count++);
+ ep->step(efd->files[index]->file, step_count++);
}
}
@@ -2654,13 +2694,15 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
Vector<String> reloads;
- EditorProgress pr("reimport", TTR("(Re)Importing Assets"), p_files.size());
+ EditorProgress *ep = memnew(EditorProgress("reimport", TTR("(Re)Importing Assets"), p_files.size()));
Vector<ImportFile> reimport_files;
HashSet<String> groups_to_reimport;
for (int i = 0; i < p_files.size(); i++) {
+ ep->step(TTR("Preparing files to reimport..."), i, false);
+
String file = p_files[i];
ResourceUID::ID uid = ResourceUID::get_singleton()->text_to_id(file);
@@ -2700,6 +2742,8 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
reimport_files.sort();
+ ep->step(TTR("Executing pre-reimport operations..."), 0, true);
+
// Emit the resource_reimporting signal for the single file before the actual importation.
emit_signal(SNAME("resources_reimporting"), reloads);
@@ -2720,7 +2764,7 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
if (i + 1 == reimport_files.size() || reimport_files[i + 1].importer != reimport_files[from].importer || groups_to_reimport.has(reimport_files[i + 1].path)) {
if (from - i == 0) {
// Single file, do not use threads.
- pr.step(reimport_files[i].path.get_file(), i);
+ ep->step(reimport_files[i].path.get_file(), i, false);
_reimport_file(reimport_files[i].path);
} else {
Ref<ResourceImporter> importer = ResourceFormatImporter::get_singleton()->get_importer_by_name(reimport_files[from].importer);
@@ -2742,7 +2786,7 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
do {
if (current_index < tdata.max_index.get()) {
current_index = tdata.max_index.get();
- pr.step(reimport_files[current_index].path.get_file(), current_index);
+ ep->step(reimport_files[current_index].path.get_file(), current_index, false);
}
OS::get_singleton()->delay_usec(1);
} while (!WorkerThreadPool::get_singleton()->is_group_task_completed(group_task));
@@ -2756,7 +2800,7 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
}
} else {
- pr.step(reimport_files[i].path.get_file(), i);
+ ep->step(reimport_files[i].path.get_file(), i, false);
_reimport_file(reimport_files[i].path);
// We need to increment the counter, maybe the next file is multithreaded
@@ -2773,7 +2817,7 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
HashMap<String, Vector<String>> group_files;
_find_group_files(filesystem, group_files, groups_to_reimport);
for (const KeyValue<String, Vector<String>> &E : group_files) {
- pr.step(E.key.get_file(), from++);
+ ep->step(E.key.get_file(), from++, false);
Error err = _reimport_group(E.key, E.value);
reloads.push_back(E.key);
reloads.append_array(E.value);
@@ -2784,15 +2828,20 @@ void EditorFileSystem::reimport_files(const Vector<String> &p_files) {
}
ResourceUID::get_singleton()->update_cache(); // After reimporting, update the cache.
-
_save_filesystem_cache();
+
+ memdelete_notnull(ep);
+
_process_update_pending();
importing = false;
+
+ ep = memnew(EditorProgress("reimport", TTR("(Re)Importing Assets"), p_files.size()));
+ ep->step(TTR("Executing post-reimport operations..."), 0, true);
if (!is_scanning()) {
emit_signal(SNAME("filesystem_changed"));
}
-
emit_signal(SNAME("resources_reimported"), reloads);
+ memdelete_notnull(ep);
}
Error EditorFileSystem::reimport_append(const String &p_file, const HashMap<StringName, Variant> &p_custom_options, const String &p_custom_importer, Variant p_generator_parameters) {