diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2013-12-13 02:22:00 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2013-12-13 02:22:00 (GMT) |
commit | cd0cb8ccd376186f08fd3ee2be0085f45f66b3d3 (patch) | |
tree | 1c376ce9b0303a145e93884229a96364c9088eba /Modules/_tracemalloc.c | |
parent | 24bd028092d0d8340980ff8d720d072b6288f355 (diff) | |
download | cpython-cd0cb8ccd376186f08fd3ee2be0085f45f66b3d3.zip cpython-cd0cb8ccd376186f08fd3ee2be0085f45f66b3d3.tar.gz cpython-cd0cb8ccd376186f08fd3ee2be0085f45f66b3d3.tar.bz2 |
Close #19787: PyThread_set_key_value() now always set the value. In Python 3.3,
the function did nothing if the key already exists (if the current value is a
non-NULL pointer).
_testcapi.run_in_subinterp() now correctly sets the new Python thread state of
the current thread when a subinterpreter is created.
Diffstat (limited to 'Modules/_tracemalloc.c')
-rw-r--r-- | Modules/_tracemalloc.c | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/Modules/_tracemalloc.c b/Modules/_tracemalloc.c index b39e950..95b05d6 100644 --- a/Modules/_tracemalloc.c +++ b/Modules/_tracemalloc.c @@ -168,14 +168,11 @@ set_reentrant(int reentrant) assert(reentrant == 0 || reentrant == 1); if (reentrant) { assert(PyThread_get_key_value(tracemalloc_reentrant_key) == NULL); - PyThread_set_key_value(tracemalloc_reentrant_key, - REENTRANT); + PyThread_set_key_value(tracemalloc_reentrant_key, REENTRANT); } else { - /* FIXME: PyThread_set_key_value() cannot be used to set the flag - to zero, because it does nothing if the variable has already - a value set. */ - PyThread_delete_key_value(tracemalloc_reentrant_key); + assert(PyThread_get_key_value(tracemalloc_reentrant_key) == REENTRANT); + PyThread_set_key_value(tracemalloc_reentrant_key, NULL); } } |