From d7a263afee91031f18394f6c3d0974542807f544 Mon Sep 17 00:00:00 2001 From: Nicole Rappe Date: Sun, 26 Oct 2025 03:41:53 -0600 Subject: [PATCH] Fix Engine web UI staging root detection --- Data/Engine/bootstrapper.py | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/Data/Engine/bootstrapper.py b/Data/Engine/bootstrapper.py index a833fee..b62e105 100644 --- a/Data/Engine/bootstrapper.py +++ b/Data/Engine/bootstrapper.py @@ -22,7 +22,25 @@ DEFAULT_PORT = 5001 def _project_root() -> Path: - return Path(__file__).resolve().parents[2] + """Locate the repository root regardless of runtime staging depth.""" + + current = Path(__file__).resolve().parent + + # Prefer an explicit sentinel (Borealis.ps1) so running from the staged + # Engine runtime still discovers the true project root one level higher. + for candidate in (current, *current.parents): + if (candidate / "Borealis.ps1").is_file(): + return candidate + + # Fallback: if we're inside ``/Engine/Data/Engine`` the parent of the + # ``Engine`` directory is the project root. + for candidate in current.parents: + if candidate.name.lower() == "engine" and (candidate.parent / "Borealis.ps1").is_file(): + return candidate.parent + + # Last resort mirrors the previous behaviour (two levels up) so we don't + # regress in unforeseen layouts. + return current.parents[1] def _build_runtime_config() -> Dict[str, Any]: