Skip to content

Commit

Permalink
limit exponent on number of calls made by _methods for unions
Browse files Browse the repository at this point in the history
  • Loading branch information
JeffBezanson committed Feb 25, 2016
1 parent e83862f commit ee0c3ed
Showing 1 changed file with 5 additions and 1 deletion.
6 changes: 5 additions & 1 deletion base/reflection.jl
Original file line number Diff line number Diff line change
Expand Up @@ -188,11 +188,15 @@ function _methods(f::ANY,t::ANY,lim)
end
function _methods_by_ftype(t::ANY, lim)
tp = t.parameters
nunions = 0
for ti in tp
if isa(ti, Union)
return _methods(Any[tp...], length(tp), lim, [])
nunions += 1

This comment has been minimized.

Copy link
@vtjnash

vtjnash Feb 25, 2016

Member

this should probably be nunions *= length(ti.types)

end
end
if 1 <= nunions <= 6
return _methods(Any[tp...], length(tp), lim, [])
end
return ccall(:jl_matching_methods, Any, (Any,Int32), t, lim)
end
function _methods(t::Array,i,lim::Integer,matching::Array{Any,1})
Expand Down

4 comments on commit ee0c3ed

@Keno
Copy link
Member

@Keno Keno commented on ee0c3ed Feb 25, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

+1 @vtjnash and I were looking at something very similar.

@vtjnash
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Keno can you push yours to a PR also, these two changes should be very complimentary

@Keno
Copy link
Member

@Keno Keno commented on ee0c3ed Feb 25, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The inference.jl change as well or was that just a temporary hack?

@vtjnash
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

both. i ended up just pushing the commit myself 26d7bb8

i found that this breaks a few tests, however, since it can also be too pessimistic in certain cases (and thus potentially break static_typeof).

Please sign in to comment.