diff options
author | bruvzg <7645683+bruvzg@users.noreply.github.com> | 2023-02-16 13:43:32 +0200 |
---|---|---|
committer | bruvzg <7645683+bruvzg@users.noreply.github.com> | 2023-02-17 09:55:56 +0200 |
commit | 174e0837e0826179a2e51e581aa895cb5cc90885 (patch) | |
tree | 4d38fbcb233e6fcabed426e0ec45ab60c6d4c93e /editor/editor_paths.cpp | |
parent | c7aadab155a6e3d3d5445465f3d6eda18a31d2e4 (diff) | |
download | redot-engine-174e0837e0826179a2e51e581aa895cb5cc90885.tar.gz |
[macOS] Re-add support for the _sc_ inside app bundle. Update docs.
Diffstat (limited to 'editor/editor_paths.cpp')
-rw-r--r-- | editor/editor_paths.cpp | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/editor/editor_paths.cpp b/editor/editor_paths.cpp index 36ebeb8c33..b707839715 100644 --- a/editor/editor_paths.cpp +++ b/editor/editor_paths.cpp @@ -117,14 +117,20 @@ EditorPaths::EditorPaths() { // Self-contained mode if a `._sc_` or `_sc_` file is present in executable dir. String exe_path = OS::get_singleton()->get_executable_path().get_base_dir(); + Ref<DirAccess> d = DirAccess::create_for_path(exe_path); + if (d->file_exists(exe_path + "/._sc_")) { + self_contained = true; + self_contained_file = exe_path + "/._sc_"; + } else if (d->file_exists(exe_path + "/_sc_")) { + self_contained = true; + self_contained_file = exe_path + "/_sc_"; + } // On macOS, look outside .app bundle, since .app bundle is read-only. + // Note: This will not work if Gatekeeper path randomization is active. if (OS::get_singleton()->has_feature("macos") && exe_path.ends_with("MacOS") && exe_path.path_join("..").simplify_path().ends_with("Contents")) { exe_path = exe_path.path_join("../../..").simplify_path(); - } - { - Ref<DirAccess> d = DirAccess::create_for_path(exe_path); - + d = DirAccess::create_for_path(exe_path); if (d->file_exists(exe_path + "/._sc_")) { self_contained = true; self_contained_file = exe_path + "/._sc_"; |