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
Xavier Thompson
cython
Commits
5e19cbac
Commit
5e19cbac
authored
Nov 27, 2008
by
Dag Sverre Seljebotn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Code.py: Make a wall between non-managed and managed temps
parent
41c28bcd
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
8 deletions
+11
-8
Cython/Compiler/Code.py
Cython/Compiler/Code.py
+11
-8
No files found.
Cython/Compiler/Code.py
View file @
5e19cbac
...
...
@@ -41,8 +41,8 @@ class FunctionState(object):
self
.
exc_vars
=
None
self
.
temps_allocated
=
[]
# of (name, type, manage_ref)
self
.
temps_free
=
{}
#
type -> list of free var
s
self
.
temps_used_type
=
{}
# name ->
type
self
.
temps_free
=
{}
#
(type, manage_ref) -> list of free vars with same type/managed statu
s
self
.
temps_used_type
=
{}
# name ->
(type, manage_ref)
self
.
temp_counter
=
0
def
new_label
(
self
,
name
=
None
):
...
...
@@ -117,7 +117,10 @@ class FunctionState(object):
A C string referring to the variable is returned.
"""
freelist
=
self
.
temps_free
.
get
(
type
)
if
not
type
.
is_pyobject
and
manage_ref
is
not
True
:
# Make manage_ref canonical for temps_free lookup purposes
raise
ValueError
(
"manage_ref only applicable when type.is_pyobject"
)
freelist
=
self
.
temps_free
.
get
((
type
,
manage_ref
))
if
freelist
is
not
None
and
len
(
freelist
)
>
0
:
result
=
freelist
.
pop
()
else
:
...
...
@@ -126,7 +129,7 @@ class FunctionState(object):
result
=
"%s%d"
%
(
Naming
.
codewriter_temp_prefix
,
self
.
temp_counter
)
if
not
result
in
self
.
names_taken
:
break
self
.
temps_allocated
.
append
((
result
,
type
,
manage_ref
))
self
.
temps_used_type
[
result
]
=
type
self
.
temps_used_type
[
result
]
=
(
type
,
manage_ref
)
return
result
def
release_temp
(
self
,
name
):
...
...
@@ -134,12 +137,12 @@ class FunctionState(object):
Releases a temporary so that it can be reused by other code needing
a temp of the same type.
"""
type
=
self
.
temps_used_type
[
name
]
freelist
=
self
.
temps_free
.
get
(
type
)
type
,
manage_ref
=
self
.
temps_used_type
[
name
]
freelist
=
self
.
temps_free
.
get
(
(
type
,
manage_ref
)
)
if
freelist
is
None
:
freelist
=
[]
self
.
temps_free
[
type
]
=
freelist
self
.
temps_free
[
(
type
,
manage_ref
)
]
=
freelist
freelist
.
append
(
name
)
def
temps_in_use
(
self
):
...
...
@@ -148,7 +151,7 @@ class FunctionState(object):
"""
used
=
[]
for
name
,
type
,
manage_ref
in
self
.
temps_allocated
:
freelist
=
self
.
temps_free
.
get
(
type
)
freelist
=
self
.
temps_free
.
get
(
(
type
,
manage_ref
)
)
if
freelist
is
None
or
name
not
in
freelist
:
used
.
append
((
name
,
type
,
manage_ref
))
return
used
...
...
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