summaryrefslogtreecommitdiffstats
path: root/editor/editor_file_system.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-08-28 00:11:16 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-08-28 00:11:16 +0200
commit7c02e067cc26d9f6f411ceb42a8cf6b4b44f89d8 (patch)
tree9eae3469bed9b80493efcb6e86fbf98cb944ed3c /editor/editor_file_system.cpp
parentb523add340ecabaceb7b71479f0195d0ebcc40b0 (diff)
parent5a3c7b41d8ca61524431c0b743ced942f6df704d (diff)
downloadredot-engine-7c02e067cc26d9f6f411ceb42a8cf6b4b44f89d8.tar.gz
Merge pull request #93611 from KoBeWi/path_rush
Optimize `get_path()` in EditorFileSystemDirectory
Diffstat (limited to 'editor/editor_file_system.cpp')
-rw-r--r--editor/editor_file_system.cpp38
1 files changed, 24 insertions, 14 deletions
diff --git a/editor/editor_file_system.cpp b/editor/editor_file_system.cpp
index 22ff7a4509..bcfc29f7a3 100644
--- a/editor/editor_file_system.cpp
+++ b/editor/editor_file_system.cpp
@@ -95,25 +95,35 @@ String EditorFileSystemDirectory::get_file(int p_idx) const {
}
String EditorFileSystemDirectory::get_path() const {
- String p;
- const EditorFileSystemDirectory *d = this;
- while (d->parent) {
- p = d->name.path_join(p);
- d = d->parent;
+ int parents = 0;
+ const EditorFileSystemDirectory *efd = this;
+ // Determine the level of nesting.
+ while (efd->parent) {
+ parents++;
+ efd = efd->parent;
}
- return "res://" + p;
-}
+ if (parents == 0) {
+ return "res://";
+ }
-String EditorFileSystemDirectory::get_file_path(int p_idx) const {
- String file = get_file(p_idx);
- const EditorFileSystemDirectory *d = this;
- while (d->parent) {
- file = d->name.path_join(file);
- d = d->parent;
+ // Using PackedStringArray, because the path is built in reverse order.
+ PackedStringArray path_bits;
+ // Allocate an array based on nesting. It will store path bits.
+ path_bits.resize(parents + 2); // Last String is empty, so paths end with /.
+ String *path_write = path_bits.ptrw();
+ path_write[0] = "res:/";
+
+ efd = this;
+ for (int i = parents; i > 0; i--) {
+ path_write[i] = efd->name;
+ efd = efd->parent;
}
+ return String("/").join(path_bits);
+}
- return "res://" + file;
+String EditorFileSystemDirectory::get_file_path(int p_idx) const {
+ return get_path().path_join(get_file(p_idx));
}
Vector<String> EditorFileSystemDirectory::get_file_deps(int p_idx) const {