Skip to content

Commit

Permalink
stale_cachefile: handle if the expected cache file is missing (#55419)
Browse files Browse the repository at this point in the history
Part of fixing JuliaLang/Pkg.jl#3984
  • Loading branch information
IanButterworth committed Aug 9, 2024
1 parent fd6d9e0 commit 3a4ccaa
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 1 deletion.
8 changes: 7 additions & 1 deletion base/loading.jl
Original file line number Diff line number Diff line change
Expand Up @@ -3005,7 +3005,13 @@ end
return stale_cachefile(PkgId(""), UInt128(0), modpath, cachefile; ignore_loaded)
end
@constprop :none function stale_cachefile(modkey::PkgId, build_id::UInt128, modpath::String, cachefile::String; ignore_loaded::Bool = false)
io = open(cachefile, "r")
io = try
open(cachefile, "r")
catch ex
ex isa IOError || ex isa SystemError || rethrow()
@debug "Rejecting cache file $cachefile for $modkey because it could not be opened" isfile(cachefile)
return true
end
try
checksum = isvalid_cache_header(io)
if iszero(checksum)
Expand Down
4 changes: 4 additions & 0 deletions test/precompile.jl
Original file line number Diff line number Diff line change
Expand Up @@ -522,6 +522,10 @@ precompile_test_harness(false) do dir
@eval using Baz
@test Base.invokelatest(Baz.baz) == 1

# should not throw if the cachefile does not exist
@test !isfile("DoesNotExist.ji")
@test Base.stale_cachefile("", "DoesNotExist.ji") === true

# Issue #12720
FooBar1_file = joinpath(dir, "FooBar1.jl")
write(FooBar1_file,
Expand Down

0 comments on commit 3a4ccaa

Please sign in to comment.