mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +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
|
@ -2069,8 +2069,7 @@ factorial_odd_part(unsigned long n)
|
|||
Py_DECREF(partial);
|
||||
if (tmp == NULL)
|
||||
goto error;
|
||||
Py_DECREF(inner);
|
||||
inner = tmp;
|
||||
Py_SETREF(inner, tmp);
|
||||
/* Now inner is the product of all odd integers j in the range (0,
|
||||
n/2**i], giving the inner product in the formula above. */
|
||||
|
||||
|
@ -2078,8 +2077,7 @@ factorial_odd_part(unsigned long n)
|
|||
tmp = PyNumber_Multiply(outer, inner);
|
||||
if (tmp == NULL)
|
||||
goto error;
|
||||
Py_DECREF(outer);
|
||||
outer = tmp;
|
||||
Py_SETREF(outer, tmp);
|
||||
}
|
||||
Py_DECREF(inner);
|
||||
return outer;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue