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
Boxiang Sun
cython
Commits
d48da4fd
Commit
d48da4fd
authored
Dec 09, 2012
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
clean up some code
parent
b47fb4d0
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
111 additions
and
123 deletions
+111
-123
Cython/Compiler/Buffer.py
Cython/Compiler/Buffer.py
+11
-10
Cython/Compiler/ExprNodes.py
Cython/Compiler/ExprNodes.py
+49
-49
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+36
-45
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+15
-19
No files found.
Cython/Compiler/Buffer.py
View file @
d48da4fd
from
Visitor
import
CythonTransform
from
Cython.Compiler.Visitor
import
CythonTransform
from
ModuleNode
import
ModuleNode
from
Cython.Compiler.ModuleNode
import
ModuleNode
from
ExprNodes
import
*
from
Cython.Compiler.Errors
import
CompileError
from
Errors
import
CompileError
from
Cython.Compiler.UtilityCode
import
CythonUtilityCode
from
UtilityCode
import
CythonUtilityCode
from
Cython.Compiler.Code
import
UtilityCode
,
TempitaUtilityCode
from
Code
import
UtilityCode
,
TempitaUtilityCode
import
Interpreter
from
Cython.Compiler
import
Options
import
PyrexTypes
from
Cython.Compiler
import
Interpreter
import
Naming
from
Cython.Compiler
import
PyrexTypes
import
Symtab
from
Cython.Compiler
import
Naming
from
Cython.Compiler
import
Symtab
def
dedent
(
text
,
reindent
=
0
):
def
dedent
(
text
,
reindent
=
0
):
...
...
Cython/Compiler/ExprNodes.py
View file @
d48da4fd
...
@@ -31,7 +31,6 @@ from Builtin import list_type, tuple_type, set_type, dict_type, \
...
@@ -31,7 +31,6 @@ from Builtin import list_type, tuple_type, set_type, dict_type, \
unicode_type
,
str_type
,
bytes_type
,
type_type
unicode_type
,
str_type
,
bytes_type
,
type_type
import
Builtin
import
Builtin
import
Symtab
import
Symtab
import
Options
from
Cython
import
Utils
from
Cython
import
Utils
from
Annotate
import
AnnotationItem
from
Annotate
import
AnnotationItem
from
Cython.Compiler
import
Future
from
Cython.Compiler
import
Future
...
@@ -369,7 +368,7 @@ class ExprNode(Node):
...
@@ -369,7 +368,7 @@ class ExprNode(Node):
def
type_dependencies
(
self
,
env
):
def
type_dependencies
(
self
,
env
):
# Returns the list of entries whose types must be determined
# Returns the list of entries whose types must be determined
# before the type of self can be infered.
# before the type of self can be infer
r
ed.
if
hasattr
(
self
,
'type'
)
and
self
.
type
is
not
None
:
if
hasattr
(
self
,
'type'
)
and
self
.
type
is
not
None
:
return
()
return
()
return
sum
([
node
.
type_dependencies
(
env
)
for
node
in
self
.
subexpr_nodes
()],
())
return
sum
([
node
.
type_dependencies
(
env
)
for
node
in
self
.
subexpr_nodes
()],
())
...
@@ -609,8 +608,6 @@ class ExprNode(Node):
...
@@ -609,8 +608,6 @@ class ExprNode(Node):
#
#
src
=
self
src
=
self
src_type
=
self
.
type
src_type
=
self
.
type
src_is_py_type
=
src_type
.
is_pyobject
dst_is_py_type
=
dst_type
.
is_pyobject
if
self
.
check_for_coercion_error
(
dst_type
):
if
self
.
check_for_coercion_error
(
dst_type
):
return
self
return
self
...
@@ -944,7 +941,7 @@ class IntNode(ConstNode):
...
@@ -944,7 +941,7 @@ class IntNode(ConstNode):
suitable_type
=
PyrexTypes
.
widest_numeric_type
(
suitable_type
,
self
.
type
)
suitable_type
=
PyrexTypes
.
widest_numeric_type
(
suitable_type
,
self
.
type
)
else
:
else
:
# C literal or Python literal - split at 32bit boundary
# C literal or Python literal - split at 32bit boundary
if
self
.
constant_result
>=
-
2
**
31
and
self
.
constant_result
<
2
**
31
:
if
-
2
**
31
<=
self
.
constant_result
<
2
**
31
:
if
self
.
type
and
self
.
type
.
is_int
:
if
self
.
type
and
self
.
type
.
is_int
:
suitable_type
=
self
.
type
suitable_type
=
self
.
type
else
:
else
:
...
@@ -1175,7 +1172,7 @@ class UnicodeNode(PyConstNode):
...
@@ -1175,7 +1172,7 @@ class UnicodeNode(PyConstNode):
# (DC00-DFFF) is likely there, too. If we don't find it,
# (DC00-DFFF) is likely there, too. If we don't find it,
# any second code unit cannot make for a surrogate pair by
# any second code unit cannot make for a surrogate pair by
# itself.
# itself.
if
c
>=
0xD800
and
c
<=
0xDBFF
:
if
0xD800
<=
c
<=
0xDBFF
:
return
True
return
True
return
False
return
False
...
@@ -1685,7 +1682,7 @@ class NameNode(AtomicExprNode):
...
@@ -1685,7 +1682,7 @@ class NameNode(AtomicExprNode):
Naming
.
module_cname
,
Naming
.
module_cname
,
interned_cname
))
interned_cname
))
if
not
self
.
cf_is_null
:
if
not
self
.
cf_is_null
:
code
.
putln
(
"}"
)
;
code
.
putln
(
"}"
)
code
.
putln
(
code
.
error_goto_if_null
(
self
.
result
(),
self
.
pos
))
code
.
putln
(
code
.
error_goto_if_null
(
self
.
result
(),
self
.
pos
))
code
.
put_gotref
(
self
.
py_result
())
code
.
put_gotref
(
self
.
py_result
())
...
@@ -1920,7 +1917,7 @@ class ImportNode(ExprNode):
...
@@ -1920,7 +1917,7 @@ class ImportNode(ExprNode):
# __import__(module_name, globals(), None, name_list, level)
# __import__(module_name, globals(), None, name_list, level)
#
#
# module_name StringNode dotted name of module. Empty module
# module_name StringNode dotted name of module. Empty module
# name means importing the parent package acco
u
rding
# name means importing the parent package according
# to level
# to level
# name_list ListNode or None list of names to be imported
# name_list ListNode or None list of names to be imported
# level int relative import level:
# level int relative import level:
...
@@ -2227,7 +2224,7 @@ class NextNode(AtomicExprNode):
...
@@ -2227,7 +2224,7 @@ class NextNode(AtomicExprNode):
# iterator IteratorNode
# iterator IteratorNode
def
__init__
(
self
,
iterator
):
def
__init__
(
self
,
iterator
):
self
.
pos
=
iterator
.
pos
AtomicExprNode
.
__init__
(
self
,
iterator
.
pos
)
self
.
iterator
=
iterator
self
.
iterator
=
iterator
def
type_dependencies
(
self
,
env
):
def
type_dependencies
(
self
,
env
):
...
@@ -2378,8 +2375,7 @@ class RawCNameExprNode(ExprNode):
...
@@ -2378,8 +2375,7 @@ class RawCNameExprNode(ExprNode):
subexprs
=
[]
subexprs
=
[]
def
__init__
(
self
,
pos
,
type
=
None
,
cname
=
None
):
def
__init__
(
self
,
pos
,
type
=
None
,
cname
=
None
):
self
.
pos
=
pos
ExprNode
.
__init__
(
self
,
pos
,
type
=
type
)
self
.
type
=
type
if
cname
is
not
None
:
if
cname
is
not
None
:
self
.
cname
=
cname
self
.
cname
=
cname
...
@@ -2493,8 +2489,8 @@ class IndexNode(ExprNode):
...
@@ -2493,8 +2489,8 @@ class IndexNode(ExprNode):
# set by SingleAssignmentNode after analyse_types()
# set by SingleAssignmentNode after analyse_types()
is_memslice_scalar_assignment
=
False
is_memslice_scalar_assignment
=
False
def
__init__
(
self
,
pos
,
index
,
*
args
,
*
*
kw
):
def
__init__
(
self
,
pos
,
index
,
**
kw
):
ExprNode
.
__init__
(
self
,
pos
,
index
=
index
,
*
args
,
*
*
kw
)
ExprNode
.
__init__
(
self
,
pos
,
index
=
index
,
**
kw
)
self
.
_index
=
index
self
.
_index
=
index
def
calculate_constant_result
(
self
):
def
calculate_constant_result
(
self
):
...
@@ -2577,7 +2573,7 @@ class IndexNode(ExprNode):
...
@@ -2577,7 +2573,7 @@ class IndexNode(ExprNode):
return
base_type
return
base_type
elif
isinstance
(
self
.
base
,
BytesNode
):
elif
isinstance
(
self
.
base
,
BytesNode
):
#if env.global_scope().context.language_level >= 3:
#if env.global_scope().context.language_level >= 3:
# # infering 'char' can be made to work in Python 3 mode
# # infer
r
ing 'char' can be made to work in Python 3 mode
# return PyrexTypes.c_char_type
# return PyrexTypes.c_char_type
# Py2/3 return different types on indexing bytes objects
# Py2/3 return different types on indexing bytes objects
return
py_object_type
return
py_object_type
...
@@ -3272,10 +3268,8 @@ class IndexNode(ExprNode):
...
@@ -3272,10 +3268,8 @@ class IndexNode(ExprNode):
code
.
putln
(
"%s = %s;"
%
(
temp
,
index
.
result
()))
code
.
putln
(
"%s = %s;"
%
(
temp
,
index
.
result
()))
# Generate buffer access code using these temps
# Generate buffer access code using these temps
import
Buffer
,
MemoryView
import
Buffer
buffer_entry
=
self
.
buffer_entry
()
buffer_entry
=
self
.
buffer_entry
()
if
buffer_entry
.
type
.
is_buffer
:
if
buffer_entry
.
type
.
is_buffer
:
negative_indices
=
buffer_entry
.
type
.
negative_indices
negative_indices
=
buffer_entry
.
type
.
negative_indices
else
:
else
:
...
@@ -4226,12 +4220,10 @@ class InlinedDefNodeCallNode(CallNode):
...
@@ -4226,12 +4220,10 @@ class InlinedDefNodeCallNode(CallNode):
class
PythonCapiFunctionNode
(
ExprNode
):
class
PythonCapiFunctionNode
(
ExprNode
):
subexprs
=
[]
subexprs
=
[]
def
__init__
(
self
,
pos
,
py_name
,
cname
,
func_type
,
utility_code
=
None
):
def
__init__
(
self
,
pos
,
py_name
,
cname
,
func_type
,
utility_code
=
None
):
self
.
pos
=
pos
ExprNode
.
__init__
(
self
,
pos
,
name
=
py_name
,
cname
=
cname
,
self
.
name
=
py_name
type
=
func_type
,
utility_code
=
utility_code
)
self
.
cname
=
cname
self
.
type
=
func_type
self
.
utility_code
=
utility_code
def
analyse_types
(
self
,
env
):
def
analyse_types
(
self
,
env
):
pass
pass
...
@@ -4243,6 +4235,7 @@ class PythonCapiFunctionNode(ExprNode):
...
@@ -4243,6 +4235,7 @@ class PythonCapiFunctionNode(ExprNode):
def
calculate_result_code
(
self
):
def
calculate_result_code
(
self
):
return
self
.
cname
return
self
.
cname
class
PythonCapiCallNode
(
SimpleCallNode
):
class
PythonCapiCallNode
(
SimpleCallNode
):
# Python C-API Function call (only created in transforms)
# Python C-API Function call (only created in transforms)
...
@@ -4347,7 +4340,7 @@ class AsTupleNode(ExprNode):
...
@@ -4347,7 +4340,7 @@ class AsTupleNode(ExprNode):
subexprs
=
[
'arg'
]
subexprs
=
[
'arg'
]
def
calculate_constant_result
(
self
):
def
calculate_constant_result
(
self
):
self
.
constant_result
=
tuple
(
self
.
base
.
constant_result
)
self
.
constant_result
=
tuple
(
self
.
arg
.
constant_result
)
def
compile_time_value
(
self
,
denv
):
def
compile_time_value
(
self
,
denv
):
arg
=
self
.
arg
.
compile_time_value
(
denv
)
arg
=
self
.
arg
.
compile_time_value
(
denv
)
...
@@ -4604,7 +4597,6 @@ class AttributeNode(ExprNode):
...
@@ -4604,7 +4597,6 @@ class AttributeNode(ExprNode):
else
:
else
:
self
.
op
=
"."
self
.
op
=
"."
if
obj_type
.
has_attributes
:
if
obj_type
.
has_attributes
:
entry
=
None
if
obj_type
.
attributes_known
():
if
obj_type
.
attributes_known
():
if
(
obj_type
.
is_memoryviewslice
and
not
if
(
obj_type
.
is_memoryviewslice
and
not
obj_type
.
scope
.
lookup_here
(
self
.
attribute
)):
obj_type
.
scope
.
lookup_here
(
self
.
attribute
)):
...
@@ -4880,7 +4872,7 @@ class StarredTargetNode(ExprNode):
...
@@ -4880,7 +4872,7 @@ class StarredTargetNode(ExprNode):
is_temp
=
1
is_temp
=
1
def
__init__
(
self
,
pos
,
target
):
def
__init__
(
self
,
pos
,
target
):
self
.
pos
=
pos
ExprNode
.
__init__
(
self
,
pos
)
self
.
target
=
target
self
.
target
=
target
def
analyse_declarations
(
self
,
env
):
def
analyse_declarations
(
self
,
env
):
...
@@ -6324,7 +6316,7 @@ class ClassCellNode(ExprNode):
...
@@ -6324,7 +6316,7 @@ class ClassCellNode(ExprNode):
'if (!%s) { PyErr_SetString(PyExc_SystemError, '
'if (!%s) { PyErr_SetString(PyExc_SystemError, '
'"super(): empty __class__ cell"); %s }'
%
(
'"super(): empty __class__ cell"); %s }'
%
(
self
.
result
(),
self
.
result
(),
code
.
error_goto
(
self
.
pos
)))
;
code
.
error_goto
(
self
.
pos
)))
code
.
put_incref
(
self
.
result
(),
py_object_type
)
code
.
put_incref
(
self
.
result
(),
py_object_type
)
...
@@ -6613,9 +6605,10 @@ class InnerFunctionNode(PyCFunctionNode):
...
@@ -6613,9 +6605,10 @@ class InnerFunctionNode(PyCFunctionNode):
def
self_result_code
(
self
):
def
self_result_code
(
self
):
if
self
.
needs_self_code
:
if
self
.
needs_self_code
:
return
"((PyObject*)%s)"
%
(
Naming
.
cur_scope_cname
)
return
"((PyObject*)%s)"
%
Naming
.
cur_scope_cname
return
"NULL"
return
"NULL"
class
CodeObjectNode
(
ExprNode
):
class
CodeObjectNode
(
ExprNode
):
# Create a PyCodeObject for a CyFunction instance.
# Create a PyCodeObject for a CyFunction instance.
#
#
...
@@ -6864,7 +6857,7 @@ class YieldExprNode(ExprNode):
...
@@ -6864,7 +6857,7 @@ class YieldExprNode(ExprNode):
code
.
putln
(
"/* return from generator, yielding value */"
)
code
.
putln
(
"/* return from generator, yielding value */"
)
code
.
putln
(
"%s->resume_label = %d;"
%
(
code
.
putln
(
"%s->resume_label = %d;"
%
(
Naming
.
generator_cname
,
self
.
label_num
))
Naming
.
generator_cname
,
self
.
label_num
))
code
.
putln
(
"return %s;"
%
Naming
.
retval_cname
)
;
code
.
putln
(
"return %s;"
%
Naming
.
retval_cname
)
code
.
put_label
(
self
.
label_name
)
code
.
put_label
(
self
.
label_name
)
for
cname
,
save_cname
,
type
in
saved
:
for
cname
,
save_cname
,
type
in
saved
:
...
@@ -6974,7 +6967,7 @@ class PyClassLocalsExprNode(AtomicExprNode):
...
@@ -6974,7 +6967,7 @@ class PyClassLocalsExprNode(AtomicExprNode):
def
analyse_types
(
self
,
env
):
def
analyse_types
(
self
,
env
):
self
.
type
=
self
.
pyclass_dict
.
type
self
.
type
=
self
.
pyclass_dict
.
type
self
.
is_t
mep
=
0
self
.
is_t
emp
=
False
def
result
(
self
):
def
result
(
self
):
return
self
.
pyclass_dict
.
result
()
return
self
.
pyclass_dict
.
result
()
...
@@ -7195,7 +7188,7 @@ class UnaryMinusNode(UnopNode):
...
@@ -7195,7 +7188,7 @@ class UnaryMinusNode(UnopNode):
def
get_constant_c_result_code
(
self
):
def
get_constant_c_result_code
(
self
):
value
=
self
.
operand
.
get_constant_c_result_code
()
value
=
self
.
operand
.
get_constant_c_result_code
()
if
value
:
if
value
:
return
"(-%s)"
%
(
value
)
return
"(-%s)"
%
value
class
TildeNode
(
UnopNode
):
class
TildeNode
(
UnopNode
):
# unary '~' operator
# unary '~' operator
...
@@ -7512,7 +7505,8 @@ class CythonArrayNode(ExprNode):
...
@@ -7512,7 +7505,8 @@ class CythonArrayNode(ExprNode):
base_type
=
self
.
operand
.
type
base_type
=
self
.
operand
.
type
if
not
self
.
operand
.
type
.
is_ptr
and
not
self
.
operand
.
type
.
is_array
:
if
not
self
.
operand
.
type
.
is_ptr
and
not
self
.
operand
.
type
.
is_array
:
return
error
(
self
.
operand
.
pos
,
ERR_NOT_POINTER
)
error
(
self
.
operand
.
pos
,
ERR_NOT_POINTER
)
return
# Dimension sizes of C array
# Dimension sizes of C array
array_dimension_sizes
=
[]
array_dimension_sizes
=
[]
...
@@ -7523,21 +7517,25 @@ class CythonArrayNode(ExprNode):
...
@@ -7523,21 +7517,25 @@ class CythonArrayNode(ExprNode):
elif
base_type
.
is_ptr
:
elif
base_type
.
is_ptr
:
base_type
=
base_type
.
base_type
base_type
=
base_type
.
base_type
else
:
else
:
return
error
()
error
(
self
.
pos
,
"unexpected base type %s found"
%
base_type
)
return
if
not
(
base_type
.
same_as
(
array_dtype
)
or
base_type
.
is_void
):
if
not
(
base_type
.
same_as
(
array_dtype
)
or
base_type
.
is_void
):
return
error
(
self
.
operand
.
pos
,
ERR_BASE_TYPE
)
error
(
self
.
operand
.
pos
,
ERR_BASE_TYPE
)
return
elif
self
.
operand
.
type
.
is_array
and
len
(
array_dimension_sizes
)
!=
ndim
:
elif
self
.
operand
.
type
.
is_array
and
len
(
array_dimension_sizes
)
!=
ndim
:
return
error
(
self
.
operand
.
pos
,
error
(
self
.
operand
.
pos
,
"Expected %d dimensions, array has %d dimensions"
%
"Expected %d dimensions, array has %d dimensions"
%
(
ndim
,
len
(
array_dimension_sizes
)))
(
ndim
,
len
(
array_dimension_sizes
)))
return
# Verify the start, stop and step values
# Verify the start, stop and step values
# In case of a C array, use the size of C array in each dimension to
# In case of a C array, use the size of C array in each dimension to
# get an automatic cast
# get an automatic cast
for
axis_no
,
axis
in
enumerate
(
axes
):
for
axis_no
,
axis
in
enumerate
(
axes
):
if
not
axis
.
start
.
is_none
:
if
not
axis
.
start
.
is_none
:
return
error
(
axis
.
start
.
pos
,
ERR_START
)
error
(
axis
.
start
.
pos
,
ERR_START
)
return
if
axis
.
stop
.
is_none
:
if
axis
.
stop
.
is_none
:
if
array_dimension_sizes
:
if
array_dimension_sizes
:
...
@@ -7546,7 +7544,8 @@ class CythonArrayNode(ExprNode):
...
@@ -7546,7 +7544,8 @@ class CythonArrayNode(ExprNode):
constant_result
=
dimsize
,
constant_result
=
dimsize
,
type
=
PyrexTypes
.
c_int_type
)
type
=
PyrexTypes
.
c_int_type
)
else
:
else
:
return
error
(
axis
.
pos
,
ERR_NOT_STOP
)
error
(
axis
.
pos
,
ERR_NOT_STOP
)
return
axis
.
stop
.
analyse_types
(
env
)
axis
.
stop
.
analyse_types
(
env
)
shape
=
axis
.
stop
.
coerce_to
(
self
.
shape_type
,
env
)
shape
=
axis
.
stop
.
coerce_to
(
self
.
shape_type
,
env
)
...
@@ -7561,17 +7560,20 @@ class CythonArrayNode(ExprNode):
...
@@ -7561,17 +7560,20 @@ class CythonArrayNode(ExprNode):
axis
.
step
.
analyse_types
(
env
)
axis
.
step
.
analyse_types
(
env
)
if
(
not
axis
.
step
.
type
.
is_int
and
axis
.
step
.
is_literal
and
not
if
(
not
axis
.
step
.
type
.
is_int
and
axis
.
step
.
is_literal
and
not
axis
.
step
.
type
.
is_error
):
axis
.
step
.
type
.
is_error
):
return
error
(
axis
.
step
.
pos
,
"Expected an integer literal"
)
error
(
axis
.
step
.
pos
,
"Expected an integer literal"
)
return
if
axis
.
step
.
compile_time_value
(
env
)
!=
1
:
if
axis
.
step
.
compile_time_value
(
env
)
!=
1
:
return
error
(
axis
.
step
.
pos
,
ERR_STEPS
)
error
(
axis
.
step
.
pos
,
ERR_STEPS
)
return
if
axis_no
==
0
:
if
axis_no
==
0
:
self
.
mode
=
"fortran"
self
.
mode
=
"fortran"
elif
not
axis
.
step
.
is_none
and
not
first_or_last
:
elif
not
axis
.
step
.
is_none
and
not
first_or_last
:
# step provided in some other dimension
# step provided in some other dimension
return
error
(
axis
.
step
.
pos
,
ERR_STEPS
)
error
(
axis
.
step
.
pos
,
ERR_STEPS
)
return
if
not
self
.
operand
.
is_name
:
if
not
self
.
operand
.
is_name
:
self
.
operand
=
self
.
operand
.
coerce_to_temp
(
env
)
self
.
operand
=
self
.
operand
.
coerce_to_temp
(
env
)
...
@@ -7891,8 +7893,6 @@ class BinopNode(ExprNode):
...
@@ -7891,8 +7893,6 @@ class BinopNode(ExprNode):
or
self
.
operand2
.
type
.
is_cpp_class
)
or
self
.
operand2
.
type
.
is_cpp_class
)
def
analyse_cpp_operation
(
self
,
env
):
def
analyse_cpp_operation
(
self
,
env
):
type1
=
self
.
operand1
.
type
type2
=
self
.
operand2
.
type
entry
=
env
.
lookup_operator
(
self
.
operator
,
[
self
.
operand1
,
self
.
operand2
])
entry
=
env
.
lookup_operator
(
self
.
operator
,
[
self
.
operand1
,
self
.
operand2
])
if
not
entry
:
if
not
entry
:
self
.
type_error
()
self
.
type_error
()
...
@@ -8080,7 +8080,7 @@ class NumBinopNode(BinopNode):
...
@@ -8080,7 +8080,7 @@ class NumBinopNode(BinopNode):
super
(
NumBinopNode
,
self
).
generate_result_code
(
code
)
super
(
NumBinopNode
,
self
).
generate_result_code
(
code
)
if
self
.
overflow_check
:
if
self
.
overflow_check
:
self
.
overflow_bit
=
code
.
funcstate
.
allocate_temp
(
PyrexTypes
.
c_int_type
,
manage_ref
=
False
)
self
.
overflow_bit
=
code
.
funcstate
.
allocate_temp
(
PyrexTypes
.
c_int_type
,
manage_ref
=
False
)
code
.
putln
(
"%s = 0;"
%
self
.
overflow_bit
)
;
code
.
putln
(
"%s = 0;"
%
self
.
overflow_bit
)
code
.
putln
(
"%s = %s;"
%
(
self
.
result
(),
self
.
calculate_result_code
()))
code
.
putln
(
"%s = %s;"
%
(
self
.
result
(),
self
.
calculate_result_code
()))
code
.
putln
(
"if (unlikely(%s)) {"
%
self
.
overflow_bit
)
code
.
putln
(
"if (unlikely(%s)) {"
%
self
.
overflow_bit
)
code
.
putln
(
'PyErr_Format(PyExc_OverflowError, "value too large");'
)
code
.
putln
(
'PyErr_Format(PyExc_OverflowError, "value too large");'
)
...
@@ -8115,10 +8115,10 @@ class NumBinopNode(BinopNode):
...
@@ -8115,10 +8115,10 @@ class NumBinopNode(BinopNode):
BinopNode
.
is_py_operation_types
(
self
,
type1
,
type2
))
BinopNode
.
is_py_operation_types
(
self
,
type1
,
type2
))
def
py_operation_function
(
self
):
def
py_operation_function
(
self
):
fu
ction
=
self
.
py_functions
[
self
.
operator
]
fu
nction_name
=
self
.
py_functions
[
self
.
operator
]
if
self
.
inplace
:
if
self
.
inplace
:
fu
ction
=
fuction
.
replace
(
'PyNumber_'
,
'PyNumber_InPlace'
)
fu
nction_name
=
function_name
.
replace
(
'PyNumber_'
,
'PyNumber_InPlace'
)
return
fu
ction
return
fu
nction_name
py_functions
=
{
py_functions
=
{
"|"
:
"PyNumber_Or"
,
"|"
:
"PyNumber_Or"
,
...
@@ -8300,7 +8300,7 @@ class DivNode(NumBinopNode):
...
@@ -8300,7 +8300,7 @@ class DivNode(NumBinopNode):
code
.
putln
(
"if ((%s < 0) ^ (%s < 0)) {"
%
(
code
.
putln
(
"if ((%s < 0) ^ (%s < 0)) {"
%
(
self
.
operand1
.
result
(),
self
.
operand1
.
result
(),
self
.
operand2
.
result
()))
self
.
operand2
.
result
()))
code
.
putln
(
code
.
set_error_info
(
self
.
pos
))
;
code
.
putln
(
code
.
set_error_info
(
self
.
pos
))
code
.
put
(
"if (__Pyx_cdivision_warning(%(FILENAME)s, "
code
.
put
(
"if (__Pyx_cdivision_warning(%(FILENAME)s, "
"%(LINENO)s)) "
%
{
"%(LINENO)s)) "
%
{
'FILENAME'
:
Naming
.
filename_cname
,
'FILENAME'
:
Naming
.
filename_cname
,
...
@@ -8565,7 +8565,7 @@ class CondExprNode(ExprNode):
...
@@ -8565,7 +8565,7 @@ class CondExprNode(ExprNode):
def
type_error
(
self
):
def
type_error
(
self
):
if
not
(
self
.
true_val
.
type
.
is_error
or
self
.
false_val
.
type
.
is_error
):
if
not
(
self
.
true_val
.
type
.
is_error
or
self
.
false_val
.
type
.
is_error
):
error
(
self
.
pos
,
"Incompat
a
ble types in conditional expression (%s; %s)"
%
error
(
self
.
pos
,
"Incompat
i
ble types in conditional expression (%s; %s)"
%
(
self
.
true_val
.
type
,
self
.
false_val
.
type
))
(
self
.
true_val
.
type
,
self
.
false_val
.
type
))
self
.
type
=
PyrexTypes
.
error_type
self
.
type
=
PyrexTypes
.
error_type
...
@@ -9269,7 +9269,7 @@ class CoercionNode(ExprNode):
...
@@ -9269,7 +9269,7 @@ class CoercionNode(ExprNode):
constant_result
=
not_a_constant
constant_result
=
not_a_constant
def
__init__
(
self
,
arg
):
def
__init__
(
self
,
arg
):
s
elf
.
pos
=
arg
.
pos
s
uper
(
CoercionNode
,
self
).
__init__
(
arg
.
pos
)
self
.
arg
=
arg
self
.
arg
=
arg
if
debug_coercion
:
if
debug_coercion
:
print
(
"%s Coercing %s"
%
(
self
,
self
.
arg
))
print
(
"%s Coercing %s"
%
(
self
,
self
.
arg
))
...
...
Cython/Compiler/Nodes.py
View file @
d48da4fd
...
@@ -11,6 +11,7 @@ cython.declare(sys=object, os=object, copy=object,
...
@@ -11,6 +11,7 @@ cython.declare(sys=object, os=object, copy=object,
absolute_path_length
=
cython
.
Py_ssize_t
)
absolute_path_length
=
cython
.
Py_ssize_t
)
import
sys
,
os
,
copy
import
sys
,
os
,
copy
from
itertools
import
chain
import
Builtin
import
Builtin
from
Errors
import
error
,
warning
,
InternalError
,
CompileError
from
Errors
import
error
,
warning
,
InternalError
,
CompileError
...
@@ -24,15 +25,13 @@ from Code import UtilityCode
...
@@ -24,15 +25,13 @@ from Code import UtilityCode
from
StringEncoding
import
EncodedString
,
escape_byte_string
,
split_string_literal
from
StringEncoding
import
EncodedString
,
escape_byte_string
,
split_string_literal
import
Options
import
Options
import
DebugFlags
import
DebugFlags
from
Cython.Compiler
import
Errors
from
itertools
import
chain
absolute_path_length
=
0
absolute_path_length
=
0
def
relative_position
(
pos
):
def
relative_position
(
pos
):
"""
"""
We embed the relative filename in the generated C file, since we
We embed the relative filename in the generated C file, since we
don't want to have to regnerate and compile all the source code
don't want to have to reg
e
nerate and compile all the source code
whenever the Python install directory moves (which could happen,
whenever the Python install directory moves (which could happen,
e.g,. when distributing binaries.)
e.g,. when distributing binaries.)
...
@@ -63,7 +62,7 @@ def embed_position(pos, docstring):
...
@@ -63,7 +62,7 @@ def embed_position(pos, docstring):
encoding
=
docstring
.
encoding
encoding
=
docstring
.
encoding
if
encoding
is
not
None
:
if
encoding
is
not
None
:
try
:
try
:
encoded_bytes
=
pos_line
.
encode
(
encoding
)
pos_line
.
encode
(
encoding
)
except
UnicodeEncodeError
:
except
UnicodeEncodeError
:
encoding
=
None
encoding
=
None
...
@@ -132,7 +131,7 @@ class Node(object):
...
@@ -132,7 +131,7 @@ class Node(object):
is_terminator
=
0
is_terminator
=
0
temps
=
None
temps
=
None
# All desc
a
ndants should set child_attrs to a list of the attributes
# All desc
e
ndants should set child_attrs to a list of the attributes
# containing nodes considered "children" in the tree. Each such attribute
# containing nodes considered "children" in the tree. Each such attribute
# can either contain a single node or a list of nodes. See Visitor.py.
# can either contain a single node or a list of nodes. See Visitor.py.
child_attrs
=
None
child_attrs
=
None
...
@@ -169,7 +168,7 @@ class Node(object):
...
@@ -169,7 +168,7 @@ class Node(object):
"""Clone the node. This is defined as a shallow copy, except for member lists
"""Clone the node. This is defined as a shallow copy, except for member lists
amongst the child attributes (from get_child_accessors) which are also
amongst the child attributes (from get_child_accessors) which are also
copied. Lists containing child nodes are thus seen as a way for the node
copied. Lists containing child nodes are thus seen as a way for the node
to hold multiple children directly; the list is not treated as a sep
e
rate
to hold multiple children directly; the list is not treated as a sep
a
rate
level in the tree."""
level in the tree."""
result
=
copy
.
copy
(
self
)
result
=
copy
.
copy
(
self
)
for
attrname
in
result
.
child_attrs
:
for
attrname
in
result
.
child_attrs
:
...
@@ -722,8 +721,7 @@ class CArgDeclNode(Node):
...
@@ -722,8 +721,7 @@ class CArgDeclNode(Node):
if
is_self_arg
:
if
is_self_arg
:
self
.
base_type
.
is_self_arg
=
self
.
is_self_arg
=
True
self
.
base_type
.
is_self_arg
=
self
.
is_self_arg
=
True
if
self
.
type
is
None
:
if
self
.
type
is
None
:
# The parser may missinterpret names as types...
# The parser may misinterpret names as types. We fix that here.
# We fix that here.
if
isinstance
(
self
.
declarator
,
CNameDeclaratorNode
)
and
self
.
declarator
.
name
==
''
:
if
isinstance
(
self
.
declarator
,
CNameDeclaratorNode
)
and
self
.
declarator
.
name
==
''
:
if
nonempty
:
if
nonempty
:
if
self
.
base_type
.
is_basic_c_type
:
if
self
.
base_type
.
is_basic_c_type
:
...
@@ -940,7 +938,9 @@ class CNestedBaseTypeNode(CBaseTypeNode):
...
@@ -940,7 +938,9 @@ class CNestedBaseTypeNode(CBaseTypeNode):
# name string
# name string
# base_type CBaseTypeNode
# base_type CBaseTypeNode
child_attrs
=
[
'base_type'
]
child_attrs
=
[
'base_type'
]
def
analyse
(
self
,
env
,
could_be_name
=
None
):
def
analyse
(
self
,
env
,
could_be_name
=
None
):
base_type
=
self
.
base_type
.
analyse
(
env
)
base_type
=
self
.
base_type
.
analyse
(
env
)
if
base_type
is
PyrexTypes
.
error_type
:
if
base_type
is
PyrexTypes
.
error_type
:
...
@@ -964,7 +964,6 @@ class TemplatedTypeNode(CBaseTypeNode):
...
@@ -964,7 +964,6 @@ class TemplatedTypeNode(CBaseTypeNode):
# After analysis:
# After analysis:
# type PyrexTypes.BufferType or PyrexTypes.CppClassType ...containing the right options
# type PyrexTypes.BufferType or PyrexTypes.CppClassType ...containing the right options
child_attrs
=
[
"base_type_node"
,
"positional_args"
,
child_attrs
=
[
"base_type_node"
,
"positional_args"
,
"keyword_args"
,
"dtype_node"
]
"keyword_args"
,
"dtype_node"
]
...
@@ -980,7 +979,7 @@ class TemplatedTypeNode(CBaseTypeNode):
...
@@ -980,7 +979,7 @@ class TemplatedTypeNode(CBaseTypeNode):
if
base_type
.
is_cpp_class
:
if
base_type
.
is_cpp_class
:
# Templated class
# Templated class
if
self
.
keyword_args
and
self
.
keyword_args
.
key_value_pairs
:
if
self
.
keyword_args
and
self
.
keyword_args
.
key_value_pairs
:
error
(
self
.
pos
,
"c++ templates cannot take keyword arguments"
)
;
error
(
self
.
pos
,
"c++ templates cannot take keyword arguments"
)
self
.
type
=
PyrexTypes
.
error_type
self
.
type
=
PyrexTypes
.
error_type
else
:
else
:
template_types
=
[]
template_types
=
[]
...
@@ -1640,7 +1639,7 @@ class FuncDefNode(StatNode, BlockNode):
...
@@ -1640,7 +1639,7 @@ class FuncDefNode(StatNode, BlockNode):
cenv
.
scope_class
.
type
.
declaration_code
(
''
),
cenv
.
scope_class
.
type
.
declaration_code
(
''
),
Naming
.
self_cname
))
Naming
.
self_cname
))
if
lenv
.
is_passthrough
:
if
lenv
.
is_passthrough
:
code
.
putln
(
"%s = %s;"
%
(
Naming
.
cur_scope_cname
,
outer_scope_cname
))
;
code
.
putln
(
"%s = %s;"
%
(
Naming
.
cur_scope_cname
,
outer_scope_cname
))
elif
self
.
needs_closure
:
elif
self
.
needs_closure
:
# inner closures own a reference to their outer parent
# inner closures own a reference to their outer parent
code
.
put_incref
(
outer_scope_cname
,
cenv
.
scope_class
.
type
)
code
.
put_incref
(
outer_scope_cname
,
cenv
.
scope_class
.
type
)
...
@@ -1837,7 +1836,7 @@ class FuncDefNode(StatNode, BlockNode):
...
@@ -1837,7 +1836,7 @@ class FuncDefNode(StatNode, BlockNode):
default_retval
=
self
.
return_type
.
default_value
default_retval
=
self
.
return_type
.
default_value
err_val
=
self
.
error_value
()
err_val
=
self
.
error_value
()
if
err_val
is
None
and
default_retval
:
if
err_val
is
None
and
default_retval
:
err_val
=
default_retval
err_val
=
default_retval
# FIXME: why is err_val not used?
if
self
.
return_type
.
is_pyobject
:
if
self
.
return_type
.
is_pyobject
:
code
.
put_xgiveref
(
self
.
return_type
.
as_pyobject
(
Naming
.
retval_cname
))
code
.
put_xgiveref
(
self
.
return_type
.
as_pyobject
(
Naming
.
retval_cname
))
...
@@ -1854,7 +1853,7 @@ class FuncDefNode(StatNode, BlockNode):
...
@@ -1854,7 +1853,7 @@ class FuncDefNode(StatNode, BlockNode):
code
.
put_trace_return
(
"Py_None"
)
code
.
put_trace_return
(
"Py_None"
)
if
not
lenv
.
nogil
:
if
not
lenv
.
nogil
:
# GIL holding funcion
# GIL holding func
t
ion
code
.
put_finish_refcount_context
()
code
.
put_finish_refcount_context
()
if
acquire_gil
or
(
lenv
.
nogil
and
lenv
.
has_with_gil_block
):
if
acquire_gil
or
(
lenv
.
nogil
and
lenv
.
has_with_gil_block
):
...
@@ -2509,7 +2508,7 @@ class DefNode(FuncDefNode):
...
@@ -2509,7 +2508,7 @@ class DefNode(FuncDefNode):
self
.
py_wrapper
.
analyse_declarations
(
env
)
self
.
py_wrapper
.
analyse_declarations
(
env
)
def
analyse_argument_types
(
self
,
env
):
def
analyse_argument_types
(
self
,
env
):
directive_locals
=
self
.
directive_locals
=
env
.
directives
[
'locals'
]
self
.
directive_locals
=
env
.
directives
[
'locals'
]
allow_none_for_extension_args
=
env
.
directives
[
'allow_none_for_extension_args'
]
allow_none_for_extension_args
=
env
.
directives
[
'allow_none_for_extension_args'
]
f2s
=
env
.
fused_to_specific
f2s
=
env
.
fused_to_specific
...
@@ -2644,7 +2643,7 @@ class DefNode(FuncDefNode):
...
@@ -2644,7 +2643,7 @@ class DefNode(FuncDefNode):
sig
=
self
.
entry
.
signature
sig
=
self
.
entry
.
signature
expected_str
=
"%d"
%
sig
.
num_fixed_args
()
expected_str
=
"%d"
%
sig
.
num_fixed_args
()
if
sig
.
has_generic_args
:
if
sig
.
has_generic_args
:
expected_str
=
expected_str
+
" or more"
expected_str
+=
" or more"
name
=
self
.
name
name
=
self
.
name
if
name
.
startswith
(
"__"
)
and
name
.
endswith
(
"__"
):
if
name
.
startswith
(
"__"
)
and
name
.
endswith
(
"__"
):
desc
=
"Special method"
desc
=
"Special method"
...
@@ -2767,10 +2766,9 @@ class DefNode(FuncDefNode):
...
@@ -2767,10 +2766,9 @@ class DefNode(FuncDefNode):
return
return
arg_code_list
=
[]
arg_code_list
=
[]
if
self
.
entry
.
signature
.
has_dummy_arg
:
if
self
.
entry
.
signature
.
has_dummy_arg
:
if
self
.
needs_outer_scope
:
self_arg
=
'PyObject *%s'
%
Naming
.
self_cname
self_arg
=
'PyObject *%s'
%
Naming
.
self_cname
els
e
:
if
not
self
.
needs_outer_scop
e
:
self_arg
=
'CYTHON_UNUSED
PyObject *%s'
%
Naming
.
self_cname
self_arg
=
'CYTHON_UNUSED
'
+
self_arg
arg_code_list
.
append
(
self_arg
)
arg_code_list
.
append
(
self_arg
)
def
arg_decl_code
(
arg
):
def
arg_decl_code
(
arg
):
...
@@ -2780,9 +2778,9 @@ class DefNode(FuncDefNode):
...
@@ -2780,9 +2778,9 @@ class DefNode(FuncDefNode):
else
:
else
:
cname
=
entry
.
cname
cname
=
entry
.
cname
decl
=
entry
.
type
.
declaration_code
(
cname
)
decl
=
entry
.
type
.
declaration_code
(
cname
)
if
entry
.
cf_used
:
if
not
entry
.
cf_used
:
decl
=
'CYTHON_UNUSED '
+
decl
return
decl
return
decl
return
'CYTHON_UNUSED '
+
decl
for
arg
in
self
.
args
:
for
arg
in
self
.
args
:
arg_code_list
.
append
(
arg_decl_code
(
arg
))
arg_code_list
.
append
(
arg_decl_code
(
arg
))
...
@@ -3646,7 +3644,7 @@ class GeneratorDefNode(DefNode):
...
@@ -3646,7 +3644,7 @@ class GeneratorDefNode(DefNode):
code
.
put_incref
(
classobj_cname
,
py_object_type
)
code
.
put_incref
(
classobj_cname
,
py_object_type
)
code
.
put_giveref
(
classobj_cname
)
code
.
put_giveref
(
classobj_cname
)
code
.
put_finish_refcount_context
()
code
.
put_finish_refcount_context
()
code
.
putln
(
'return (PyObject *) gen;'
)
;
code
.
putln
(
'return (PyObject *) gen;'
)
code
.
putln
(
'}'
)
code
.
putln
(
'}'
)
def
generate_function_definitions
(
self
,
env
,
code
):
def
generate_function_definitions
(
self
,
env
,
code
):
...
@@ -3690,7 +3688,7 @@ class GeneratorBodyDefNode(DefNode):
...
@@ -3690,7 +3688,7 @@ class GeneratorBodyDefNode(DefNode):
if
proto
:
if
proto
:
code
.
putln
(
'%s; /* proto */'
%
header
)
code
.
putln
(
'%s; /* proto */'
%
header
)
else
:
else
:
code
.
putln
(
'%s /* generator body */
\
n
{'
%
header
)
;
code
.
putln
(
'%s /* generator body */
\
n
{'
%
header
)
def
generate_function_definitions
(
self
,
env
,
code
):
def
generate_function_definitions
(
self
,
env
,
code
):
lenv
=
self
.
local_scope
lenv
=
self
.
local_scope
...
@@ -3796,9 +3794,8 @@ class OverrideCheckNode(StatNode):
...
@@ -3796,9 +3794,8 @@ class OverrideCheckNode(StatNode):
first_arg
=
1
first_arg
=
1
import
ExprNodes
import
ExprNodes
self
.
func_node
=
ExprNodes
.
RawCNameExprNode
(
self
.
pos
,
py_object_type
)
self
.
func_node
=
ExprNodes
.
RawCNameExprNode
(
self
.
pos
,
py_object_type
)
call_tuple
=
ExprNodes
.
TupleNode
(
self
.
pos
,
args
=
[
ExprNodes
.
NameNode
(
self
.
pos
,
name
=
arg
.
name
)
for
arg
in
self
.
args
[
first_arg
:]])
call_node
=
ExprNodes
.
SimpleCallNode
(
call_node
=
ExprNodes
.
SimpleCallNode
(
self
.
pos
,
self
.
pos
,
function
=
self
.
func_node
,
function
=
self
.
func_node
,
args
=
[
ExprNodes
.
NameNode
(
self
.
pos
,
name
=
arg
.
name
)
for
arg
in
self
.
args
[
first_arg
:]])
args
=
[
ExprNodes
.
NameNode
(
self
.
pos
,
name
=
arg
.
name
)
for
arg
in
self
.
args
[
first_arg
:]])
self
.
body
=
ReturnStatNode
(
self
.
pos
,
value
=
call_node
)
self
.
body
=
ReturnStatNode
(
self
.
pos
,
value
=
call_node
)
self
.
body
.
analyse_expressions
(
env
)
self
.
body
.
analyse_expressions
(
env
)
...
@@ -3812,7 +3809,7 @@ class OverrideCheckNode(StatNode):
...
@@ -3812,7 +3809,7 @@ class OverrideCheckNode(StatNode):
self_arg
=
"((PyObject *)%s)"
%
self
.
args
[
0
].
cname
self_arg
=
"((PyObject *)%s)"
%
self
.
args
[
0
].
cname
code
.
putln
(
"/* Check if called by wrapper */"
)
code
.
putln
(
"/* Check if called by wrapper */"
)
code
.
putln
(
"if (unlikely(%s)) ;"
%
Naming
.
skip_dispatch_cname
)
code
.
putln
(
"if (unlikely(%s)) ;"
%
Naming
.
skip_dispatch_cname
)
code
.
putln
(
"/* Check if overriden in Python */"
)
code
.
putln
(
"/* Check if overrid
d
en in Python */"
)
if
self
.
py_func
.
is_module_scope
:
if
self
.
py_func
.
is_module_scope
:
code
.
putln
(
"else {"
)
code
.
putln
(
"else {"
)
else
:
else
:
...
@@ -4134,7 +4131,7 @@ class CClassDefNode(ClassDefNode):
...
@@ -4134,7 +4131,7 @@ class CClassDefNode(ClassDefNode):
if
not
base_class_entry
.
is_type
:
if
not
base_class_entry
.
is_type
:
error
(
self
.
pos
,
"'%s' is not a type name"
%
self
.
base_class_name
)
error
(
self
.
pos
,
"'%s' is not a type name"
%
self
.
base_class_name
)
elif
not
base_class_entry
.
type
.
is_extension_type
and
\
elif
not
base_class_entry
.
type
.
is_extension_type
and
\
not
(
base_class_entry
.
type
.
is_builtin_type
and
\
not
(
base_class_entry
.
type
.
is_builtin_type
and
base_class_entry
.
type
.
objstruct_cname
):
base_class_entry
.
type
.
objstruct_cname
):
error
(
self
.
pos
,
"'%s' is not an extension type"
%
self
.
base_class_name
)
error
(
self
.
pos
,
"'%s' is not an extension type"
%
self
.
base_class_name
)
elif
not
base_class_entry
.
type
.
is_complete
():
elif
not
base_class_entry
.
type
.
is_complete
():
...
@@ -4542,8 +4539,8 @@ class CascadedAssignmentNode(AssignmentNode):
...
@@ -4542,8 +4539,8 @@ class CascadedAssignmentNode(AssignmentNode):
def
annotate
(
self
,
code
):
def
annotate
(
self
,
code
):
for
i
in
range
(
len
(
self
.
lhs_list
)):
for
i
in
range
(
len
(
self
.
lhs_list
)):
lhs
=
self
.
lhs_list
[
i
].
annotate
(
code
)
self
.
lhs_list
[
i
].
annotate
(
code
)
rhs
=
self
.
coerced_rhs_list
[
i
].
annotate
(
code
)
self
.
coerced_rhs_list
[
i
].
annotate
(
code
)
self
.
rhs
.
annotate
(
code
)
self
.
rhs
.
annotate
(
code
)
...
@@ -5581,10 +5578,9 @@ class ForFromStatNode(LoopNode, StatNode):
...
@@ -5581,10 +5578,9 @@ class ForFromStatNode(LoopNode, StatNode):
self
.
bound2
.
analyse_types
(
env
)
self
.
bound2
.
analyse_types
(
env
)
if
self
.
step
is
not
None
:
if
self
.
step
is
not
None
:
if
isinstance
(
self
.
step
,
ExprNodes
.
UnaryMinusNode
):
if
isinstance
(
self
.
step
,
ExprNodes
.
UnaryMinusNode
):
warning
(
self
.
step
.
pos
,
"Probable infinite loop in for-from-by statment. Consider switching the directions of the relations."
,
2
)
warning
(
self
.
step
.
pos
,
"Probable infinite loop in for-from-by stat
e
ment. Consider switching the directions of the relations."
,
2
)
self
.
step
.
analyse_types
(
env
)
self
.
step
.
analyse_types
(
env
)
target_type
=
self
.
target
.
type
if
self
.
target
.
type
.
is_numeric
:
if
self
.
target
.
type
.
is_numeric
:
loop_type
=
self
.
target
.
type
loop_type
=
self
.
target
.
type
else
:
else
:
...
@@ -5927,7 +5923,7 @@ class TryExceptStatNode(StatNode):
...
@@ -5927,7 +5923,7 @@ class TryExceptStatNode(StatNode):
try_end_label
=
code
.
new_label
(
'try_end'
)
try_end_label
=
code
.
new_label
(
'try_end'
)
exc_save_vars
=
[
code
.
funcstate
.
allocate_temp
(
py_object_type
,
False
)
exc_save_vars
=
[
code
.
funcstate
.
allocate_temp
(
py_object_type
,
False
)
for
i
in
xrange
(
3
)]
for
_
in
xrange
(
3
)]
code
.
putln
(
"{"
)
code
.
putln
(
"{"
)
code
.
putln
(
"__Pyx_ExceptionSave(%s);"
%
code
.
putln
(
"__Pyx_ExceptionSave(%s);"
%
', '
.
join
([
'&%s'
%
var
for
var
in
exc_save_vars
]))
', '
.
join
([
'&%s'
%
var
for
var
in
exc_save_vars
]))
...
@@ -6047,8 +6043,6 @@ class ExceptClauseNode(Node):
...
@@ -6047,8 +6043,6 @@ class ExceptClauseNode(Node):
self
.
body
.
analyse_declarations
(
env
)
self
.
body
.
analyse_declarations
(
env
)
def
analyse_expressions
(
self
,
env
):
def
analyse_expressions
(
self
,
env
):
import
ExprNodes
genv
=
env
.
global_scope
()
self
.
function_name
=
env
.
qualified_name
self
.
function_name
=
env
.
qualified_name
if
self
.
pattern
:
if
self
.
pattern
:
# normalise/unpack self.pattern into a list
# normalise/unpack self.pattern into a list
...
@@ -6057,12 +6051,13 @@ class ExceptClauseNode(Node):
...
@@ -6057,12 +6051,13 @@ class ExceptClauseNode(Node):
self
.
pattern
[
i
]
=
pattern
.
coerce_to_pyobject
(
env
)
self
.
pattern
[
i
]
=
pattern
.
coerce_to_pyobject
(
env
)
if
self
.
target
:
if
self
.
target
:
import
ExprNodes
self
.
exc_value
=
ExprNodes
.
ExcValueNode
(
self
.
pos
,
env
)
self
.
exc_value
=
ExprNodes
.
ExcValueNode
(
self
.
pos
,
env
)
self
.
target
.
analyse_target_expression
(
env
,
self
.
exc_value
)
self
.
target
.
analyse_target_expression
(
env
,
self
.
exc_value
)
if
self
.
excinfo_target
is
not
None
:
if
self
.
excinfo_target
is
not
None
:
import
ExprNodes
import
ExprNodes
self
.
excinfo_tuple
=
ExprNodes
.
TupleNode
(
pos
=
self
.
pos
,
args
=
[
self
.
excinfo_tuple
=
ExprNodes
.
TupleNode
(
pos
=
self
.
pos
,
args
=
[
ExprNodes
.
ExcValueNode
(
pos
=
self
.
pos
,
env
=
env
)
for
x
in
range
(
3
)])
ExprNodes
.
ExcValueNode
(
pos
=
self
.
pos
,
env
=
env
)
for
_
in
range
(
3
)])
self
.
excinfo_tuple
.
analyse_expressions
(
env
)
self
.
excinfo_tuple
.
analyse_expressions
(
env
)
self
.
body
.
analyse_expressions
(
env
)
self
.
body
.
analyse_expressions
(
env
)
...
@@ -6099,7 +6094,7 @@ class ExceptClauseNode(Node):
...
@@ -6099,7 +6094,7 @@ class ExceptClauseNode(Node):
exc_vars
=
[
code
.
funcstate
.
allocate_temp
(
py_object_type
,
exc_vars
=
[
code
.
funcstate
.
allocate_temp
(
py_object_type
,
manage_ref
=
True
)
manage_ref
=
True
)
for
i
in
xrange
(
3
)]
for
_
in
xrange
(
3
)]
code
.
put_add_traceback
(
self
.
function_name
)
code
.
put_add_traceback
(
self
.
function_name
)
# We always have to fetch the exception value even if
# We always have to fetch the exception value even if
# there is no target, because this also normalises the
# there is no target, because this also normalises the
...
@@ -6957,8 +6952,6 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -6957,8 +6952,6 @@ class ParallelStatNode(StatNode, ParallelNode):
code
.
globalstate
.
use_utility_code
(
code
.
globalstate
.
use_utility_code
(
invalid_values_utility_code
)
invalid_values_utility_code
)
first
=
False
first
=
False
have_invalid_values
=
True
code
.
putln
(
"%s = %s;"
%
(
entry
.
cname
,
code
.
putln
(
"%s = %s;"
%
(
entry
.
cname
,
entry
.
type
.
cast_code
(
invalid_value
)))
entry
.
type
.
cast_code
(
invalid_value
)))
...
@@ -6992,7 +6985,7 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -6992,7 +6985,7 @@ class ParallelStatNode(StatNode, ParallelNode):
"""
"""
self
.
modified_entries
=
[]
self
.
modified_entries
=
[]
for
entry
,
(
pos
,
op
)
in
self
.
assignments
.
iteritems
()
:
for
entry
in
self
.
assignments
:
if
entry
.
from_closure
or
entry
.
in_closure
:
if
entry
.
from_closure
or
entry
.
in_closure
:
self
.
_allocate_closure_temp
(
code
,
entry
)
self
.
_allocate_closure_temp
(
code
,
entry
)
...
@@ -7142,7 +7135,6 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -7142,7 +7135,6 @@ class ParallelStatNode(StatNode, ParallelNode):
"""
"""
save_lastprivates_label
=
code
.
new_label
()
save_lastprivates_label
=
code
.
new_label
()
dont_return_label
=
code
.
new_label
()
dont_return_label
=
code
.
new_label
()
insertion_point
=
code
.
insertion_point
()
self
.
any_label_used
=
False
self
.
any_label_used
=
False
self
.
breaking_label_used
=
False
self
.
breaking_label_used
=
False
...
@@ -7501,8 +7493,8 @@ class ParallelRangeNode(ParallelStatNode):
...
@@ -7501,8 +7493,8 @@ class ParallelRangeNode(ParallelStatNode):
(
self
.
schedule
,))
(
self
.
schedule
,))
def
analyse_expressions
(
self
,
env
):
def
analyse_expressions
(
self
,
env
):
if
self
.
nogil
:
was_nogil
=
env
.
nogil
was_nogil
=
env
.
nogil
if
self
.
nogil
:
env
.
nogil
=
True
env
.
nogil
=
True
if
self
.
target
is
None
:
if
self
.
target
is
None
:
...
@@ -7860,7 +7852,6 @@ class CnameDecoratorNode(StatNode):
...
@@ -7860,7 +7852,6 @@ class CnameDecoratorNode(StatNode):
if
entry
.
func_cname
:
if
entry
.
func_cname
:
entry
.
func_cname
=
self
.
mangle
(
entry
.
cname
)
entry
.
func_cname
=
self
.
mangle
(
entry
.
cname
)
if
entry
.
pyfunc_cname
:
if
entry
.
pyfunc_cname
:
old
=
entry
.
pyfunc_cname
entry
.
pyfunc_cname
=
self
.
mangle
(
entry
.
pyfunc_cname
)
entry
.
pyfunc_cname
=
self
.
mangle
(
entry
.
pyfunc_cname
)
def
mangle
(
self
,
cname
):
def
mangle
(
self
,
cname
):
...
...
Cython/Compiler/PyrexTypes.py
View file @
d48da4fd
...
@@ -447,7 +447,7 @@ class MemoryViewSliceType(PyrexType):
...
@@ -447,7 +447,7 @@ class MemoryViewSliceType(PyrexType):
has_attributes
=
1
has_attributes
=
1
scope
=
None
scope
=
None
# These are specialcased in Defnode
# These are special
cased in Defnode
from_py_function
=
None
from_py_function
=
None
to_py_function
=
None
to_py_function
=
None
...
@@ -457,7 +457,7 @@ class MemoryViewSliceType(PyrexType):
...
@@ -457,7 +457,7 @@ class MemoryViewSliceType(PyrexType):
subtypes
=
[
'dtype'
]
subtypes
=
[
'dtype'
]
def
__init__
(
self
,
base_dtype
,
axes
):
def
__init__
(
self
,
base_dtype
,
axes
):
'''
"""
MemoryViewSliceType(base, axes)
MemoryViewSliceType(base, axes)
Base is the C base type; axes is a list of (access, packing) strings,
Base is the C base type; axes is a list of (access, packing) strings,
...
@@ -489,7 +489,7 @@ class MemoryViewSliceType(PyrexType):
...
@@ -489,7 +489,7 @@ class MemoryViewSliceType(PyrexType):
Fortran-contiguous memory has 'direct' as the access spec, 'contig' as
Fortran-contiguous memory has 'direct' as the access spec, 'contig' as
the *first* axis' packing spec and 'follow' for all other packing
the *first* axis' packing spec and 'follow' for all other packing
specs.
specs.
'''
"""
import
MemoryView
import
MemoryView
self
.
dtype
=
base_dtype
self
.
dtype
=
base_dtype
...
@@ -684,8 +684,6 @@ class MemoryViewSliceType(PyrexType):
...
@@ -684,8 +684,6 @@ class MemoryViewSliceType(PyrexType):
return
"__pyx_memoryview_fromslice(%s, %s, %s, %s, %d);"
%
tup
return
"__pyx_memoryview_fromslice(%s, %s, %s, %s, %d);"
%
tup
def
dtype_object_conversion_funcs
(
self
,
env
):
def
dtype_object_conversion_funcs
(
self
,
env
):
import
MemoryView
,
Code
get_function
=
"__pyx_memview_get_%s"
%
self
.
dtype_name
get_function
=
"__pyx_memview_get_%s"
%
self
.
dtype_name
set_function
=
"__pyx_memview_set_%s"
%
self
.
dtype_name
set_function
=
"__pyx_memview_set_%s"
%
self
.
dtype_name
...
@@ -724,13 +722,13 @@ class MemoryViewSliceType(PyrexType):
...
@@ -724,13 +722,13 @@ class MemoryViewSliceType(PyrexType):
return
get_function
,
set_function
return
get_function
,
set_function
def
axes_to_code
(
self
):
def
axes_to_code
(
self
):
"
Return a list of code constants for each axis
"
"
""Return a list of code constants for each axis""
"
import
MemoryView
import
MemoryView
d
=
MemoryView
.
_spec_to_const
d
=
MemoryView
.
_spec_to_const
return
[
"(%s | %s)"
%
(
d
[
a
],
d
[
p
])
for
a
,
p
in
self
.
axes
]
return
[
"(%s | %s)"
%
(
d
[
a
],
d
[
p
])
for
a
,
p
in
self
.
axes
]
def
axes_to_name
(
self
):
def
axes_to_name
(
self
):
"
Return an abbreviated name for our axes
"
"
""Return an abbreviated name for our axes""
"
import
MemoryView
import
MemoryView
d
=
MemoryView
.
_spec_to_abbrev
d
=
MemoryView
.
_spec_to_abbrev
return
""
.
join
([
"%s%s"
%
(
d
[
a
],
d
[
p
])
for
a
,
p
in
self
.
axes
])
return
""
.
join
([
"%s%s"
%
(
d
[
a
],
d
[
p
])
for
a
,
p
in
self
.
axes
])
...
@@ -763,7 +761,7 @@ class MemoryViewSliceType(PyrexType):
...
@@ -763,7 +761,7 @@ class MemoryViewSliceType(PyrexType):
return
"%s[%s]"
%
(
dtype_name
,
", "
.
join
(
axes_code_list
))
return
"%s[%s]"
%
(
dtype_name
,
", "
.
join
(
axes_code_list
))
def
specialize
(
self
,
values
):
def
specialize
(
self
,
values
):
"
This does not validate the base type!!
"
"
""This does not validate the base type!!""
"
dtype
=
self
.
dtype
.
specialize
(
values
)
dtype
=
self
.
dtype
.
specialize
(
values
)
if
dtype
is
not
self
.
dtype
:
if
dtype
is
not
self
.
dtype
:
return
MemoryViewSliceType
(
dtype
,
self
.
axes
)
return
MemoryViewSliceType
(
dtype
,
self
.
axes
)
...
@@ -868,7 +866,7 @@ class PyObjectType(PyrexType):
...
@@ -868,7 +866,7 @@ class PyObjectType(PyrexType):
return
True
return
True
def
default_coerced_ctype
(
self
):
def
default_coerced_ctype
(
self
):
"
The default C type that this Python type coerces to, or None.
"
"
""The default C type that this Python type coerces to, or None.""
"
return
None
return
None
def
assignable_from
(
self
,
src_type
):
def
assignable_from
(
self
,
src_type
):
...
@@ -990,7 +988,7 @@ class BuiltinObjectType(PyObjectType):
...
@@ -990,7 +988,7 @@ class BuiltinObjectType(PyObjectType):
type_check
=
self
.
type_check_function
(
exact
=
True
)
type_check
=
self
.
type_check_function
(
exact
=
True
)
check
=
'likely(%s(%s))'
%
(
type_check
,
arg
)
check
=
'likely(%s(%s))'
%
(
type_check
,
arg
)
if
not
notnone
:
if
not
notnone
:
check
=
check
+
(
'||((%s) == Py_None)'
%
arg
)
check
+=
'||((%s) == Py_None)'
%
arg
error
=
'(PyErr_Format(PyExc_TypeError, "Expected %s, got %%.200s", Py_TYPE(%s)->tp_name), 0)'
%
(
self
.
name
,
arg
)
error
=
'(PyErr_Format(PyExc_TypeError, "Expected %s, got %%.200s", Py_TYPE(%s)->tp_name), 0)'
%
(
self
.
name
,
arg
)
return
check
+
'||'
+
error
return
check
+
'||'
+
error
...
@@ -1198,7 +1196,7 @@ class CConstType(BaseType):
...
@@ -1198,7 +1196,7 @@ class CConstType(BaseType):
if
base_type
==
self
.
const_base_type
:
if
base_type
==
self
.
const_base_type
:
return
self
return
self
else
:
else
:
return
ConstType
(
base_type
)
return
C
C
onstType
(
base_type
)
def
create_to_py_utility_code
(
self
,
env
):
def
create_to_py_utility_code
(
self
,
env
):
if
self
.
const_base_type
.
create_to_py_utility_code
(
env
):
if
self
.
const_base_type
.
create_to_py_utility_code
(
env
):
...
@@ -1330,7 +1328,7 @@ class CNumericType(CType):
...
@@ -1330,7 +1328,7 @@ class CNumericType(CType):
visibility
=
"extern"
)
visibility
=
"extern"
)
scope
.
parent_type
=
self
scope
.
parent_type
=
self
scope
.
directives
=
{}
scope
.
directives
=
{}
entry
=
scope
.
declare_cfunction
(
scope
.
declare_cfunction
(
"conjugate"
,
"conjugate"
,
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)],
nogil
=
True
),
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)],
nogil
=
True
),
pos
=
None
,
pos
=
None
,
...
@@ -1339,7 +1337,7 @@ class CNumericType(CType):
...
@@ -1339,7 +1337,7 @@ class CNumericType(CType):
return
True
return
True
def
__lt__
(
self
,
other
):
def
__lt__
(
self
,
other
):
"
Sort based on rank, preferring signed over unsigned
"
"
""Sort based on rank, preferring signed over unsigned""
"
if
other
.
is_numeric
:
if
other
.
is_numeric
:
return
self
.
rank
>
other
.
rank
and
self
.
signed
>=
other
.
signed
return
self
.
rank
>
other
.
rank
and
self
.
signed
>=
other
.
signed
...
@@ -1928,7 +1926,7 @@ class CComplexType(CNumericType):
...
@@ -1928,7 +1926,7 @@ class CComplexType(CNumericType):
scope
.
directives
=
{}
scope
.
directives
=
{}
scope
.
declare_var
(
"real"
,
self
.
real_type
,
None
,
cname
=
"real"
,
is_cdef
=
True
)
scope
.
declare_var
(
"real"
,
self
.
real_type
,
None
,
cname
=
"real"
,
is_cdef
=
True
)
scope
.
declare_var
(
"imag"
,
self
.
real_type
,
None
,
cname
=
"imag"
,
is_cdef
=
True
)
scope
.
declare_var
(
"imag"
,
self
.
real_type
,
None
,
cname
=
"imag"
,
is_cdef
=
True
)
entry
=
scope
.
declare_cfunction
(
scope
.
declare_cfunction
(
"conjugate"
,
"conjugate"
,
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)],
nogil
=
True
),
CFuncType
(
self
,
[
CFuncTypeArg
(
"self"
,
self
,
None
)],
nogil
=
True
),
pos
=
None
,
pos
=
None
,
...
@@ -2790,7 +2788,7 @@ class CFuncType(CType):
...
@@ -2790,7 +2788,7 @@ class CFuncType(CType):
return
result
return
result
def
get_fused_types
(
self
,
result
=
None
,
seen
=
None
,
subtypes
=
None
):
def
get_fused_types
(
self
,
result
=
None
,
seen
=
None
,
subtypes
=
None
):
"
Return fused types in the order they appear as parameter types
"
"
""Return fused types in the order they appear as parameter types""
"
return
super
(
CFuncType
,
self
).
get_fused_types
(
result
,
seen
,
return
super
(
CFuncType
,
self
).
get_fused_types
(
result
,
seen
,
subtypes
=
[
'args'
])
subtypes
=
[
'args'
])
...
@@ -3223,8 +3221,8 @@ class CppClassType(CType):
...
@@ -3223,8 +3221,8 @@ class CppClassType(CType):
def
specialize_here
(
self
,
pos
,
template_values
=
None
):
def
specialize_here
(
self
,
pos
,
template_values
=
None
):
if
self
.
templates
is
None
:
if
self
.
templates
is
None
:
error
(
pos
,
"'%s' type is not a template"
%
self
)
;
error
(
pos
,
"'%s' type is not a template"
%
self
)
return
PyrexTypes
.
error_type
return
error_type
if
len
(
self
.
templates
)
!=
len
(
template_values
):
if
len
(
self
.
templates
)
!=
len
(
template_values
):
error
(
pos
,
"%s templated type receives %d arguments, got %d"
%
error
(
pos
,
"%s templated type receives %d arguments, got %d"
%
(
self
.
name
,
len
(
self
.
templates
),
len
(
template_values
)))
(
self
.
name
,
len
(
self
.
templates
),
len
(
template_values
)))
...
@@ -3625,8 +3623,6 @@ def best_match(args, functions, pos=None, env=None):
...
@@ -3625,8 +3623,6 @@ def best_match(args, functions, pos=None, env=None):
the same weight, we return None (as there is no best match). If pos
the same weight, we return None (as there is no best match). If pos
is not None, we also generate an error.
is not None, we also generate an error.
"""
"""
from
Cython
import
Utils
# TODO: args should be a list of types, not a list of Nodes.
# TODO: args should be a list of types, not a list of Nodes.
actual_nargs
=
len
(
args
)
actual_nargs
=
len
(
args
)
...
...
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