Skip to content

Commit

Permalink
Merge pull request #416 from ihnorton/fix343_invokelatest
Browse files Browse the repository at this point in the history
RFC: Use invokelatest in jl_Function_call
  • Loading branch information
Keno authored Jul 28, 2017
2 parents a223575 + df1d16c commit 70057b4
Showing 1 changed file with 24 additions and 6 deletions.
30 changes: 24 additions & 6 deletions src/callback.jl
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,31 @@ function jl_Function_call(self_::PyPtr, args_::PyPtr, kw_::PyPtr)
args = PyObject(args_) # don't need pyincref because of finally clause below
try
f = unsafe_pyjlwrap_to_objref(self_)::Function
if kw_ == C_NULL
ret = PyObject(f(convert(PyAny, args)...))
else
kw = PyDict{Symbol,PyAny}(pyincref(kw_))
kwargs = [ (k,v) for (k,v) in kw ]
ret = PyObject(f(convert(PyAny, args)...; kwargs...))

# on 0.6 we need to use invokelatest to get execution in newest world
@static if isdefined(Base, :invokelatest)
if kw_ == C_NULL
ret = PyObject(Base.invokelatest(f, convert(PyAny, args)...))
else
kw = PyDict{Symbol,PyAny}(pyincref(kw_))
kwargs = [ (k,v) for (k,v) in kw ]

# 0.6 `invokelatest` doesn't support kwargs, instead
# use a closure over kwargs. see:
# https://github.com/JuliaLang/julia/pull/22646
f_kw_closure() = f(convert(PyAny, args)...; kwargs...)
ret = PyObject(Core._apply_latest(f_kw_closure))
end
else # 0.5 support
if kw_ == C_NULL
ret = PyObject(f(convert(PyAny, args)...))
else
kw = PyDict{Symbol,PyAny}(pyincref(kw_))
kwargs = [ (k,v) for (k,v) in kw ]
ret = PyObject(f(convert(PyAny, args)...; kwargs...))
end
end

return pystealref!(ret)
catch e
pyraise(e)
Expand Down

0 comments on commit 70057b4

Please sign in to comment.