From c2ed90348a85c86e26b113251332f946ba6810a6 Mon Sep 17 00:00:00 2001 From: Ian Butterworth Date: Sat, 9 Oct 2021 12:35:18 -0400 Subject: [PATCH] add option to allow stale_cachefile to ignore loaded modules (#42545) (cherry picked from commit bbe93759d5e3730f4e8b55fc5249b8252917c8c6) --- base/loading.jl | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/base/loading.jl b/base/loading.jl index a6145398946b8..76b4cc1c7ef39 100644 --- a/base/loading.jl +++ b/base/loading.jl @@ -1712,7 +1712,7 @@ get_compiletime_preferences(::Nothing) = String[] # returns true if it "cachefile.ji" is stale relative to "modpath.jl" # otherwise returns the list of dependencies to also check -function stale_cachefile(modpath::String, cachefile::String) +function stale_cachefile(modpath::String, cachefile::String; ignore_loaded = false) io = open(cachefile, "r") try if !isvalid_cache_header(io) @@ -1733,11 +1733,15 @@ function stale_cachefile(modpath::String, cachefile::String) M = root_module(req_key) if PkgId(M) == req_key && module_build_id(M) === req_build_id depmods[i] = M + elseif ignore_loaded + # Used by Pkg.precompile given that there it's ok to precompile different versions of loaded packages + @goto locate_branch else @debug "Rejecting cache file $cachefile because module $req_key is already loaded and incompatible." return true # Won't be able to fulfill dependency end else + @label locate_branch path = locate_package(req_key) get!(PkgOrigin, pkgorigins, req_key).path = path if path === nothing