diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-08-28 00:11:16 +0200 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-08-28 00:11:16 +0200 |
commit | 7c02e067cc26d9f6f411ceb42a8cf6b4b44f89d8 (patch) | |
tree | 9eae3469bed9b80493efcb6e86fbf98cb944ed3c /editor/editor_file_system.cpp | |
parent | b523add340ecabaceb7b71479f0195d0ebcc40b0 (diff) | |
parent | 5a3c7b41d8ca61524431c0b743ced942f6df704d (diff) | |
download | redot-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.cpp | 38 |
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 { |