mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
gh-99537: Use Py_SETREF() function in C code (#99656)
Fix potential race condition in code patterns: * Replace "Py_DECREF(var); var = new;" with "Py_SETREF(var, new);" * Replace "Py_XDECREF(var); var = new;" with "Py_XSETREF(var, new);" * Replace "Py_CLEAR(var); var = new;" with "Py_XSETREF(var, new);" Other changes: * Replace "old = var; var = new; Py_DECREF(var)" with "Py_SETREF(var, new);" * Replace "old = var; var = new; Py_XDECREF(var)" with "Py_XSETREF(var, new);" * And remove the "old" variable.
This commit is contained in:
parent
135ec7cefb
commit
7e3f09cad9
20 changed files with 37 additions and 89 deletions
|
@ -1829,8 +1829,7 @@ get_deep_attribute(PyObject *obj, PyObject *names, PyObject **pparent)
|
|||
n = PyList_GET_SIZE(names);
|
||||
for (i = 0; i < n; i++) {
|
||||
PyObject *name = PyList_GET_ITEM(names, i);
|
||||
Py_XDECREF(parent);
|
||||
parent = obj;
|
||||
Py_XSETREF(parent, obj);
|
||||
(void)_PyObject_LookupAttr(parent, name, &obj);
|
||||
if (obj == NULL) {
|
||||
Py_DECREF(parent);
|
||||
|
@ -3717,9 +3716,7 @@ save_global(PicklerObject *self, PyObject *obj, PyObject *name)
|
|||
else {
|
||||
gen_global:
|
||||
if (parent == module) {
|
||||
Py_INCREF(lastname);
|
||||
Py_DECREF(global_name);
|
||||
global_name = lastname;
|
||||
Py_SETREF(global_name, Py_NewRef(lastname));
|
||||
}
|
||||
if (self->proto >= 4) {
|
||||
const char stack_global_op = STACK_GLOBAL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue