From 6ba909ba3bafc7178aba92b461f5ebd351d0df94 Mon Sep 17 00:00:00 2001 From: Starbuck5 <46412508+Starbuck5@users.noreply.github.com> Date: Sun, 24 Nov 2024 22:52:06 -0800 Subject: [PATCH 1/2] Remove unnecessary calls to PyNumber_Index, PyLong_Checks --- src_c/pixelarray.c | 20 ++++---------------- src_c/rect_impl.h | 19 ++----------------- 2 files changed, 6 insertions(+), 33 deletions(-) diff --git a/src_c/pixelarray.c b/src_c/pixelarray.c index 53c32a41f5..f13c604553 100644 --- a/src_c/pixelarray.c +++ b/src_c/pixelarray.c @@ -1666,15 +1666,9 @@ _pxarray_subscript(pgPixelArrayObject *array, PyObject *op) return _pxarray_subscript_internal(array, start, stop, step, 0, dim1, 1); } - else if (PyIndex_Check(op) || PyLong_Check(op)) { - Py_ssize_t i; - PyObject *val = PyNumber_Index(op); - if (!val) { - return 0; - } + else if (PyIndex_Check(op)) { /* A simple index. */ - i = PyNumber_AsSsize_t(val, PyExc_IndexError); - Py_DECREF(val); + Py_ssize_t i = PyNumber_AsSsize_t(op, PyExc_IndexError); if (i == -1 && PyErr_Occurred()) { return 0; } @@ -1828,15 +1822,9 @@ _pxarray_ass_subscript(pgPixelArrayObject *array, PyObject *op, Py_DECREF(tmparray); return retval; } - else if (PyIndex_Check(op) || PyLong_Check(op)) { - Py_ssize_t i; - PyObject *val = PyNumber_Index(op); - if (!val) { - return -1; - } + else if (PyIndex_Check(op)) { /* A simple index. */ - i = PyNumber_AsSsize_t(val, PyExc_IndexError); - Py_DECREF(val); + Py_ssize_t i = PyNumber_AsSsize_t(op, PyExc_IndexError); if (i == -1 && PyErr_Occurred()) { return -1; } diff --git a/src_c/rect_impl.h b/src_c/rect_impl.h index 3f4084ff9c..0deafbcef4 100644 --- a/src_c/rect_impl.h +++ b/src_c/rect_impl.h @@ -2160,14 +2160,7 @@ RectExport_subscript(RectObject *self, PyObject *op) PrimitiveType *data = (PrimitiveType *)&self->r; if (PyIndex_Check(op)) { - PyObject *index = PyNumber_Index(op); - Py_ssize_t i; - - if (index == NULL) { - return NULL; - } - i = PyNumber_AsSsize_t(index, NULL); - Py_DECREF(index); + Py_ssize_t i = PyNumber_AsSsize_t(op, NULL); return RectExport_item(self, i); } else if (op == Py_Ellipsis) { @@ -2213,15 +2206,7 @@ RectExport_assSubscript(RectObject *self, PyObject *op, PyObject *value) return -1; } if (PyIndex_Check(op)) { - PyObject *index; - Py_ssize_t i; - - index = PyNumber_Index(op); - if (index == NULL) { - return -1; - } - i = PyNumber_AsSsize_t(index, NULL); - Py_DECREF(index); + Py_ssize_t i = PyNumber_AsSsize_t(op, NULL); return RectExport_assItem(self, i, value); } else if (op == Py_Ellipsis) { From b7eed5f40eb1b371a93ab907c6ed1cd8295ea7b2 Mon Sep 17 00:00:00 2001 From: Starbuck5 <46412508+Starbuck5@users.noreply.github.com> Date: Tue, 26 Nov 2024 23:07:50 -0800 Subject: [PATCH 2/2] Error check PyNumber_AsSsize_t in rect_impl.h --- src_c/rect_impl.h | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src_c/rect_impl.h b/src_c/rect_impl.h index 0deafbcef4..27df1bc315 100644 --- a/src_c/rect_impl.h +++ b/src_c/rect_impl.h @@ -2161,6 +2161,9 @@ RectExport_subscript(RectObject *self, PyObject *op) if (PyIndex_Check(op)) { Py_ssize_t i = PyNumber_AsSsize_t(op, NULL); + if (i == -1 && PyErr_Occurred()) { + return NULL; + } return RectExport_item(self, i); } else if (op == Py_Ellipsis) { @@ -2207,6 +2210,9 @@ RectExport_assSubscript(RectObject *self, PyObject *op, PyObject *value) } if (PyIndex_Check(op)) { Py_ssize_t i = PyNumber_AsSsize_t(op, NULL); + if (i == -1 && PyErr_Occurred()) { + return -1; + } return RectExport_assItem(self, i, value); } else if (op == Py_Ellipsis) {