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
38abf1b6
Commit
38abf1b6
authored
Jul 25, 2015
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
make dict iteration compatible with Py2/Py3
parent
caa2fe39
Changes
23
Hide whitespace changes
Inline
Side-by-side
Showing
23 changed files
with
78 additions
and
91 deletions
+78
-91
Cython/Build/Dependencies.py
Cython/Build/Dependencies.py
+1
-1
Cython/Build/Inline.py
Cython/Build/Inline.py
+2
-3
Cython/Compiler/Buffer.py
Cython/Compiler/Buffer.py
+8
-10
Cython/Compiler/Code.py
Cython/Compiler/Code.py
+3
-5
Cython/Compiler/FlowControl.py
Cython/Compiler/FlowControl.py
+2
-2
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+1
-1
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+8
-10
Cython/Compiler/ParseTreeTransforms.py
Cython/Compiler/ParseTreeTransforms.py
+6
-6
Cython/Compiler/Pipeline.py
Cython/Compiler/Pipeline.py
+2
-2
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+1
-1
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+2
-2
Cython/Compiler/TreeFragment.py
Cython/Compiler/TreeFragment.py
+1
-1
Cython/Compiler/TypeSlots.py
Cython/Compiler/TypeSlots.py
+1
-1
Cython/Compiler/UtilityCode.py
Cython/Compiler/UtilityCode.py
+1
-1
Cython/Compiler/Visitor.py
Cython/Compiler/Visitor.py
+1
-1
Cython/Debugger/Tests/test_libcython_in_gdb.py
Cython/Debugger/Tests/test_libcython_in_gdb.py
+1
-1
Cython/Debugger/libcython.py
Cython/Debugger/libcython.py
+10
-12
Cython/Debugger/libpython.py
Cython/Debugger/libpython.py
+9
-8
Cython/Distutils/extension.py
Cython/Distutils/extension.py
+1
-1
Cython/Plex/DFA.py
Cython/Plex/DFA.py
+3
-3
Cython/Plex/Machines.py
Cython/Plex/Machines.py
+5
-5
Cython/Plex/Transitions.py
Cython/Plex/Transitions.py
+3
-3
Cython/Tempita/_tempita.py
Cython/Tempita/_tempita.py
+6
-11
No files found.
Cython/Build/Dependencies.py
View file @
38abf1b6
...
@@ -878,7 +878,7 @@ def cythonize(module_list, exclude=[], nthreads=0, aliases=None, quiet=False, fo
...
@@ -878,7 +878,7 @@ def cythonize(module_list, exclude=[], nthreads=0, aliases=None, quiet=False, fo
if
exclude_failures
:
if
exclude_failures
:
failed_modules
=
set
()
failed_modules
=
set
()
for
c_file
,
modules
in
modules_by_cfile
.
ite
rite
ms
():
for
c_file
,
modules
in
modules_by_cfile
.
items
():
if
not
os
.
path
.
exists
(
c_file
):
if
not
os
.
path
.
exists
(
c_file
):
failed_modules
.
update
(
modules
)
failed_modules
.
update
(
modules
)
elif
os
.
path
.
getsize
(
c_file
)
<
200
:
elif
os
.
path
.
getsize
(
c_file
)
<
200
:
...
...
Cython/Build/Inline.py
View file @
38abf1b6
...
@@ -149,8 +149,7 @@ def cython_inline(code,
...
@@ -149,8 +149,7 @@ def cython_inline(code,
if
arg
is
cython_module
:
if
arg
is
cython_module
:
cimports
.
append
(
'
\
n
cimport cython as %s'
%
name
)
cimports
.
append
(
'
\
n
cimport cython as %s'
%
name
)
del
kwds
[
name
]
del
kwds
[
name
]
arg_names
=
kwds
.
keys
()
arg_names
=
sorted
(
kwds
)
arg_names
.
sort
()
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
=
orig_code
,
arg_sigs
,
sys
.
version_info
,
sys
.
executable
,
Cython
.
__version__
key
=
orig_code
,
arg_sigs
,
sys
.
version_info
,
sys
.
executable
,
Cython
.
__version__
module_name
=
"_cython_inline_"
+
hashlib
.
md5
(
str
(
key
).
encode
(
'utf-8'
)).
hexdigest
()
module_name
=
"_cython_inline_"
+
hashlib
.
md5
(
str
(
key
).
encode
(
'utf-8'
)).
hexdigest
()
...
@@ -282,7 +281,7 @@ except ImportError:
...
@@ -282,7 +281,7 @@ except ImportError:
if
kwds
is
not
None
:
if
kwds
is
not
None
:
all
[
kwds
]
=
kwd_values
all
[
kwds
]
=
kwd_values
elif
kwd_values
:
elif
kwd_values
:
raise
TypeError
(
"Unexpected keyword arguments: %s"
%
kwd_values
.
keys
(
))
raise
TypeError
(
"Unexpected keyword arguments: %s"
%
list
(
kwd_values
))
if
defaults
is
None
:
if
defaults
is
None
:
defaults
=
()
defaults
=
()
first_default
=
len
(
args
)
-
len
(
defaults
)
first_default
=
len
(
args
)
-
len
(
defaults
)
...
...
Cython/Compiler/Buffer.py
View file @
38abf1b6
...
@@ -49,25 +49,22 @@ class IntroduceBufferAuxiliaryVars(CythonTransform):
...
@@ -49,25 +49,22 @@ class IntroduceBufferAuxiliaryVars(CythonTransform):
# For all buffers, insert extra variables in the scope.
# For all buffers, insert extra variables in the scope.
# The variables are also accessible from the buffer_info
# The variables are also accessible from the buffer_info
# on the buffer entry
# on the buffer entry
bufvars
=
[
entry
for
name
,
entry
scope_items
=
scope
.
entries
.
items
()
in
scope
.
entries
.
iteritems
()
bufvars
=
[
entry
for
name
,
entry
in
scope_items
if
entry
.
type
.
is_buffer
]
if
entry
.
type
.
is_buffer
]
if
len
(
bufvars
)
>
0
:
if
len
(
bufvars
)
>
0
:
bufvars
.
sort
(
key
=
lambda
entry
:
entry
.
name
)
bufvars
.
sort
(
key
=
lambda
entry
:
entry
.
name
)
self
.
buffers_exists
=
True
self
.
buffers_exists
=
True
memviewslicevars
=
[
entry
for
name
,
entry
memviewslicevars
=
[
entry
for
name
,
entry
in
scope_items
if
entry
.
type
.
is_memoryviewslice
]
in
scope
.
entries
.
iteritems
()
if
entry
.
type
.
is_memoryviewslice
]
if
len
(
memviewslicevars
)
>
0
:
if
len
(
memviewslicevars
)
>
0
:
self
.
buffers_exists
=
True
self
.
buffers_exists
=
True
for
(
name
,
entry
)
in
scope
.
entries
.
iteritems
()
:
for
(
name
,
entry
)
in
scope
_items
:
if
name
==
'memoryview'
and
isinstance
(
entry
.
utility_code_definition
,
CythonUtilityCode
):
if
name
==
'memoryview'
and
isinstance
(
entry
.
utility_code_definition
,
CythonUtilityCode
):
self
.
using_memoryview
=
True
self
.
using_memoryview
=
True
break
break
del
scope_items
if
isinstance
(
node
,
ModuleNode
)
and
len
(
bufvars
)
>
0
:
if
isinstance
(
node
,
ModuleNode
)
and
len
(
bufvars
)
>
0
:
# for now...note that pos is wrong
# for now...note that pos is wrong
...
@@ -143,13 +140,14 @@ def analyse_buffer_options(globalpos, env, posargs, dictargs, defaults=None, nee
...
@@ -143,13 +140,14 @@ def analyse_buffer_options(globalpos, env, posargs, dictargs, defaults=None, nee
if
defaults
is
None
:
if
defaults
is
None
:
defaults
=
buffer_defaults
defaults
=
buffer_defaults
posargs
,
dictargs
=
Interpreter
.
interpret_compiletime_options
(
posargs
,
dictargs
,
type_env
=
env
,
type_args
=
(
0
,
'dtype'
))
posargs
,
dictargs
=
Interpreter
.
interpret_compiletime_options
(
posargs
,
dictargs
,
type_env
=
env
,
type_args
=
(
0
,
'dtype'
))
if
len
(
posargs
)
>
buffer_positional_options_count
:
if
len
(
posargs
)
>
buffer_positional_options_count
:
raise
CompileError
(
posargs
[
-
1
][
1
],
ERR_BUF_TOO_MANY
)
raise
CompileError
(
posargs
[
-
1
][
1
],
ERR_BUF_TOO_MANY
)
options
=
{}
options
=
{}
for
name
,
(
value
,
pos
)
in
dictargs
.
ite
rite
ms
():
for
name
,
(
value
,
pos
)
in
dictargs
.
items
():
if
not
name
in
buffer_options
:
if
not
name
in
buffer_options
:
raise
CompileError
(
pos
,
ERR_BUF_OPTION_UNKNOWN
%
name
)
raise
CompileError
(
pos
,
ERR_BUF_OPTION_UNKNOWN
%
name
)
options
[
name
]
=
value
options
[
name
]
=
value
...
...
Cython/Compiler/Code.py
View file @
38abf1b6
...
@@ -774,9 +774,8 @@ class FunctionState(object):
...
@@ -774,9 +774,8 @@ class FunctionState(object):
error case.
error case.
"""
"""
return [(cname, type)
return [(cname, type)
for (type, manage_ref), freelist in self.temps_free.items()
for (type, manage_ref), freelist in self.temps_free.items() if manage_ref
if manage_ref
for cname in freelist]
for cname in freelist]
def start_collecting_temps(self):
def start_collecting_temps(self):
"""
"""
...
@@ -1303,8 +1302,7 @@ class GlobalState(object):
...
@@ -1303,8 +1302,7 @@ class GlobalState(object):
cleanup
.
putln
(
"Py_CLEAR(%s.method);"
%
cname
)
cleanup
.
putln
(
"Py_CLEAR(%s.method);"
%
cname
)
def
generate_string_constants
(
self
):
def
generate_string_constants
(
self
):
c_consts
=
[
(
len
(
c
.
cname
),
c
.
cname
,
c
)
c_consts
=
[(
len
(
c
.
cname
),
c
.
cname
,
c
)
for
c
in
self
.
string_const_index
.
values
()]
for
c
in
self
.
string_const_index
.
values
()
]
c_consts
.
sort
()
c_consts
.
sort
()
py_strings
=
[]
py_strings
=
[]
...
...
Cython/Compiler/FlowControl.py
View file @
38abf1b6
...
@@ -259,7 +259,7 @@ class ControlFlow(object):
...
@@ -259,7 +259,7 @@ class ControlFlow(object):
for
entry
in
block
.
bounded
:
for
entry
in
block
.
bounded
:
block
.
i_kill
|=
self
.
assmts
[
entry
].
bit
block
.
i_kill
|=
self
.
assmts
[
entry
].
bit
for
assmts
in
self
.
assmts
.
iter
values
():
for
assmts
in
self
.
assmts
.
values
():
self
.
entry_point
.
i_gen
|=
assmts
.
bit
self
.
entry_point
.
i_gen
|=
assmts
.
bit
self
.
entry_point
.
i_output
=
self
.
entry_point
.
i_gen
self
.
entry_point
.
i_output
=
self
.
entry_point
.
i_gen
...
@@ -602,7 +602,7 @@ def check_definitions(flow, compiler_directives):
...
@@ -602,7 +602,7 @@ def check_definitions(flow, compiler_directives):
node
.
cf_maybe_null
=
False
node
.
cf_maybe_null
=
False
# Find uninitialized references and cf-hints
# Find uninitialized references and cf-hints
for
node
,
entry
in
references
.
ite
rite
ms
():
for
node
,
entry
in
references
.
items
():
if
Uninitialized
in
node
.
cf_state
:
if
Uninitialized
in
node
.
cf_state
:
node
.
cf_maybe_null
=
True
node
.
cf_maybe_null
=
True
if
not
entry
.
from_closure
and
len
(
node
.
cf_state
)
==
1
:
if
not
entry
.
from_closure
and
len
(
node
.
cf_state
)
==
1
:
...
...
Cython/Compiler/ModuleNode.py
View file @
38abf1b6
...
@@ -413,7 +413,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -413,7 +413,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
d
.
setdefault
(
cython_lineno
,
[]).
append
(
c_lineno
+
1
)
d
.
setdefault
(
cython_lineno
,
[]).
append
(
c_lineno
+
1
)
tb
.
start
(
'LineNumberMapping'
)
tb
.
start
(
'LineNumberMapping'
)
for
cython_lineno
,
c_linenos
in
sorted
(
d
.
ite
rite
ms
()):
for
cython_lineno
,
c_linenos
in
sorted
(
d
.
items
()):
attrs
=
{
attrs
=
{
'c_linenos'
:
' '
.
join
(
map
(
str
,
c_linenos
)),
'c_linenos'
:
' '
.
join
(
map
(
str
,
c_linenos
)),
'cython_lineno'
:
str
(
cython_lineno
),
'cython_lineno'
:
str
(
cython_lineno
),
...
...
Cython/Compiler/Nodes.py
View file @
38abf1b6
...
@@ -320,7 +320,6 @@ class Node(object):
...
@@ -320,7 +320,6 @@ class Node(object):
else
:
else
:
return
repr
(
x
)
return
repr
(
x
)
attrs
=
[(
key
,
value
)
for
key
,
value
in
self
.
__dict__
.
items
()
if
key
not
in
filter_out
]
attrs
=
[(
key
,
value
)
for
key
,
value
in
self
.
__dict__
.
items
()
if
key
not
in
filter_out
]
if
len
(
attrs
)
==
0
:
if
len
(
attrs
)
==
0
:
return
"<%s (0x%x)>"
%
(
self
.
__class__
.
__name__
,
id
(
self
))
return
"<%s (0x%x)>"
%
(
self
.
__class__
.
__name__
,
id
(
self
))
...
@@ -1945,8 +1944,7 @@ class FuncDefNode(StatNode, BlockNode):
...
@@ -1945,8 +1944,7 @@ class FuncDefNode(StatNode, BlockNode):
# Clean up buffers -- this calls a Python function
# Clean up buffers -- this calls a Python function
# so need to save and restore error state
# so need to save and restore error state
buffers_present
=
len
(
lenv
.
buffer_entries
)
>
0
buffers_present
=
len
(
lenv
.
buffer_entries
)
>
0
memslice_entries
=
[
e
for
e
in
lenv
.
entries
.
itervalues
()
#memslice_entries = [e for e in lenv.entries.values() if e.type.is_memoryviewslice]
if
e
.
type
.
is_memoryviewslice
]
if
buffers_present
:
if
buffers_present
:
code
.
globalstate
.
use_utility_code
(
restore_exception_utility_code
)
code
.
globalstate
.
use_utility_code
(
restore_exception_utility_code
)
code
.
putln
(
"{ PyObject *__pyx_type, *__pyx_value, *__pyx_tb;"
)
code
.
putln
(
"{ PyObject *__pyx_type, *__pyx_value, *__pyx_tb;"
)
...
@@ -7405,7 +7403,7 @@ class FromCImportStatNode(StatNode):
...
@@ -7405,7 +7403,7 @@ class FromCImportStatNode(StatNode):
env
.
add_imported_module
(
module_scope
)
env
.
add_imported_module
(
module_scope
)
for
pos
,
name
,
as_name
,
kind
in
self
.
imported_names
:
for
pos
,
name
,
as_name
,
kind
in
self
.
imported_names
:
if
name
==
"*"
:
if
name
==
"*"
:
for
local_name
,
entry
in
module_scope
.
entries
.
items
(
):
for
local_name
,
entry
in
list
(
module_scope
.
entries
.
items
()
):
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
env
.
add_imported_entry
(
local_name
,
entry
,
pos
)
else
:
else
:
entry
=
module_scope
.
lookup
(
name
)
entry
=
module_scope
.
lookup
(
name
)
...
@@ -7668,7 +7666,7 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -7668,7 +7666,7 @@ class ParallelStatNode(StatNode, ParallelNode):
else
:
else
:
self
.
kwargs
=
{}
self
.
kwargs
=
{}
for
kw
,
val
in
self
.
kwargs
.
ite
rite
ms
():
for
kw
,
val
in
self
.
kwargs
.
items
():
if
kw
not
in
self
.
valid_keyword_arguments
:
if
kw
not
in
self
.
valid_keyword_arguments
:
error
(
self
.
pos
,
"Invalid keyword argument: %s"
%
kw
)
error
(
self
.
pos
,
"Invalid keyword argument: %s"
%
kw
)
else
:
else
:
...
@@ -7709,7 +7707,7 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -7709,7 +7707,7 @@ class ParallelStatNode(StatNode, ParallelNode):
This should be called in a post-order fashion during the
This should be called in a post-order fashion during the
analyse_expressions phase
analyse_expressions phase
"""
"""
for
entry
,
(
pos
,
op
)
in
self
.
assignments
.
ite
rite
ms
():
for
entry
,
(
pos
,
op
)
in
self
.
assignments
.
items
():
if
self
.
is_prange
and
not
self
.
is_parallel
:
if
self
.
is_prange
and
not
self
.
is_parallel
:
# closely nested prange in a with parallel block, disallow
# closely nested prange in a with parallel block, disallow
...
@@ -7826,7 +7824,7 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -7826,7 +7824,7 @@ class ParallelStatNode(StatNode, ParallelNode):
def
initialize_privates_to_nan
(
self
,
code
,
exclude
=
None
):
def
initialize_privates_to_nan
(
self
,
code
,
exclude
=
None
):
first
=
True
first
=
True
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
ite
rite
ms
():
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
items
():
if
not
op
and
(
not
exclude
or
entry
!=
exclude
):
if
not
op
and
(
not
exclude
or
entry
!=
exclude
):
invalid_value
=
entry
.
type
.
invalid_value
()
invalid_value
=
entry
.
type
.
invalid_value
()
...
@@ -8088,7 +8086,7 @@ class ParallelStatNode(StatNode, ParallelNode):
...
@@ -8088,7 +8086,7 @@ class ParallelStatNode(StatNode, ParallelNode):
c
=
self
.
begin_of_parallel_control_block_point
c
=
self
.
begin_of_parallel_control_block_point
temp_count
=
0
temp_count
=
0
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
ite
rite
ms
():
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
items
():
if
not
lastprivate
or
entry
.
type
.
is_pyobject
:
if
not
lastprivate
or
entry
.
type
.
is_pyobject
:
continue
continue
...
@@ -8617,7 +8615,7 @@ class ParallelRangeNode(ParallelStatNode):
...
@@ -8617,7 +8615,7 @@ class ParallelRangeNode(ParallelStatNode):
code
.
putln
(
"#ifdef _OPENMP"
)
code
.
putln
(
"#ifdef _OPENMP"
)
code
.
put
(
"#pragma omp for"
)
code
.
put
(
"#pragma omp for"
)
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
ite
rite
ms
():
for
entry
,
(
op
,
lastprivate
)
in
self
.
privates
.
items
():
# Don't declare the index variable as a reduction
# Don't declare the index variable as a reduction
if
op
and
op
in
"+*-&^|"
and
entry
!=
self
.
target
.
entry
:
if
op
and
op
in
"+*-&^|"
and
entry
!=
self
.
target
.
entry
:
if
entry
.
type
.
is_pyobject
:
if
entry
.
type
.
is_pyobject
:
...
@@ -8737,7 +8735,7 @@ class CnameDecoratorNode(StatNode):
...
@@ -8737,7 +8735,7 @@ class CnameDecoratorNode(StatNode):
scope
.
scope_prefix
=
self
.
cname
+
"_"
scope
.
scope_prefix
=
self
.
cname
+
"_"
for
name
,
entry
in
scope
.
entries
.
ite
rite
ms
():
for
name
,
entry
in
scope
.
entries
.
items
():
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
:
...
...
Cython/Compiler/ParseTreeTransforms.py
View file @
38abf1b6
...
@@ -647,7 +647,7 @@ class InterpretCompilerDirectives(CythonTransform, SkipDeclarations):
...
@@ -647,7 +647,7 @@ class InterpretCompilerDirectives(CythonTransform, SkipDeclarations):
special_methods
=
set
([
'declare'
,
'union'
,
'struct'
,
'typedef'
,
special_methods
=
set
([
'declare'
,
'union'
,
'struct'
,
'typedef'
,
'sizeof'
,
'cast'
,
'pointer'
,
'compiled'
,
'sizeof'
,
'cast'
,
'pointer'
,
'compiled'
,
'NULL'
,
'fused_type'
,
'parallel'
])
'NULL'
,
'fused_type'
,
'parallel'
])
special_methods
.
update
(
unop_method_nodes
.
keys
()
)
special_methods
.
update
(
unop_method_nodes
)
valid_parallel_directives
=
set
([
valid_parallel_directives
=
set
([
"parallel"
,
"parallel"
,
...
@@ -934,7 +934,7 @@ class InterpretCompilerDirectives(CythonTransform, SkipDeclarations):
...
@@ -934,7 +934,7 @@ class InterpretCompilerDirectives(CythonTransform, SkipDeclarations):
directives
=
self
.
_extract_directives
(
node
,
'function'
)
directives
=
self
.
_extract_directives
(
node
,
'function'
)
if
not
directives
:
if
not
directives
:
return
node
return
node
for
name
,
value
in
directives
.
ite
rite
ms
():
for
name
,
value
in
directives
.
items
():
if
name
==
'locals'
:
if
name
==
'locals'
:
node
.
directive_locals
=
value
node
.
directive_locals
=
value
elif
name
not
in
(
'final'
,
'staticmethod'
):
elif
name
not
in
(
'final'
,
'staticmethod'
):
...
@@ -2888,11 +2888,11 @@ class DebugTransform(CythonTransform):
...
@@ -2888,11 +2888,11 @@ class DebugTransform(CythonTransform):
self
.
tb
.
start
(
'Globals'
)
self
.
tb
.
start
(
'Globals'
)
entries
=
{}
entries
=
{}
for
k
,
v
in
node
.
scope
.
entries
.
ite
rite
ms
():
for
k
,
v
in
node
.
scope
.
entries
.
items
():
if
(
v
.
qualified_name
not
in
self
.
visited
and
not
if
(
v
.
qualified_name
not
in
self
.
visited
and
not
v
.
name
.
startswith
(
'__pyx_'
)
and
not
v
.
name
.
startswith
(
'__pyx_'
)
and
not
v
.
type
.
is_cfunction
and
not
v
.
type
.
is_cfunction
and
not
v
.
type
.
is_extension_type
):
v
.
type
.
is_extension_type
):
entries
[
k
]
=
v
entries
[
k
]
=
v
self
.
serialize_local_variables
(
entries
)
self
.
serialize_local_variables
(
entries
)
...
...
Cython/Compiler/Pipeline.py
View file @
38abf1b6
...
@@ -57,7 +57,7 @@ def generate_pyx_code_stage_factory(options, result):
...
@@ -57,7 +57,7 @@ def generate_pyx_code_stage_factory(options, result):
def
inject_pxd_code_stage_factory
(
context
):
def
inject_pxd_code_stage_factory
(
context
):
def
inject_pxd_code_stage
(
module_node
):
def
inject_pxd_code_stage
(
module_node
):
for
name
,
(
statlistnode
,
scope
)
in
context
.
pxds
.
ite
rite
ms
():
for
name
,
(
statlistnode
,
scope
)
in
context
.
pxds
.
items
():
module_node
.
merge_in
(
statlistnode
,
scope
)
module_node
.
merge_in
(
statlistnode
,
scope
)
return
module_node
return
module_node
return
inject_pxd_code_stage
return
inject_pxd_code_stage
...
@@ -66,7 +66,7 @@ def use_utility_code_definitions(scope, target, seen=None):
...
@@ -66,7 +66,7 @@ def use_utility_code_definitions(scope, target, seen=None):
if
seen
is
None
:
if
seen
is
None
:
seen
=
set
()
seen
=
set
()
for
entry
in
scope
.
entries
.
iter
values
():
for
entry
in
scope
.
entries
.
values
():
if
entry
in
seen
:
if
entry
in
seen
:
continue
continue
...
...
Cython/Compiler/PyrexTypes.py
View file @
38abf1b6
...
@@ -4123,7 +4123,7 @@ def merge_template_deductions(a, b):
...
@@ -4123,7 +4123,7 @@ def merge_template_deductions(a, b):
if
a
is
None
or
b
is
None
:
if
a
is
None
or
b
is
None
:
return
None
return
None
all
=
a
all
=
a
for
param
,
value
in
b
.
ite
rite
ms
():
for
param
,
value
in
b
.
items
():
if
param
in
all
:
if
param
in
all
:
if
a
[
param
]
!=
b
[
param
]:
if
a
[
param
]
!=
b
[
param
]:
return
None
return
None
...
...
Cython/Compiler/Symtab.py
View file @
38abf1b6
...
@@ -344,7 +344,7 @@ class Scope(object):
...
@@ -344,7 +344,7 @@ class Scope(object):
def
merge_in
(
self
,
other
,
merge_unused
=
True
,
whitelist
=
None
):
def
merge_in
(
self
,
other
,
merge_unused
=
True
,
whitelist
=
None
):
# Use with care...
# Use with care...
entries
=
[]
entries
=
[]
for
name
,
entry
in
other
.
entries
.
ite
rite
ms
():
for
name
,
entry
in
other
.
entries
.
items
():
if
not
whitelist
or
name
in
whitelist
:
if
not
whitelist
or
name
in
whitelist
:
if
entry
.
used
or
merge_unused
:
if
entry
.
used
or
merge_unused
:
entries
.
append
((
name
,
entry
))
entries
.
append
((
name
,
entry
))
...
@@ -899,7 +899,7 @@ class BuiltinScope(Scope):
...
@@ -899,7 +899,7 @@ class BuiltinScope(Scope):
Scope
.
__init__
(
self
,
"__builtin__"
,
PreImportScope
(),
None
)
Scope
.
__init__
(
self
,
"__builtin__"
,
PreImportScope
(),
None
)
self
.
type_names
=
{}
self
.
type_names
=
{}
for
name
,
definition
in
s
elf
.
builtin_entries
.
iteritems
(
):
for
name
,
definition
in
s
orted
(
self
.
builtin_entries
.
items
()
):
cname
,
type
=
definition
cname
,
type
=
definition
self
.
declare_var
(
name
,
type
,
None
,
cname
)
self
.
declare_var
(
name
,
type
,
None
,
cname
)
...
...
Cython/Compiler/TreeFragment.py
View file @
38abf1b6
...
@@ -219,7 +219,7 @@ class TreeFragment(object):
...
@@ -219,7 +219,7 @@ class TreeFragment(object):
fmt_code
=
fmt
(
code
)
fmt_code
=
fmt
(
code
)
fmt_pxds
=
{}
fmt_pxds
=
{}
for
key
,
value
in
pxds
.
ite
rite
ms
():
for
key
,
value
in
pxds
.
items
():
fmt_pxds
[
key
]
=
fmt
(
value
)
fmt_pxds
[
key
]
=
fmt
(
value
)
mod
=
t
=
parse_from_strings
(
name
,
fmt_code
,
fmt_pxds
,
level
=
level
,
initial_pos
=
initial_pos
)
mod
=
t
=
parse_from_strings
(
name
,
fmt_code
,
fmt_pxds
,
level
=
level
,
initial_pos
=
initial_pos
)
if
level
is
None
:
if
level
is
None
:
...
...
Cython/Compiler/TypeSlots.py
View file @
38abf1b6
...
@@ -71,7 +71,7 @@ class Signature(object):
...
@@ -71,7 +71,7 @@ class Signature(object):
}
}
type_to_format_map
=
dict
(
type_to_format_map
=
dict
(
(
type_
,
format_
)
for
format_
,
type_
in
format_map
.
ite
rite
ms
())
(
type_
,
format_
)
for
format_
,
type_
in
format_map
.
items
())
error_value_map
=
{
error_value_map
=
{
'O'
:
"NULL"
,
'O'
:
"NULL"
,
...
...
Cython/Compiler/UtilityCode.py
View file @
38abf1b6
...
@@ -186,7 +186,7 @@ class CythonUtilityCode(Code.UtilityCodeBase):
...
@@ -186,7 +186,7 @@ class CythonUtilityCode(Code.UtilityCodeBase):
entries
.
pop
(
'__builtins__'
)
entries
.
pop
(
'__builtins__'
)
entries
.
pop
(
'__doc__'
)
entries
.
pop
(
'__doc__'
)
for
name
,
entry
in
entries
.
ite
rite
ms
():
for
name
,
entry
in
entries
.
items
():
entry
.
utility_code_definition
=
self
entry
.
utility_code_definition
=
self
entry
.
used
=
used
entry
.
used
=
used
...
...
Cython/Compiler/Visitor.py
View file @
38abf1b6
...
@@ -249,7 +249,7 @@ class VisitorTransform(TreeVisitor):
...
@@ -249,7 +249,7 @@ class VisitorTransform(TreeVisitor):
"""
"""
def
visitchildren
(
self
,
parent
,
attrs
=
None
):
def
visitchildren
(
self
,
parent
,
attrs
=
None
):
result
=
self
.
_visitchildren
(
parent
,
attrs
)
result
=
self
.
_visitchildren
(
parent
,
attrs
)
for
attr
,
newnode
in
result
.
ite
rite
ms
():
for
attr
,
newnode
in
result
.
items
():
if
type
(
newnode
)
is
not
list
:
if
type
(
newnode
)
is
not
list
:
setattr
(
parent
,
attr
,
newnode
)
setattr
(
parent
,
attr
,
newnode
)
else
:
else
:
...
...
Cython/Debugger/Tests/test_libcython_in_gdb.py
View file @
38abf1b6
...
@@ -45,7 +45,7 @@ def print_on_call_decorator(func):
...
@@ -45,7 +45,7 @@ def print_on_call_decorator(func):
class
TraceMethodCallMeta
(
type
):
class
TraceMethodCallMeta
(
type
):
def
__init__
(
self
,
name
,
bases
,
dict
):
def
__init__
(
self
,
name
,
bases
,
dict
):
for
func_name
,
func
in
dict
.
ite
rite
ms
():
for
func_name
,
func
in
dict
.
items
():
if
inspect
.
isfunction
(
func
):
if
inspect
.
isfunction
(
func
):
setattr
(
self
,
func_name
,
print_on_call_decorator
(
func
))
setattr
(
self
,
func_name
,
print_on_call_decorator
(
func
))
...
...
Cython/Debugger/libcython.py
View file @
38abf1b6
...
@@ -381,7 +381,7 @@ class CythonBase(object):
...
@@ -381,7 +381,7 @@ class CythonBase(object):
result
=
{}
result
=
{}
seen
=
set
()
seen
=
set
()
for
k
,
v
in
pyobject_dict
.
ite
rite
ms
():
for
k
,
v
in
pyobject_dict
.
items
():
result
[
k
.
proxyval
(
seen
)]
=
v
result
[
k
.
proxyval
(
seen
)]
=
v
return
result
return
result
...
@@ -849,10 +849,10 @@ class CyBreak(CythonCommand):
...
@@ -849,10 +849,10 @@ class CyBreak(CythonCommand):
def
complete
(
self
,
text
,
word
):
def
complete
(
self
,
text
,
word
):
# Filter init-module functions (breakpoints can be set using
# Filter init-module functions (breakpoints can be set using
# modulename:linenumber).
# modulename:linenumber).
names
=
[
n
for
n
,
L
in
self
.
cy
.
functions_by_name
.
ite
rite
ms
()
names
=
[
n
for
n
,
L
in
self
.
cy
.
functions_by_name
.
items
()
if
any
(
not
f
.
is_initmodule_function
for
f
in
L
)]
if
any
(
not
f
.
is_initmodule_function
for
f
in
L
)]
qnames
=
[
n
for
n
,
f
in
self
.
cy
.
functions_by_qualified_name
.
ite
rite
ms
()
qnames
=
[
n
for
n
,
f
in
self
.
cy
.
functions_by_qualified_name
.
items
()
if
not
f
.
is_initmodule_function
]
if
not
f
.
is_initmodule_function
]
if
parameters
.
complete_unqualified
:
if
parameters
.
complete_unqualified
:
all_names
=
itertools
.
chain
(
qnames
,
names
)
all_names
=
itertools
.
chain
(
qnames
,
names
)
...
@@ -1142,7 +1142,7 @@ class CyLocals(CythonCommand):
...
@@ -1142,7 +1142,7 @@ class CyLocals(CythonCommand):
local_cython_vars
=
cython_function
.
locals
local_cython_vars
=
cython_function
.
locals
max_name_length
=
len
(
max
(
local_cython_vars
,
key
=
len
))
max_name_length
=
len
(
max
(
local_cython_vars
,
key
=
len
))
for
name
,
cyvar
in
sorted
(
local_cython_vars
.
ite
rite
ms
(),
key
=
sortkey
):
for
name
,
cyvar
in
sorted
(
local_cython_vars
.
items
(),
key
=
sortkey
):
if
self
.
is_initialized
(
self
.
get_cython_function
(),
cyvar
.
name
):
if
self
.
is_initialized
(
self
.
get_cython_function
(),
cyvar
.
name
):
value
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
value
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
if
not
value
.
is_optimized_out
:
if
not
value
.
is_optimized_out
:
...
@@ -1175,13 +1175,13 @@ class CyGlobals(CyLocals):
...
@@ -1175,13 +1175,13 @@ class CyGlobals(CyLocals):
seen
=
set
()
seen
=
set
()
print
(
'Python globals:'
)
print
(
'Python globals:'
)
for
k
,
v
in
sorted
(
global_python_dict
.
ite
rite
ms
(),
key
=
sortkey
):
for
k
,
v
in
sorted
(
global_python_dict
.
items
(),
key
=
sortkey
):
v
=
v
.
get_truncated_repr
(
libpython
.
MAX_OUTPUT_LEN
)
v
=
v
.
get_truncated_repr
(
libpython
.
MAX_OUTPUT_LEN
)
seen
.
add
(
k
)
seen
.
add
(
k
)
print
(
' %-*s = %s'
%
(
max_name_length
,
k
,
v
))
print
(
' %-*s = %s'
%
(
max_name_length
,
k
,
v
))
print
(
'C globals:'
)
print
(
'C globals:'
)
for
name
,
cyvar
in
sorted
(
module_globals
.
ite
rite
ms
(),
key
=
sortkey
):
for
name
,
cyvar
in
sorted
(
module_globals
.
items
(),
key
=
sortkey
):
if
name
not
in
seen
:
if
name
not
in
seen
:
try
:
try
:
value
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
value
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
...
@@ -1204,10 +1204,8 @@ class EvaluateOrExecuteCodeMixin(object):
...
@@ -1204,10 +1204,8 @@ class EvaluateOrExecuteCodeMixin(object):
"Fill a remotely allocated dict with values from the Cython C stack"
"Fill a remotely allocated dict with values from the Cython C stack"
cython_func
=
self
.
get_cython_function
()
cython_func
=
self
.
get_cython_function
()
for
name
,
cyvar
in
cython_func
.
locals
.
iteritems
():
for
name
,
cyvar
in
cython_func
.
locals
.
items
():
if
(
cyvar
.
type
==
PythonObject
and
if
cyvar
.
type
==
PythonObject
and
self
.
is_initialized
(
cython_func
,
name
):
self
.
is_initialized
(
cython_func
,
name
)):
try
:
try
:
val
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
val
=
gdb
.
parse_and_eval
(
cyvar
.
cname
)
except
RuntimeError
:
except
RuntimeError
:
...
...
Cython/Debugger/libpython.py
View file @
38abf1b6
...
@@ -463,7 +463,7 @@ def _write_instance_repr(out, visited, name, pyop_attrdict, address):
...
@@ -463,7 +463,7 @@ def _write_instance_repr(out, visited, name, pyop_attrdict, address):
if
isinstance
(
pyop_attrdict
,
PyDictObjectPtr
):
if
isinstance
(
pyop_attrdict
,
PyDictObjectPtr
):
out
.
write
(
'('
)
out
.
write
(
'('
)
first
=
True
first
=
True
for
pyop_arg
,
pyop_val
in
pyop_attrdict
.
ite
rite
ms
():
for
pyop_arg
,
pyop_val
in
pyop_attrdict
.
items
():
if
not
first
:
if
not
first
:
out
.
write
(
', '
)
out
.
write
(
', '
)
first
=
False
first
=
False
...
@@ -483,8 +483,7 @@ class InstanceProxy(object):
...
@@ -483,8 +483,7 @@ class InstanceProxy(object):
def
__repr__
(
self
):
def
__repr__
(
self
):
if
isinstance
(
self
.
attrdict
,
dict
):
if
isinstance
(
self
.
attrdict
,
dict
):
kwargs
=
', '
.
join
(
"%s=%r"
%
(
arg
,
val
)
kwargs
=
', '
.
join
(
"%s=%r"
%
(
arg
,
val
)
for
arg
,
val
in
self
.
attrdict
.
items
())
for
arg
,
val
in
self
.
attrdict
.
iteritems
())
return
'<%s(%s) at remote 0x%x>'
%
(
return
'<%s(%s) at remote 0x%x>'
%
(
self
.
cl_name
,
kwargs
,
self
.
address
)
self
.
cl_name
,
kwargs
,
self
.
address
)
else
:
else
:
...
@@ -693,7 +692,7 @@ class PyDictObjectPtr(PyObjectPtr):
...
@@ -693,7 +692,7 @@ class PyDictObjectPtr(PyObjectPtr):
def
iteritems
(
self
):
def
iteritems
(
self
):
'''
'''
Yields a sequence of (PyObjectPtr key, PyObjectPtr value) pairs,
Yields a sequence of (PyObjectPtr key, PyObjectPtr value) pairs,
analagous to dict.ite
rite
ms()
analagous to dict.items()
'''
'''
for
i
in
safe_range
(
self
.
field
(
'ma_mask'
)
+
1
):
for
i
in
safe_range
(
self
.
field
(
'ma_mask'
)
+
1
):
ep
=
self
.
field
(
'ma_table'
)
+
i
ep
=
self
.
field
(
'ma_table'
)
+
i
...
@@ -702,6 +701,8 @@ class PyDictObjectPtr(PyObjectPtr):
...
@@ -702,6 +701,8 @@ class PyDictObjectPtr(PyObjectPtr):
pyop_key
=
PyObjectPtr
.
from_pyobject_ptr
(
ep
[
'me_key'
])
pyop_key
=
PyObjectPtr
.
from_pyobject_ptr
(
ep
[
'me_key'
])
yield
(
pyop_key
,
pyop_value
)
yield
(
pyop_key
,
pyop_value
)
items
=
iteritems
def
proxyval
(
self
,
visited
):
def
proxyval
(
self
,
visited
):
# Guard against infinite loops:
# Guard against infinite loops:
if
self
.
as_address
()
in
visited
:
if
self
.
as_address
()
in
visited
:
...
@@ -709,7 +710,7 @@ class PyDictObjectPtr(PyObjectPtr):
...
@@ -709,7 +710,7 @@ class PyDictObjectPtr(PyObjectPtr):
visited
.
add
(
self
.
as_address
())
visited
.
add
(
self
.
as_address
())
result
=
{}
result
=
{}
for
pyop_key
,
pyop_value
in
self
.
ite
rite
ms
():
for
pyop_key
,
pyop_value
in
self
.
items
():
proxy_key
=
pyop_key
.
proxyval
(
visited
)
proxy_key
=
pyop_key
.
proxyval
(
visited
)
proxy_value
=
pyop_value
.
proxyval
(
visited
)
proxy_value
=
pyop_value
.
proxyval
(
visited
)
result
[
proxy_key
]
=
proxy_value
result
[
proxy_key
]
=
proxy_value
...
@@ -724,7 +725,7 @@ class PyDictObjectPtr(PyObjectPtr):
...
@@ -724,7 +725,7 @@ class PyDictObjectPtr(PyObjectPtr):
out
.
write
(
'{'
)
out
.
write
(
'{'
)
first
=
True
first
=
True
for
pyop_key
,
pyop_value
in
self
.
ite
rite
ms
():
for
pyop_key
,
pyop_value
in
self
.
items
():
if
not
first
:
if
not
first
:
out
.
write
(
', '
)
out
.
write
(
', '
)
first
=
False
first
=
False
...
@@ -924,7 +925,7 @@ class PyFrameObjectPtr(PyObjectPtr):
...
@@ -924,7 +925,7 @@ class PyFrameObjectPtr(PyObjectPtr):
return
return
pyop_globals
=
self
.
pyop_field
(
'f_globals'
)
pyop_globals
=
self
.
pyop_field
(
'f_globals'
)
return
pyop_globals
.
iteritems
(
)
return
iter
(
pyop_globals
.
items
()
)
def
iter_builtins
(
self
):
def
iter_builtins
(
self
):
'''
'''
...
@@ -935,7 +936,7 @@ class PyFrameObjectPtr(PyObjectPtr):
...
@@ -935,7 +936,7 @@ class PyFrameObjectPtr(PyObjectPtr):
return
return
pyop_builtins
=
self
.
pyop_field
(
'f_builtins'
)
pyop_builtins
=
self
.
pyop_field
(
'f_builtins'
)
return
pyop_builtins
.
iteritems
(
)
return
iter
(
pyop_builtins
.
items
()
)
def
get_var_by_name
(
self
,
name
):
def
get_var_by_name
(
self
,
name
):
'''
'''
...
...
Cython/Distutils/extension.py
View file @
38abf1b6
...
@@ -45,7 +45,7 @@ class Extension(_Extension.Extension):
...
@@ -45,7 +45,7 @@ class Extension(_Extension.Extension):
# Translate pyrex_X to cython_X for backwards compatibility.
# Translate pyrex_X to cython_X for backwards compatibility.
had_pyrex_options
=
False
had_pyrex_options
=
False
for
key
in
kw
.
keys
(
):
for
key
in
list
(
kw
):
if
key
.
startswith
(
'pyrex_'
):
if
key
.
startswith
(
'pyrex_'
):
had_pyrex_options
=
True
had_pyrex_options
=
True
kw
[
'cython'
+
key
[
5
:]]
=
kw
.
pop
(
key
)
kw
[
'cython'
+
key
[
5
:]]
=
kw
.
pop
(
key
)
...
...
Cython/Plex/DFA.py
View file @
38abf1b6
...
@@ -32,7 +32,7 @@ def nfa_to_dfa(old_machine, debug=None):
...
@@ -32,7 +32,7 @@ def nfa_to_dfa(old_machine, debug=None):
# Seed the process using the initial states of the old machine.
# Seed the process using the initial states of the old machine.
# Make the corresponding new states into initial states of the new
# Make the corresponding new states into initial states of the new
# machine with the same names.
# machine with the same names.
for
(
key
,
old_state
)
in
old_machine
.
initial_states
.
ite
rite
ms
():
for
(
key
,
old_state
)
in
old_machine
.
initial_states
.
items
():
new_state
=
state_map
.
old_to_new
(
epsilon_closure
(
old_state
))
new_state
=
state_map
.
old_to_new
(
epsilon_closure
(
old_state
))
new_machine
.
make_initial_state
(
key
,
new_state
)
new_machine
.
make_initial_state
(
key
,
new_state
)
# Tricky bit here: we add things to the end of this list while we're
# Tricky bit here: we add things to the end of this list while we're
...
@@ -40,10 +40,10 @@ def nfa_to_dfa(old_machine, debug=None):
...
@@ -40,10 +40,10 @@ def nfa_to_dfa(old_machine, debug=None):
for
new_state
in
new_machine
.
states
:
for
new_state
in
new_machine
.
states
:
transitions
=
TransitionMap
()
transitions
=
TransitionMap
()
for
old_state
in
state_map
.
new_to_old
(
new_state
):
for
old_state
in
state_map
.
new_to_old
(
new_state
):
for
event
,
old_target_states
in
old_state
.
transitions
.
ite
rite
ms
():
for
event
,
old_target_states
in
old_state
.
transitions
.
items
():
if
event
and
old_target_states
:
if
event
and
old_target_states
:
transitions
.
add_set
(
event
,
set_epsilon_closure
(
old_target_states
))
transitions
.
add_set
(
event
,
set_epsilon_closure
(
old_target_states
))
for
event
,
old_states
in
transitions
.
ite
rite
ms
():
for
event
,
old_states
in
transitions
.
items
():
new_machine
.
add_transitions
(
new_state
,
event
,
state_map
.
old_to_new
(
old_states
))
new_machine
.
add_transitions
(
new_state
,
event
,
state_map
.
old_to_new
(
old_states
))
if
debug
:
if
debug
:
debug
.
write
(
"
\
n
===== State Mapping =====
\
n
"
)
debug
.
write
(
"
\
n
===== State Mapping =====
\
n
"
)
...
...
Cython/Plex/Machines.py
View file @
38abf1b6
...
@@ -59,7 +59,7 @@ class Machine(object):
...
@@ -59,7 +59,7 @@ class Machine(object):
file
.
write
(
"Plex.Machine:
\
n
"
)
file
.
write
(
"Plex.Machine:
\
n
"
)
if
self
.
initial_states
is
not
None
:
if
self
.
initial_states
is
not
None
:
file
.
write
(
" Initial states:
\
n
"
)
file
.
write
(
" Initial states:
\
n
"
)
for
(
name
,
state
)
in
s
elf
.
initial_states
.
iteritems
(
):
for
(
name
,
state
)
in
s
orted
(
self
.
initial_states
.
items
()
):
file
.
write
(
" '%s': %d
\
n
"
%
(
name
,
state
.
number
))
file
.
write
(
" '%s': %d
\
n
"
%
(
name
,
state
.
number
))
for
s
in
self
.
states
:
for
s
in
self
.
states
:
s
.
dump
(
file
)
s
.
dump
(
file
)
...
@@ -150,11 +150,11 @@ class FastMachine(object):
...
@@ -150,11 +150,11 @@ class FastMachine(object):
for
old_state
in
old_machine
.
states
:
for
old_state
in
old_machine
.
states
:
new_state
=
self
.
new_state
()
new_state
=
self
.
new_state
()
old_to_new
[
old_state
]
=
new_state
old_to_new
[
old_state
]
=
new_state
for
name
,
old_state
in
old_machine
.
initial_states
.
ite
rite
ms
():
for
name
,
old_state
in
old_machine
.
initial_states
.
items
():
initial_states
[
name
]
=
old_to_new
[
old_state
]
initial_states
[
name
]
=
old_to_new
[
old_state
]
for
old_state
in
old_machine
.
states
:
for
old_state
in
old_machine
.
states
:
new_state
=
old_to_new
[
old_state
]
new_state
=
old_to_new
[
old_state
]
for
event
,
old_state_set
in
old_state
.
transitions
.
ite
rite
ms
():
for
event
,
old_state_set
in
old_state
.
transitions
.
items
():
if
old_state_set
:
if
old_state_set
:
new_state
[
event
]
=
old_to_new
[
old_state_set
.
keys
()[
0
]]
new_state
[
event
]
=
old_to_new
[
old_state_set
.
keys
()[
0
]]
else
:
else
:
...
@@ -195,7 +195,7 @@ class FastMachine(object):
...
@@ -195,7 +195,7 @@ class FastMachine(object):
def
dump
(
self
,
file
):
def
dump
(
self
,
file
):
file
.
write
(
"Plex.FastMachine:
\
n
"
)
file
.
write
(
"Plex.FastMachine:
\
n
"
)
file
.
write
(
" Initial states:
\
n
"
)
file
.
write
(
" Initial states:
\
n
"
)
for
name
,
state
in
s
elf
.
initial_states
.
iteritems
(
):
for
name
,
state
in
s
orted
(
self
.
initial_states
.
items
()
):
file
.
write
(
" %s: %s
\
n
"
%
(
repr
(
name
),
state
[
'number'
]))
file
.
write
(
" %s: %s
\
n
"
%
(
repr
(
name
),
state
[
'number'
]))
for
state
in
self
.
states
:
for
state
in
self
.
states
:
self
.
dump_state
(
state
,
file
)
self
.
dump_state
(
state
,
file
)
...
@@ -213,7 +213,7 @@ class FastMachine(object):
...
@@ -213,7 +213,7 @@ class FastMachine(object):
def
dump_transitions
(
self
,
state
,
file
):
def
dump_transitions
(
self
,
state
,
file
):
chars_leading_to_state
=
{}
chars_leading_to_state
=
{}
special_to_state
=
{}
special_to_state
=
{}
for
(
c
,
s
)
in
state
.
ite
rite
ms
():
for
(
c
,
s
)
in
state
.
items
():
if
len
(
c
)
==
1
:
if
len
(
c
)
==
1
:
chars
=
chars_leading_to_state
.
get
(
id
(
s
),
None
)
chars
=
chars_leading_to_state
.
get
(
id
(
s
),
None
)
if
chars
is
None
:
if
chars
is
None
:
...
...
Cython/Plex/Transitions.py
View file @
38abf1b6
...
@@ -110,7 +110,7 @@ class TransitionMap(object):
...
@@ -110,7 +110,7 @@ class TransitionMap(object):
result
.
append
(((
code0
,
code1
),
set
))
result
.
append
(((
code0
,
code1
),
set
))
code0
=
code1
code0
=
code1
i
+=
2
i
+=
2
for
event
,
set
in
self
.
special
.
ite
rite
ms
():
for
event
,
set
in
self
.
special
.
items
():
if
set
:
if
set
:
result
.
append
((
event
,
set
))
result
.
append
((
event
,
set
))
return
iter
(
result
)
return
iter
(
result
)
...
@@ -182,7 +182,7 @@ class TransitionMap(object):
...
@@ -182,7 +182,7 @@ class TransitionMap(object):
map_strs
.
append
(
state_set_str
(
map
[
i
]))
map_strs
.
append
(
state_set_str
(
map
[
i
]))
i
+=
1
i
+=
1
special_strs
=
{}
special_strs
=
{}
for
event
,
set
in
self
.
special
.
ite
rite
ms
():
for
event
,
set
in
self
.
special
.
items
():
special_strs
[
event
]
=
state_set_str
(
set
)
special_strs
[
event
]
=
state_set_str
(
set
)
return
"[%s]+%s"
%
(
return
"[%s]+%s"
%
(
','
.
join
(
map_strs
),
','
.
join
(
map_strs
),
...
@@ -204,7 +204,7 @@ class TransitionMap(object):
...
@@ -204,7 +204,7 @@ class TransitionMap(object):
while
i
<
n
:
while
i
<
n
:
self
.
dump_range
(
map
[
i
],
map
[
i
+
2
],
map
[
i
+
1
],
file
)
self
.
dump_range
(
map
[
i
],
map
[
i
+
2
],
map
[
i
+
1
],
file
)
i
+=
2
i
+=
2
for
event
,
set
in
self
.
special
.
ite
rite
ms
():
for
event
,
set
in
self
.
special
.
items
():
if
set
:
if
set
:
if
not
event
:
if
not
event
:
event
=
'empty'
event
=
'empty'
...
...
Cython/Tempita/_tempita.py
View file @
38abf1b6
...
@@ -202,7 +202,7 @@ class Template(object):
...
@@ -202,7 +202,7 @@ class Template(object):
position=None, name=self.name)
position=None, name=self.name)
templ = self.get_template(inherit_template, self)
templ = self.get_template(inherit_template, self)
self_ = TemplateObject(self.name)
self_ = TemplateObject(self.name)
for name, value in defs.ite
rite
ms():
for name, value in defs.items():
setattr(self_, name, value)
setattr(self_, name, value)
self_.body = body
self_.body = body
ns = ns.copy()
ns = ns.copy()
...
@@ -391,7 +391,7 @@ def paste_script_template_renderer(content, vars, filename=None):
...
@@ -391,7 +391,7 @@ def paste_script_template_renderer(content, vars, filename=None):
class bunch(dict):
class bunch(dict):
def __init__(self, **kw):
def __init__(self, **kw):
for name, value in kw.ite
rite
ms():
for name, value in kw.items():
setattr(self, name, value)
setattr(self, name, value)
def __setattr__(self, name, value):
def __setattr__(self, name, value):
...
@@ -413,12 +413,9 @@ class bunch(dict):
...
@@ -413,12 +413,9 @@ class bunch(dict):
return dict.__getitem__(self, key)
return dict.__getitem__(self, key)
def __repr__(self):
def __repr__(self):
items = [
(k, v) for k, v in self.iteritems()]
items.sort()
return '
<%
s
%
s
>
' % (
return '
<%
s
%
s
>
' % (
self.__class__.__name__,
self.__class__.__name__,
'
'.join(['
%
s
=%
r' % (k, v) for k, v in
items
]))
'
'.join(['
%
s
=%
r' % (k, v) for k, v in
sorted(self.items())
]))
############################################################
############################################################
## HTML Templating
## HTML Templating
...
@@ -467,10 +464,8 @@ def url(v):
...
@@ -467,10 +464,8 @@ def url(v):
def attr(**kw):
def attr(**kw):
kw = list(kw.iteritems())
kw.sort()
parts = []
parts = []
for name, value in
kw
:
for name, value in
sorted(kw.items())
:
if value is None:
if value is None:
continue
continue
if name.endswith('
_
'):
if name.endswith('
_
'):
...
@@ -549,7 +544,7 @@ class TemplateDef(object):
...
@@ -549,7 +544,7 @@ class TemplateDef(object):
values = {}
values = {}
sig_args, var_args, var_kw, defaults = self._func_signature
sig_args, var_args, var_kw, defaults = self._func_signature
extra_kw = {}
extra_kw = {}
for name, value in kw.ite
rite
ms():
for name, value in kw.items():
if not var_kw and name not in sig_args:
if not var_kw and name not in sig_args:
raise TypeError(
raise TypeError(
'
Unexpected
argument
%
s
' % name)
'
Unexpected
argument
%
s
' % name)
...
@@ -572,7 +567,7 @@ class TemplateDef(object):
...
@@ -572,7 +567,7 @@ class TemplateDef(object):
raise TypeError(
raise TypeError(
'
Extra
position
arguments
:
%
s
'
'
Extra
position
arguments
:
%
s
'
% '
,
'.join([repr(v) for v in args]))
% '
,
'.join([repr(v) for v in args]))
for name, value_expr in defaults.ite
rite
ms():
for name, value_expr in defaults.items():
if name not in values:
if name not in values:
values[name] = self._template._eval(
values[name] = self._template._eval(
value_expr, self._ns, self._pos)
value_expr, self._ns, self._pos)
...
...
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