From d7d49fd60dbf1a1eef6f2c73ddd7707f2931d2af Mon Sep 17 00:00:00 2001 From: Tim Holy Date: Sun, 3 Mar 2019 05:29:15 -0600 Subject: [PATCH] Handle case where find_source_file fails --- src/CodeTracking.jl | 9 ++++++--- test/runtests.jl | 6 ++++++ 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/src/CodeTracking.jl b/src/CodeTracking.jl index 6e94a4c..2730744 100644 --- a/src/CodeTracking.jl +++ b/src/CodeTracking.jl @@ -35,10 +35,13 @@ function whereis(method::Method) file, line = fileline(lin[1]) end if !isabspath(file) - # This is a Base or Core method - file = Base.find_source_file(file) + # This may be a Base or Core method + newfile = Base.find_source_file(file) + if isa(newfile, AbstractString) + file = normpath(newfile) + end end - return normpath(file), line + return file, line end """ diff --git a/test/runtests.jl b/test/runtests.jl index 10a3b43..11fb78b 100644 --- a/test/runtests.jl +++ b/test/runtests.jl @@ -42,4 +42,10 @@ include("script.jl") @test pkgfiles("ColorTypes") === nothing @test_throws ErrorException pkgfiles("NotAPkg") + + # Test that definitions at the REPL work with `whereis` + ex = Base.parse_input_line("replfunc(x) = 1"; filename="REPL[1]") + eval(ex) + m = first(methods(replfunc)) + @test whereis(m) == ("REPL[1]", 1) end