Skip to content

Commit

Permalink
tidier code & don't check modules if no hooks available
Browse files Browse the repository at this point in the history
  • Loading branch information
IanButterworth committed Apr 25, 2021
1 parent ba8e166 commit e70611a
Showing 1 changed file with 14 additions and 14 deletions.
28 changes: 14 additions & 14 deletions stdlib/REPL/src/REPL.jl
Original file line number Diff line number Diff line change
Expand Up @@ -782,20 +782,30 @@ backend(r::AbstractREPL) = r.backendref
const install_packages_hooks = Any[]

function eval_with_backend(ast, backend::REPLBackendRef)
mods_to_be_loaded = modules_to_be_loaded(ast)
mods_not_found = list_unfindable_modules(mods_to_be_loaded)
!isempty(mods_not_found) && pass_to_install_package_hooks(mods_not_found)
if !isempty(install_packages_hooks)
check_for_missing_packages_and_run_hooks(ast)
end
put!(backend.repl_channel, (ast, 1))
resp = take!(backend.response_channel) # (val, iserr)
return resp
end

function check_for_missing_packages_and_run_hooks(ast)
mods = modules_to_be_loaded(ast)
filter!(mod -> isnothing(Base.identify_package(String(mod))), mods) # keep non-findable modules
if !isempty(mods)
for f in install_packages_hooks
f(mods) && return
end
end
end

function modules_to_be_loaded(ast, mods = Symbol[])
if ast.head in [:using, :import]
for arg in ast.args
if first(arg.args) isa Symbol # i.e. `Foo`
push!(mods, first(arg.args))
else # i.e. `Foo: Bar`
else # i.e. `Foo: bar`
push!(mods, first(first(arg.args).args))
end
end
Expand All @@ -806,16 +816,6 @@ function modules_to_be_loaded(ast, mods = Symbol[])
return mods
end

function list_unfindable_modules(mods)
filter(mod -> isnothing(Base.identify_package(String(mod))), mods)
end

function pass_to_install_package_hooks(mods)
for f in install_packages_hooks
f(mods) && return
end
end

function respond(f, repl, main; pass_empty::Bool = false, suppress_on_semicolon::Bool = true)
return function do_respond(s::MIState, buf, ok::Bool)
if !ok
Expand Down

0 comments on commit e70611a

Please sign in to comment.