Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cython
Commits
f599da79
Commit
f599da79
authored
Jul 17, 2015
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
make 'object' predictably the last fallback option for fused typed arguments
parent
9e9b474a
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
45 additions
and
39 deletions
+45
-39
CHANGES.rst
CHANGES.rst
+4
-0
Cython/Compiler/FusedNode.py
Cython/Compiler/FusedNode.py
+41
-39
No files found.
CHANGES.rst
View file @
f599da79
...
@@ -78,6 +78,10 @@ Bugs fixed
...
@@ -78,6 +78,10 @@ Bugs fixed
* Language level 3 did not enable true division (a.k.a. float division)
* Language level 3 did not enable true division (a.k.a. float division)
for integer operands.
for integer operands.
* Functions with fused argument types that included a generic 'object'
fallback could end up using that fallback also for other explicitly
listed object types.
* Relative cimports could accidentally fall back to trying an absolute
* Relative cimports could accidentally fall back to trying an absolute
cimport on failure.
cimport on failure.
...
...
Cython/Compiler/FusedNode.py
View file @
f599da79
...
@@ -268,8 +268,8 @@ class FusedCFuncDefNode(StatListNode):
...
@@ -268,8 +268,8 @@ class FusedCFuncDefNode(StatListNode):
)
)
pyx_code
.
put_chunk
(
pyx_code
.
put_chunk
(
u"""
u"""
el
if isinstance(arg, {{py_type_name}}):
if isinstance(arg, {{py_type_name}}):
dest_sig[{{dest_sig_idx}}] = '{{specialized_type_name}}'
dest_sig[{{dest_sig_idx}}] = '{{specialized_type_name}}'
; break
"""
)
"""
)
def
_dtype_name
(
self
,
dtype
):
def
_dtype_name
(
self
,
dtype
):
...
@@ -394,39 +394,34 @@ class FusedCFuncDefNode(StatListNode):
...
@@ -394,39 +394,34 @@ class FusedCFuncDefNode(StatListNode):
to match the format string.
to match the format string.
"""
"""
# The first thing to find a match in this loop breaks out of the loop
# The first thing to find a match in this loop breaks out of the loop
if
pyx_code
.
indenter
(
u"while 1:"
):
pyx_code
.
put_chunk
(
pyx_code
.
put_chunk
(
u"""
u"""
if ndarray is not None:
if ndarray is not None:
if isinstance(arg, ndarray):
if isinstance(arg, ndarray):
dtype = arg.dtype
dtype = arg.dtype
elif __pyx_memoryview_check(arg):
elif __pyx_memoryview_check(arg):
arg_base = arg.base
arg_base = arg.base
if isinstance(arg_base, ndarray):
if isinstance(arg_base, ndarray):
dtype = arg_base.dtype
dtype = arg_base.dtype
else:
dtype = None
else:
else:
dtype = None
dtype = None
else:
dtype = None
itemsize = -1
itemsize = -1
if dtype is not None:
if dtype is not None:
itemsize = dtype.itemsize
itemsize = dtype.itemsize
kind = ord(dtype.kind)
kind = ord(dtype.kind)
dtype_signed = kind == 'i'
dtype_signed = kind == 'i'
"""
)
"""
)
pyx_code
.
indent
(
2
)
pyx_code
.
indent
(
2
)
pyx_code
.
named_insertion_point
(
"numpy_dtype_checks"
)
pyx_code
.
named_insertion_point
(
"numpy_dtype_checks"
)
self
.
_buffer_check_numpy_dtype
(
pyx_code
,
buffer_types
)
self
.
_buffer_check_numpy_dtype
(
pyx_code
,
buffer_types
)
pyx_code
.
dedent
(
2
)
pyx_code
.
dedent
(
2
)
for
specialized_type
in
buffer_types
:
self
.
_buffer_parse_format_string_check
(
pyx_code
,
decl_code
,
specialized_type
,
env
)
pyx_code
.
putln
(
self
.
no_match
)
for
specialized_type
in
buffer_types
:
pyx_code
.
putln
(
"break"
)
self
.
_buffer_parse_format_string_check
(
pyx_code
.
dedent
(
)
pyx_code
,
decl_code
,
specialized_type
,
env
)
def
_buffer_declarations
(
self
,
pyx_code
,
decl_code
,
all_buffer_types
):
def
_buffer_declarations
(
self
,
pyx_code
,
decl_code
,
all_buffer_types
):
"""
"""
...
@@ -492,17 +487,21 @@ class FusedCFuncDefNode(StatListNode):
...
@@ -492,17 +487,21 @@ class FusedCFuncDefNode(StatListNode):
# specialized_types.sort()
# specialized_types.sort()
seen_py_type_names
=
set
()
seen_py_type_names
=
set
()
normal_types
,
buffer_types
=
[],
[]
normal_types
,
buffer_types
=
[],
[]
has_object_fallback
=
False
for
specialized_type
in
specialized_types
:
for
specialized_type
in
specialized_types
:
py_type_name
=
specialized_type
.
py_type_name
()
py_type_name
=
specialized_type
.
py_type_name
()
if
py_type_name
:
if
py_type_name
:
if
py_type_name
in
seen_py_type_names
:
if
py_type_name
in
seen_py_type_names
:
continue
continue
seen_py_type_names
.
add
(
py_type_name
)
seen_py_type_names
.
add
(
py_type_name
)
normal_types
.
append
(
specialized_type
)
if
py_type_name
==
'object'
:
has_object_fallback
=
True
else
:
normal_types
.
append
(
specialized_type
)
elif
specialized_type
.
is_buffer
or
specialized_type
.
is_memoryviewslice
:
elif
specialized_type
.
is_buffer
or
specialized_type
.
is_memoryviewslice
:
buffer_types
.
append
(
specialized_type
)
buffer_types
.
append
(
specialized_type
)
return
normal_types
,
buffer_types
return
normal_types
,
buffer_types
,
has_object_fallback
def
_unpack_argument
(
self
,
pyx_code
):
def
_unpack_argument
(
self
,
pyx_code
):
pyx_code
.
put_chunk
(
pyx_code
.
put_chunk
(
...
@@ -593,18 +592,21 @@ class FusedCFuncDefNode(StatListNode):
...
@@ -593,18 +592,21 @@ class FusedCFuncDefNode(StatListNode):
default_idx
=
default_idx
,
default_idx
=
default_idx
,
)
)
normal_types
,
buffer_types
=
self
.
_split_fused_types
(
arg
)
normal_types
,
buffer_types
,
has_object_fallback
=
self
.
_split_fused_types
(
arg
)
self
.
_unpack_argument
(
pyx_code
)
self
.
_unpack_argument
(
pyx_code
)
# we need an 'if' to allow the following elif/else branches
# 'unrolled' loop, first match breaks out of it
pyx_code
.
putln
(
"if 0: pass"
)
if
pyx_code
.
indenter
(
"while 1:"
):
if
normal_types
:
if
normal_types
:
self
.
_fused_instance_checks
(
normal_types
,
pyx_code
,
env
)
self
.
_fused_instance_checks
(
normal_types
,
pyx_code
,
env
)
if
pyx_code
.
indenter
(
"else:"
):
if
buffer_types
:
if
buffer_types
:
self
.
_buffer_checks
(
buffer_types
,
pyx_code
,
decl_code
,
env
)
self
.
_buffer_checks
(
buffer_types
,
pyx_code
,
decl_code
,
env
)
if
has_object_fallback
:
pyx_code
.
context
.
update
(
specialized_type_name
=
'object'
)
pyx_code
.
putln
(
self
.
match
)
else
:
else
:
pyx_code
.
putln
(
self
.
no_match
)
pyx_code
.
putln
(
self
.
no_match
)
pyx_code
.
putln
(
"break"
)
pyx_code
.
dedent
()
pyx_code
.
dedent
()
fused_index
+=
1
fused_index
+=
1
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment