Skip to content

Commit

Permalink
fix JuliaLang#44153, limit input types of reflection utilities (Julia…
Browse files Browse the repository at this point in the history
…Lang#44155)

After JuliaLang#43113 Julia compiler can inline `@nospecialize ::AbstractType`
signature, so we can reintroduce the input type annotations.
Still I want to keep the current `::Any` signature for those utility
functions heavily in `Core.Compiler` (e.g. `isbitstype`) because `isa(t, Type)`
check inserted by the inliner otherwise might involve some cost.
But I agree that the other non-performance sensitive functions like `which`
is better to have input type restrictions.
  • Loading branch information
aviatesk authored and antoine-levitt committed Feb 17, 2022
1 parent dcdb36e commit 3de59e7
Showing 1 changed file with 4 additions and 4 deletions.
8 changes: 4 additions & 4 deletions base/reflection.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1230,7 +1230,7 @@ end
Similar to [`code_typed`](@ref), except the argument is a tuple type describing
a full signature to query.
"""
function code_typed_by_type(@nospecialize(tt#=::Type=#);
function code_typed_by_type(@nospecialize(tt::Type);
optimize=true,
debuginfo::Symbol=:default,
world = get_world_counter(),
Expand Down Expand Up @@ -1301,7 +1301,7 @@ function print_statement_costs(io::IO, @nospecialize(f), @nospecialize(t); kwarg
print_statement_costs(io, tt; kwargs...)
end

function print_statement_costs(io::IO, @nospecialize(tt#=::Type=#);
function print_statement_costs(io::IO, @nospecialize(tt::Type);
world = get_world_counter(),
interp = Core.Compiler.NativeInterpreter(world))
matches = _methods_by_ftype(tt, -1, world)::Vector
Expand Down Expand Up @@ -1329,9 +1329,9 @@ function print_statement_costs(io::IO, @nospecialize(tt#=::Type=#);
end
end

print_statement_costs(args...; kwargs...) = print_statement_costs(stdout, args...; kwargs...)
print_statement_costs(args...; kwargs...) = print_statement_costs(stdout::IO, args...; kwargs...)

function _which(@nospecialize(tt#=::Type=#), world=get_world_counter())
function _which(@nospecialize(tt::Type), world=get_world_counter())
min_valid = RefValue{UInt}(typemin(UInt))
max_valid = RefValue{UInt}(typemax(UInt))
match = ccall(:jl_gf_invoke_lookup_worlds, Any,
Expand Down

0 comments on commit 3de59e7

Please sign in to comment.