Commit 8d817fc0 authored by will-ca's avatar will-ca Committed by GitHub

Prevent generating code hash twice for `cython.inline()`. (GH-3495)

parent 34714637
...@@ -160,6 +160,8 @@ def cython_inline(code, get_type=unsafe_type, ...@@ -160,6 +160,8 @@ def cython_inline(code, get_type=unsafe_type,
if language_level is not None: if language_level is not None:
cython_compiler_directives['language_level'] = language_level cython_compiler_directives['language_level'] = language_level
key_hash = None
# Fast path if this has been called in this session. # Fast path if this has been called in this session.
_unbound_symbols = _cython_inline_cache.get(code) _unbound_symbols = _cython_inline_cache.get(code)
if _unbound_symbols is not None: if _unbound_symbols is not None:
...@@ -195,7 +197,8 @@ def cython_inline(code, get_type=unsafe_type, ...@@ -195,7 +197,8 @@ def cython_inline(code, get_type=unsafe_type,
del kwds[name] del kwds[name]
arg_names = sorted(kwds) arg_names = sorted(kwds)
arg_sigs = tuple([(get_type(kwds[arg], ctx), arg) for arg in arg_names]) arg_sigs = tuple([(get_type(kwds[arg], ctx), arg) for arg in arg_names])
key_hash = _inline_key(orig_code, arg_sigs, language_level) if key_hash is None:
key_hash = _inline_key(orig_code, arg_sigs, language_level)
module_name = "_cython_inline_" + key_hash module_name = "_cython_inline_" + key_hash
if module_name in sys.modules: if module_name in sys.modules:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment