summaryrefslogtreecommitdiffstats
path: root/Modules/_json.c
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2012-11-01 19:03:30 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2012-11-01 19:03:30 (GMT)
commit53d36b691241f278fa6173034e6edb10154e62d3 (patch)
tree4dc522e53a8ab1f0c6f1cf24b0aeea5e9c0528b9 /Modules/_json.c
parent1511a5a3af26c99d73ae2933c74aed25ad1e8722 (diff)
parent5ebe65f8cb541b10f07fb6ce2b4283a26c7e1d80 (diff)
downloadcpython-53d36b691241f278fa6173034e6edb10154e62d3.zip
cpython-53d36b691241f278fa6173034e6edb10154e62d3.tar.gz
cpython-53d36b691241f278fa6173034e6edb10154e62d3.tar.bz2
Issue #16228: Fix a crash in the json module where a list changes size while it is being encoded.
Patch by Serhiy Storchaka.
Diffstat (limited to 'Modules/_json.c')
-rw-r--r--Modules/_json.c10
1 files changed, 3 insertions, 7 deletions
diff --git a/Modules/_json.c b/Modules/_json.c
index 2538b05..dbe3bad 100644
--- a/Modules/_json.c
+++ b/Modules/_json.c
@@ -1659,8 +1659,6 @@ encoder_listencode_list(PyEncoderObject *s, _PyAccu *acc,
static PyObject *empty_array = NULL;
PyObject *ident = NULL;
PyObject *s_fast = NULL;
- Py_ssize_t num_items;
- PyObject **seq_items;
Py_ssize_t i;
if (open_array == NULL || close_array == NULL || empty_array == NULL) {
@@ -1674,8 +1672,7 @@ encoder_listencode_list(PyEncoderObject *s, _PyAccu *acc,
s_fast = PySequence_Fast(seq, "_iterencode_list needs a sequence");
if (s_fast == NULL)
return -1;
- num_items = PySequence_Fast_GET_SIZE(s_fast);
- if (num_items == 0) {
+ if (PySequence_Fast_GET_SIZE(s_fast) == 0) {
Py_DECREF(s_fast);
return _PyAccu_Accumulate(acc, empty_array);
}
@@ -1696,7 +1693,6 @@ encoder_listencode_list(PyEncoderObject *s, _PyAccu *acc,
}
}
- seq_items = PySequence_Fast_ITEMS(s_fast);
if (_PyAccu_Accumulate(acc, open_array))
goto bail;
if (s->indent != Py_None) {
@@ -1708,8 +1704,8 @@ encoder_listencode_list(PyEncoderObject *s, _PyAccu *acc,
buf += newline_indent
*/
}
- for (i = 0; i < num_items; i++) {
- PyObject *obj = seq_items[i];
+ for (i = 0; i < PySequence_Fast_GET_SIZE(s_fast); i++) {
+ PyObject *obj = PySequence_Fast_GET_ITEM(s_fast, i);
if (i) {
if (_PyAccu_Accumulate(acc, s->item_separator))
goto bail;