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,6 +197,7 @@ def cython_inline(code, get_type=unsafe_type, ...@@ -195,6 +197,7 @@ 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])
if key_hash is None:
key_hash = _inline_key(orig_code, arg_sigs, language_level) key_hash = _inline_key(orig_code, arg_sigs, language_level)
module_name = "_cython_inline_" + key_hash module_name = "_cython_inline_" + key_hash
......
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