From e357f5b4b968e1d8f1bb67f860ebe18724aace5d Mon Sep 17 00:00:00 2001 From: Frames White Date: Fri, 16 Feb 2024 14:12:05 +0800 Subject: [PATCH] Rename at-scriptdir project argument to at-script and search upwards from at-script --- HISTORY.md | 1 + base/initdefs.jl | 9 +++++++-- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/HISTORY.md b/HISTORY.md index 8d876766c0aab..d7ab58c657f5d 100644 --- a/HISTORY.md +++ b/HISTORY.md @@ -68,6 +68,7 @@ difference between defining a `main` function and executing the code directly at * The `--compiled-modules` and `--pkgimages` flags can now be set to `existing`, which will cause Julia to consider loading existing cache files, but not to create new ones ([#50586] and [#52573]). +* The `--project` argument now accepts `@script` to give a path to a directory with a Project.toml relative to the passed script file. `--project=@script/foo` for the `foo` subdirectory. If no path is given after (i.e. `--project=@script`) then (like `--project=@.`) the directory and its parents are searched for a Project.toml ([#50864] and [#53352]) Multi-threading changes ----------------------- diff --git a/base/initdefs.jl b/base/initdefs.jl index 60fbaded1b282..2f5dcaf3bd870 100644 --- a/base/initdefs.jl +++ b/base/initdefs.jl @@ -278,7 +278,7 @@ function load_path_expand(env::AbstractString)::Union{String, Nothing} env == "@" && return active_project(false) env == "@." && return current_project() env == "@stdlib" && return Sys.STDLIB - if startswith(env, "@scriptdir") + if startswith(env, "@script") if @isdefined(PROGRAM_FILE) dir = dirname(PROGRAM_FILE) else @@ -289,7 +289,12 @@ function load_path_expand(env::AbstractString)::Union{String, Nothing} end dir = dirname(ARGS[1]) end - return abspath(replace(env, "@scriptdir" => dir)) + if env == "@script" # complete match, not startswith, so search upwards + return current_project(dir) + else + # starts with, so assume relative path is after + return abspath(replace(env, "@script" => dir)) + end end env = replace(env, '#' => VERSION.major, count=1) env = replace(env, '#' => VERSION.minor, count=1)