summaryrefslogtreecommitdiffstats
path: root/Python/structmember.c
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2022-11-10 10:23:36 (GMT)
committerGitHub <noreply@github.com>2022-11-10 10:23:36 (GMT)
commit231d83b72435d61e929d6d62f2be7305e7b5b62b (patch)
tree17768fa10f1ade6bae9022d26e1470fd0b931366 /Python/structmember.c
parentd8f239d86eb70c31aa4c4ac46a1d0a27bdb14b20 (diff)
downloadcpython-231d83b72435d61e929d6d62f2be7305e7b5b62b.zip
cpython-231d83b72435d61e929d6d62f2be7305e7b5b62b.tar.gz
cpython-231d83b72435d61e929d6d62f2be7305e7b5b62b.tar.bz2
gh-99300: Use Py_NewRef() in Python/ directory (#99317)
Replace Py_INCREF() and Py_XINCREF() with Py_NewRef() and Py_XNewRef() in C files of the Python/ directory. Update Parser/asdl_c.py to regenerate Python/Python-ast.c.
Diffstat (limited to 'Python/structmember.c')
-rw-r--r--Python/structmember.c9
1 files changed, 3 insertions, 6 deletions
diff --git a/Python/structmember.c b/Python/structmember.c
index c7e3188..b94f512 100644
--- a/Python/structmember.c
+++ b/Python/structmember.c
@@ -49,8 +49,7 @@ PyMember_GetOne(const char *obj_addr, PyMemberDef *l)
break;
case T_STRING:
if (*(char**)addr == NULL) {
- Py_INCREF(Py_None);
- v = Py_None;
+ v = Py_NewRef(Py_None);
}
else
v = PyUnicode_FromString(*(char**)addr);
@@ -85,8 +84,7 @@ PyMember_GetOne(const char *obj_addr, PyMemberDef *l)
v = PyLong_FromUnsignedLongLong(*(unsigned long long *)addr);
break;
case T_NONE:
- v = Py_None;
- Py_INCREF(v);
+ v = Py_NewRef(Py_None);
break;
default:
PyErr_SetString(PyExc_SystemError, "bad memberdescr type");
@@ -247,9 +245,8 @@ PyMember_SetOne(char *addr, PyMemberDef *l, PyObject *v)
break;
case T_OBJECT:
case T_OBJECT_EX:
- Py_XINCREF(v);
oldv = *(PyObject **)addr;
- *(PyObject **)addr = v;
+ *(PyObject **)addr = Py_XNewRef(v);
Py_XDECREF(oldv);
break;
case T_CHAR: {