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
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
6815414b
Commit
6815414b
authored
Jan 03, 2013
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Plain Diff
merge
parents
0018075f
470c22c1
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
54 additions
and
1 deletion
+54
-1
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+10
-0
MANIFEST.in
MANIFEST.in
+1
-1
tests/run/double_dealloc_T796.pyx
tests/run/double_dealloc_T796.pyx
+43
-0
No files found.
Cython/Compiler/ModuleNode.py
View file @
6815414b
...
...
@@ -1130,6 +1130,11 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
or
weakref_slot
in
scope
.
var_entries
):
self
.
generate_self_cast
(
scope
,
code
)
# We must mark ths object as (gc) untracked while tearing it down, lest
# the garbage collection is invoked while running this destructor.
if
scope
.
needs_gc
():
code
.
putln
(
"PyObject_GC_UnTrack(o);"
);
# call the user's __dealloc__
self
.
generate_usr_dealloc_call
(
scope
,
code
)
if
weakref_slot
in
scope
.
var_entries
:
...
...
@@ -1153,6 +1158,11 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
code
.
put_xdecref_memoryviewslice
(
"p->%s"
%
entry
.
cname
,
have_gil
=
True
)
# The base class deallocator probably expects this to be tracked, so
# undo the untracking above.
if
scope
.
needs_gc
():
code
.
putln
(
"PyObject_GC_Track(o);"
);
if
base_type
:
tp_dealloc
=
TypeSlots
.
get_base_slot_function
(
scope
,
tp_slot
)
if
tp_dealloc
is
not
None
:
...
...
MANIFEST.in
View file @
6815414b
include MANIFEST.in README.txt INSTALL.txt ToDo.txt USAGE.txt
include MANIFEST.in README.txt INSTALL.txt ToDo.txt USAGE.txt
CHANGES.rst
include COPYING.txt LICENSE.txt Makefile
include .gitrev
include setup.py
...
...
tests/run/double_dealloc_T796.pyx
0 → 100644
View file @
6815414b
"""
>>> x = SimpleGarbage()
SimpleGarbage(1) __cinit__
>>> del x
SimpleGarbage(1) __dealloc__
Collector.__dealloc__
collect 0
"""
import
gc
,
sys
,
weakref
cdef
int
counter
=
0
cdef
int
next_counter
():
global
counter
counter
+=
1
return
counter
cdef
class
Collector
:
# Indirectly trigger garbage collection in SimpleGarbage deallocation.
# The __dealloc__ method of SimpleGarbage won't trigger the bug as the
# refcount is artifitially inflated for the durration of that function.
def
__dealloc__
(
self
):
print
"Collector.__dealloc__"
print
"collect"
,
gc
.
collect
()
cdef
class
SimpleGarbage
:
cdef
Collector
c
# to particpate in garbage collection
cdef
int
index
cdef
bint
deallocated
def
__cinit__
(
self
):
self
.
index
=
next_counter
()
self
.
c
=
Collector
()
print
self
,
"__cinit__"
def
__dealloc__
(
self
):
print
self
,
"__dealloc__"
if
self
.
deallocated
:
print
"Double dealloc!"
self
.
deallocated
=
True
gc
.
collect
()
def
__str__
(
self
):
return
"SimpleGarbage(%s)"
%
self
.
index
def
__repr__
(
self
):
return
"SimpleGarbage(%s)"
%
self
.
index
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