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
dd000240
Commit
dd000240
authored
May 17, 2008
by
Dag Sverre Seljebotn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Usability fixes in Transform
parent
2673725c
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
35 additions
and
24 deletions
+35
-24
Cython/Compiler/Transform.py
Cython/Compiler/Transform.py
+35
-24
No files found.
Cython/Compiler/Transform.py
View file @
dd000240
...
@@ -6,16 +6,14 @@ import ExprNodes
...
@@ -6,16 +6,14 @@ import ExprNodes
import
inspect
import
inspect
class
Transform
(
object
):
class
Transform
(
object
):
# parent_stack [Node] A stack providing information about where in the tree
# parent The parent node of the currently processed node.
# we currently are. Nodes here should be considered
# access_path [(Node, str, int|None)]
# read-only.
# A stack providing information about where in the tree
#
# we are located.
# attr_stack [(string,int|None)]
# The first tuple item is the a node in the tree (parent nodes).
# A stack providing information about the attribute names
# The second tuple item is the attribute name followed, while
# followed to get to the current location in the tree.
# the third is the index if the attribute is a list, or
# The first tuple item is the attribute name, the second is
# None otherwise.
# the index if the attribute is a list, or None otherwise.
#
#
#
# Additionally, any keyword arguments to __call__ will be set as fields while in
# Additionally, any keyword arguments to __call__ will be set as fields while in
# a transformation.
# a transformation.
...
@@ -29,34 +27,38 @@ class Transform(object):
...
@@ -29,34 +27,38 @@ class Transform(object):
# return the input node untouched. Returning None will remove the node from the
# return the input node untouched. Returning None will remove the node from the
# parent.
# parent.
def
process_children
(
self
,
node
):
def
process_children
(
self
,
node
,
attrnames
=
None
):
"""For all children of node, either process_list (if isinstance(node, list))
"""For all children of node, either process_list (if isinstance(node, list))
or process_node (otherwise) is called."""
or process_node (otherwise) is called."""
if
node
==
None
:
return
if
node
==
None
:
return
self
.
parent_stack
.
append
(
node
)
oldparent
=
self
.
parent
self
.
parent
=
node
for
childacc
in
node
.
get_child_accessors
():
for
childacc
in
node
.
get_child_accessors
():
attrname
=
childacc
.
name
()
if
attrnames
is
not
None
and
attrname
not
in
attrnames
:
continue
child
=
childacc
.
get
()
child
=
childacc
.
get
()
if
isinstance
(
child
,
list
):
if
isinstance
(
child
,
list
):
newchild
=
self
.
process_list
(
child
,
childacc
.
name
()
)
newchild
=
self
.
process_list
(
child
,
attrname
)
if
not
isinstance
(
newchild
,
list
):
raise
Exception
(
"Cannot replace list with non-list!"
)
if
not
isinstance
(
newchild
,
list
):
raise
Exception
(
"Cannot replace list with non-list!"
)
else
:
else
:
self
.
a
ttr_stack
.
append
((
childacc
.
name
()
,
None
))
self
.
a
ccess_path
.
append
((
node
,
attrname
,
None
))
newchild
=
self
.
process_node
(
child
)
newchild
=
self
.
process_node
(
child
)
if
newchild
is
not
None
and
not
isinstance
(
newchild
,
Nodes
.
Node
):
if
newchild
is
not
None
and
not
isinstance
(
newchild
,
Nodes
.
Node
):
raise
Exception
(
"Cannot replace Node with non-Node!"
)
raise
Exception
(
"Cannot replace Node with non-Node!"
)
self
.
a
ttr_stack
.
pop
()
self
.
a
ccess_path
.
pop
()
childacc
.
set
(
newchild
)
childacc
.
set
(
newchild
)
self
.
parent
_stack
.
pop
()
self
.
parent
=
oldparent
def
process_list
(
self
,
l
,
attrname
):
def
process_list
(
self
,
l
,
attrname
):
"""Calls process_node on all the items in l. Each item in l is transformed
"""Calls process_node on all the items in l. Each item in l is transformed
in-place by the item process_node returns, then l is returned. If process_node
in-place by the item process_node returns, then l is returned. If process_node
returns None, the item is removed from the list."""
returns None, the item is removed from the list."""
for
idx
in
xrange
(
len
(
l
)):
for
idx
in
xrange
(
len
(
l
)):
self
.
a
ttr_stack
.
append
((
attrname
,
idx
))
self
.
a
ccess_path
.
append
((
self
.
parent
,
attrname
,
idx
))
l
[
idx
]
=
self
.
process_node
(
l
[
idx
])
l
[
idx
]
=
self
.
process_node
(
l
[
idx
])
self
.
a
ttr_stack
.
pop
()
self
.
a
ccess_path
.
pop
()
return
[
x
for
x
in
l
if
x
is
not
None
]
return
[
x
for
x
in
l
if
x
is
not
None
]
def
process_node
(
self
,
node
):
def
process_node
(
self
,
node
):
...
@@ -67,15 +69,15 @@ class Transform(object):
...
@@ -67,15 +69,15 @@ class Transform(object):
raise
NotImplementedError
(
"Not implemented"
)
raise
NotImplementedError
(
"Not implemented"
)
def
__call__
(
self
,
root
,
**
params
):
def
__call__
(
self
,
root
,
**
params
):
self
.
parent
_stack
=
[]
self
.
parent
=
None
self
.
a
ttr_stack
=
[]
self
.
a
ccess_path
=
[]
for
key
,
value
in
params
.
iteritems
():
for
key
,
value
in
params
.
iteritems
():
setattr
(
self
,
key
,
value
)
setattr
(
self
,
key
,
value
)
root
=
self
.
process_node
(
root
)
root
=
self
.
process_node
(
root
)
for
key
,
value
in
params
.
iteritems
():
for
key
,
value
in
params
.
iteritems
():
delattr
(
self
,
key
)
delattr
(
self
,
key
)
del
self
.
parent
_stack
del
self
.
parent
del
self
.
a
ttr_stack
del
self
.
a
ccess_path
return
root
return
root
...
@@ -140,6 +142,15 @@ def ensure_statlist(node):
...
@@ -140,6 +142,15 @@ def ensure_statlist(node):
node
=
Nodes
.
StatListNode
(
pos
=
node
.
pos
,
stats
=
[
node
])
node
=
Nodes
.
StatListNode
(
pos
=
node
.
pos
,
stats
=
[
node
])
return
node
return
node
def
replace_node
(
ptr
,
value
):
"""Replaces a node. ptr is of the form used on the access path stack
(parent, attrname, listidx|None)
"""
parent
,
attrname
,
listidx
=
ptr
if
listidx
is
None
:
setattr
(
parent
,
attrname
,
value
)
else
:
getattr
(
parent
,
attrname
)[
listidx
]
=
value
class
PrintTree
(
Transform
):
class
PrintTree
(
Transform
):
"""Prints a representation of the tree to standard output.
"""Prints a representation of the tree to standard output.
...
@@ -164,10 +175,10 @@ class PrintTree(Transform):
...
@@ -164,10 +175,10 @@ class PrintTree(Transform):
# the hierarchy.
# the hierarchy.
def
process_node
(
self
,
node
):
def
process_node
(
self
,
node
):
if
len
(
self
.
a
ttr_stack
)
==
0
:
if
len
(
self
.
a
ccess_path
)
==
0
:
name
=
"(root)"
name
=
"(root)"
else
:
else
:
attr
,
idx
=
self
.
attr_stack
[
-
1
]
parent
,
attr
,
idx
=
self
.
access_path
[
-
1
]
if
idx
is
not
None
:
if
idx
is
not
None
:
name
=
"%s[%d]"
%
(
attr
,
idx
)
name
=
"%s[%d]"
%
(
attr
,
idx
)
else
:
else
:
...
...
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