Skip to content

Commit

Permalink
also set the version in pkgorigins
Browse files Browse the repository at this point in the history
  • Loading branch information
KristofferC committed Feb 23, 2022
1 parent 629eb86 commit b7d88d6
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 13 deletions.
40 changes: 28 additions & 12 deletions base/loading.jl
Original file line number Diff line number Diff line change
Expand Up @@ -411,6 +411,16 @@ const project_names = ("JuliaProject.toml", "Project.toml")
const manifest_names = ("JuliaManifest.toml", "Manifest.toml")
const preferences_names = ("JuliaLocalPreferences.toml", "LocalPreferences.toml")

function locate_project_file(env::String)
for proj in project_names
project_file = joinpath(env, proj)
if isfile_casesensitive(project_file)
return project_file
end
end
return true
end

# classify the LOAD_PATH entry to be one of:
# - `false`: nonexistant / nothing to see here
# - `true`: `env` is an implicit environment
Expand All @@ -423,14 +433,7 @@ function env_project_file(env::String)::Union{Bool,String}
project_file === nothing || return project_file
end
if isdir(env)
for proj in project_names
maybe_project_file = joinpath(env, proj)
if isfile_casesensitive(maybe_project_file)
project_file = maybe_project_file
break
end
end
project_file =true
project_file = locate_project_file(env)
elseif basename(env) in project_names && isfile_casesensitive(env)
project_file = env
else
Expand Down Expand Up @@ -1069,11 +1072,11 @@ function require(into::Module, mod::Symbol)
end

mutable struct PkgOrigin
# version::VersionNumber
path::Union{String,Nothing}
cachepath::Union{String,Nothing}
version::Union{VersionNumber,Nothing}
end
PkgOrigin() = PkgOrigin(nothing, nothing)
PkgOrigin() = PkgOrigin(nothing, nothing, nothing)
const pkgorigins = Dict{PkgId,PkgOrigin}()

require(uuidkey::PkgId) = @lock require_lock _require_prelocked(uuidkey)
Expand Down Expand Up @@ -1147,6 +1150,19 @@ function unreference_module(key::PkgId)
end
end

function set_pkgorigin_version_path(pkg, path)
pkgorigin = get!(PkgOrigin, pkgorigins, pkg)
project_file = locate_project_file(joinpath(dirname(path), ".."))
if project_file isa String
d = parsed_toml(project_file)
v = get(d, "version", nothing)
if v !== nothing
pkgorigin.version = VersionNumber(v)
end
end
pkgorigin.path = path
end

# Returns `nothing` or the name of the newly-created cachefile
function _require(pkg::PkgId)
# handle recursive calls to require
Expand All @@ -1163,7 +1179,7 @@ function _require(pkg::PkgId)
toplevel_load[] = false
# perform the search operation to select the module file require intends to load
path = locate_package(pkg)
get!(PkgOrigin, pkgorigins, pkg).path = path
set_pkgorigin_version_path(pkg, path)
if path === nothing
throw(ArgumentError("""
Package $pkg is required but does not seem to be installed:
Expand Down Expand Up @@ -1930,7 +1946,7 @@ get_compiletime_preferences(::Nothing) = String[]
else
@label locate_branch
path = locate_package(req_key)
get!(PkgOrigin, pkgorigins, req_key).path = path
set_pkgorigin_version_path(req_key, path)
if path === nothing
@debug "Rejecting cache file $cachefile because dependency $req_key not found."
return true # Won't be able to fulfill dependency
Expand Down
2 changes: 1 addition & 1 deletion test/TestPkg/Project.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
name = "TestPkg"
uuid = "69145d58-7df6-11e8-0660-cf7622583916"

version = "1.2.3"

[deps]
Random = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c"
1 change: 1 addition & 0 deletions test/loading.jl
Original file line number Diff line number Diff line change
Expand Up @@ -651,6 +651,7 @@ finally
Base.set_active_project(old_act_proj)
popfirst!(LOAD_PATH)
end
@test Base.pkgorigins[Base.PkgId(UUID("69145d58-7df6-11e8-0660-cf7622583916"), "TestPkg")].version == v"1.2.3"

@testset "--project and JULIA_PROJECT paths should be absolutified" begin
mktempdir() do dir; cd(dir) do
Expand Down

0 comments on commit b7d88d6

Please sign in to comment.