mirror of
https://github.com/python/cpython.git
synced 2025-12-15 21:44:50 +00:00
bpo-40943: Fix skipitem() didn't raise SystemError (GH-25937)
`convertitem()` raises `SystemError` when '#' is used without `PY_SSIZE_T_CLEAN`. This commit makes `skipitem()` raise it too.
This commit is contained in:
parent
ee8e7c2fa9
commit
4ebf4a6bfa
3 changed files with 32 additions and 11 deletions
|
|
@ -5455,9 +5455,6 @@ pynumber_tobase(PyObject *module, PyObject *args)
|
|||
}
|
||||
|
||||
|
||||
static PyObject *test_buildvalue_issue38913(PyObject *, PyObject *);
|
||||
|
||||
|
||||
static PyObject*
|
||||
test_set_type_size(PyObject *self, PyObject *Py_UNUSED(ignored))
|
||||
{
|
||||
|
|
@ -5596,6 +5593,8 @@ test_fatal_error(PyObject *self, PyObject *args)
|
|||
}
|
||||
|
||||
|
||||
static PyObject *test_buildvalue_issue38913(PyObject *, PyObject *);
|
||||
static PyObject *getargs_s_hash_int(PyObject *, PyObject *, PyObject*);
|
||||
|
||||
static PyMethodDef TestMethods[] = {
|
||||
{"raise_exception", raise_exception, METH_VARARGS},
|
||||
|
|
@ -5703,6 +5702,8 @@ static PyMethodDef TestMethods[] = {
|
|||
{"getargs_s", getargs_s, METH_VARARGS},
|
||||
{"getargs_s_star", getargs_s_star, METH_VARARGS},
|
||||
{"getargs_s_hash", getargs_s_hash, METH_VARARGS},
|
||||
{"getargs_s_hash_int", (PyCFunction)(void(*)(void))getargs_s_hash_int,
|
||||
METH_VARARGS|METH_KEYWORDS},
|
||||
{"getargs_z", getargs_z, METH_VARARGS},
|
||||
{"getargs_z_star", getargs_z_star, METH_VARARGS},
|
||||
{"getargs_z_hash", getargs_z_hash, METH_VARARGS},
|
||||
|
|
@ -7375,3 +7376,19 @@ test_buildvalue_issue38913(PyObject *self, PyObject *Py_UNUSED(ignored))
|
|||
|
||||
Py_RETURN_NONE;
|
||||
}
|
||||
|
||||
#undef PyArg_ParseTupleAndKeywords
|
||||
PyAPI_FUNC(int) PyArg_ParseTupleAndKeywords(PyObject *, PyObject *,
|
||||
const char *, char **, ...);
|
||||
|
||||
static PyObject *
|
||||
getargs_s_hash_int(PyObject *self, PyObject *args, PyObject *kwargs)
|
||||
{
|
||||
static char *keywords[] = {"", "x", NULL};
|
||||
const char *s;
|
||||
int len;
|
||||
int i = 0;
|
||||
if (!PyArg_ParseTupleAndKeywords(args, kwargs, "|s#i", keywords, &s, &len, &i))
|
||||
return NULL;
|
||||
Py_RETURN_NONE;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue