mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Backed out changeset b9c9691c72c5
Issue #28858: The change b9c9691c72c5 introduced a regression. It seems like _PyObject_CallArg1() uses more stack memory than PyObject_CallFunctionObjArgs().
This commit is contained in:
parent
c8d03187ff
commit
de4ae3d486
33 changed files with 83 additions and 71 deletions
|
@ -721,7 +721,8 @@ static PyObject *
|
|||
_asyncio_Future__repr_info_impl(FutureObj *self)
|
||||
/*[clinic end generated code: output=fa69e901bd176cfb input=f21504d8e2ae1ca2]*/
|
||||
{
|
||||
return _PyObject_CallArg1(asyncio_future_repr_info_func, self);
|
||||
return PyObject_CallFunctionObjArgs(
|
||||
asyncio_future_repr_info_func, self, NULL);
|
||||
}
|
||||
|
||||
/*[clinic input]
|
||||
|
@ -1536,7 +1537,8 @@ static PyObject *
|
|||
_asyncio_Task__repr_info_impl(TaskObj *self)
|
||||
/*[clinic end generated code: output=6a490eb66d5ba34b input=3c6d051ed3ddec8b]*/
|
||||
{
|
||||
return _PyObject_CallArg1(asyncio_task_repr_info_func, self);
|
||||
return PyObject_CallFunctionObjArgs(
|
||||
asyncio_task_repr_info_func, self, NULL);
|
||||
}
|
||||
|
||||
/*[clinic input]
|
||||
|
@ -1896,7 +1898,7 @@ task_set_error_soon(TaskObj *task, PyObject *et, const char *format, ...)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
PyObject *e = _PyObject_CallArg1(et, msg);
|
||||
PyObject *e = PyObject_CallFunctionObjArgs(et, msg, NULL);
|
||||
Py_DECREF(msg);
|
||||
if (e == NULL) {
|
||||
return NULL;
|
||||
|
@ -1946,7 +1948,7 @@ task_step_impl(TaskObj *task, PyObject *exc)
|
|||
|
||||
if (!exc) {
|
||||
/* exc was not a CancelledError */
|
||||
exc = _PyObject_CallNoArg(asyncio_CancelledError);
|
||||
exc = PyObject_CallFunctionObjArgs(asyncio_CancelledError, NULL);
|
||||
if (!exc) {
|
||||
goto fail;
|
||||
}
|
||||
|
@ -2179,7 +2181,7 @@ task_step_impl(TaskObj *task, PyObject *exc)
|
|||
}
|
||||
|
||||
/* Check if `result` is a generator */
|
||||
o = _PyObject_CallArg1(inspect_isgenerator, result);
|
||||
o = PyObject_CallFunctionObjArgs(inspect_isgenerator, result, NULL);
|
||||
if (o == NULL) {
|
||||
/* An exception in inspect.isgenerator */
|
||||
goto fail;
|
||||
|
|
|
@ -1259,7 +1259,7 @@ csv_writerow(WriterObj *self, PyObject *seq)
|
|||
(void *) self->rec, self->rec_len);
|
||||
if (line == NULL)
|
||||
return NULL;
|
||||
result = _PyObject_CallArg1(self->writeline, line);
|
||||
result = PyObject_CallFunctionObjArgs(self->writeline, line, NULL);
|
||||
Py_DECREF(line);
|
||||
return result;
|
||||
}
|
||||
|
|
|
@ -2457,7 +2457,7 @@ treebuilder_append_event(TreeBuilderObject *self, PyObject *action,
|
|||
PyObject *event = PyTuple_Pack(2, action, node);
|
||||
if (event == NULL)
|
||||
return -1;
|
||||
res = _PyObject_CallArg1(self->events_append, event);
|
||||
res = PyObject_CallFunctionObjArgs(self->events_append, event, NULL);
|
||||
Py_DECREF(event);
|
||||
if (res == NULL)
|
||||
return -1;
|
||||
|
|
|
@ -813,14 +813,14 @@ _parse_object_unicode(PyScannerObject *s, PyObject *pystr, Py_ssize_t idx, Py_ss
|
|||
*next_idx_ptr = idx + 1;
|
||||
|
||||
if (has_pairs_hook) {
|
||||
val = _PyObject_CallArg1(s->object_pairs_hook, rval);
|
||||
val = PyObject_CallFunctionObjArgs(s->object_pairs_hook, rval, NULL);
|
||||
Py_DECREF(rval);
|
||||
return val;
|
||||
}
|
||||
|
||||
/* if object_hook is not None: rval = object_hook(rval) */
|
||||
if (s->object_hook != Py_None) {
|
||||
val = _PyObject_CallArg1(s->object_hook, rval);
|
||||
val = PyObject_CallFunctionObjArgs(s->object_hook, rval, NULL);
|
||||
Py_DECREF(rval);
|
||||
return val;
|
||||
}
|
||||
|
@ -924,7 +924,7 @@ _parse_constant(PyScannerObject *s, const char *constant, Py_ssize_t idx, Py_ssi
|
|||
return NULL;
|
||||
|
||||
/* rval = parse_constant(constant) */
|
||||
rval = _PyObject_CallArg1(s->parse_constant, cstr);
|
||||
rval = PyObject_CallFunctionObjArgs(s->parse_constant, cstr, NULL);
|
||||
idx += PyUnicode_GET_LENGTH(cstr);
|
||||
Py_DECREF(cstr);
|
||||
*next_idx_ptr = idx;
|
||||
|
@ -1023,7 +1023,7 @@ _match_number_unicode(PyScannerObject *s, PyObject *pystr, Py_ssize_t start, Py_
|
|||
idx - start);
|
||||
if (numstr == NULL)
|
||||
return NULL;
|
||||
rval = _PyObject_CallArg1(custom_func, numstr);
|
||||
rval = PyObject_CallFunctionObjArgs(custom_func, numstr, NULL);
|
||||
}
|
||||
else {
|
||||
Py_ssize_t i, n;
|
||||
|
@ -1475,7 +1475,7 @@ encoder_encode_string(PyEncoderObject *s, PyObject *obj)
|
|||
if (s->fast_encode)
|
||||
return s->fast_encode(NULL, obj);
|
||||
else
|
||||
return _PyObject_CallArg1(s->encoder, obj);
|
||||
return PyObject_CallFunctionObjArgs(s->encoder, obj, NULL);
|
||||
}
|
||||
|
||||
static int
|
||||
|
@ -1553,7 +1553,7 @@ encoder_listencode_obj(PyEncoderObject *s, _PyAccu *acc,
|
|||
return -1;
|
||||
}
|
||||
}
|
||||
newobj = _PyObject_CallArg1(s->defaultfn, obj);
|
||||
newobj = PyObject_CallFunctionObjArgs(s->defaultfn, obj, NULL);
|
||||
if (newobj == NULL) {
|
||||
Py_XDECREF(ident);
|
||||
return -1;
|
||||
|
|
|
@ -3197,7 +3197,7 @@ _password_callback(char *buf, int size, int rwflag, void *userdata)
|
|||
PySSL_END_ALLOW_THREADS_S(pw_info->thread_state);
|
||||
|
||||
if (pw_info->callable) {
|
||||
fn_ret = _PyObject_CallNoArg(pw_info->callable);
|
||||
fn_ret = PyObject_CallFunctionObjArgs(pw_info->callable, NULL);
|
||||
if (!fn_ret) {
|
||||
/* TODO: It would be nice to move _ctypes_add_traceback() into the
|
||||
core python API, so we could use it to add a frame here */
|
||||
|
|
|
@ -2046,7 +2046,7 @@ cache_struct(PyObject *fmt)
|
|||
return s_object;
|
||||
}
|
||||
|
||||
s_object = _PyObject_CallArg1((PyObject *)(&PyStructType), fmt);
|
||||
s_object = PyObject_CallFunctionObjArgs((PyObject *)(&PyStructType), fmt, NULL);
|
||||
if (s_object != NULL) {
|
||||
if (PyDict_Size(cache) >= MAXCACHE)
|
||||
PyDict_Clear(cache);
|
||||
|
|
|
@ -312,7 +312,7 @@ pack_from_list(PyObject *obj, PyObject *items, PyObject *format,
|
|||
assert(PyObject_CheckBuffer(obj));
|
||||
assert(PyList_Check(items) || PyTuple_Check(items));
|
||||
|
||||
structobj = _PyObject_CallArg1(Struct, format);
|
||||
structobj = PyObject_CallFunctionObjArgs(Struct, format, NULL);
|
||||
if (structobj == NULL)
|
||||
return -1;
|
||||
|
||||
|
@ -406,7 +406,7 @@ pack_single(char *ptr, PyObject *item, const char *fmt, Py_ssize_t itemsize)
|
|||
if (format == NULL)
|
||||
goto out;
|
||||
|
||||
structobj = _PyObject_CallArg1(Struct, format);
|
||||
structobj = PyObject_CallFunctionObjArgs(Struct, format, NULL);
|
||||
if (structobj == NULL)
|
||||
goto out;
|
||||
|
||||
|
@ -620,7 +620,7 @@ unpack_rec(PyObject *unpack_from, char *ptr, PyObject *mview, char *item,
|
|||
|
||||
if (ndim == 0) {
|
||||
memcpy(item, ptr, itemsize);
|
||||
x = _PyObject_CallArg1(unpack_from, mview);
|
||||
x = PyObject_CallFunctionObjArgs(unpack_from, mview, NULL);
|
||||
if (x == NULL)
|
||||
return NULL;
|
||||
if (PyTuple_GET_SIZE(x) == 1) {
|
||||
|
@ -696,7 +696,7 @@ ndarray_as_list(NDArrayObject *nd)
|
|||
if (format == NULL)
|
||||
goto out;
|
||||
|
||||
structobj = _PyObject_CallArg1(Struct, format);
|
||||
structobj = PyObject_CallFunctionObjArgs(Struct, format, NULL);
|
||||
Py_DECREF(format);
|
||||
if (structobj == NULL)
|
||||
goto out;
|
||||
|
@ -788,7 +788,7 @@ get_itemsize(PyObject *format)
|
|||
PyObject *tmp;
|
||||
Py_ssize_t itemsize;
|
||||
|
||||
tmp = _PyObject_CallArg1(calcsize, format);
|
||||
tmp = PyObject_CallFunctionObjArgs(calcsize, format, NULL);
|
||||
if (tmp == NULL)
|
||||
return -1;
|
||||
itemsize = PyLong_AsSsize_t(tmp);
|
||||
|
|
|
@ -709,7 +709,7 @@ handle_weakrefs(PyGC_Head *unreachable, PyGC_Head *old)
|
|||
assert(callback != NULL);
|
||||
|
||||
/* copy-paste of weakrefobject.c's handle_callback() */
|
||||
temp = _PyObject_CallArg1(callback, wr);
|
||||
temp = PyObject_CallFunctionObjArgs(callback, wr, NULL);
|
||||
if (temp == NULL)
|
||||
PyErr_WriteUnraisable(callback);
|
||||
else
|
||||
|
|
|
@ -101,7 +101,7 @@ groupby_next(groupbyobject *gbo)
|
|||
newkey = newvalue;
|
||||
Py_INCREF(newvalue);
|
||||
} else {
|
||||
newkey = _PyObject_CallArg1(gbo->keyfunc, newvalue);
|
||||
newkey = PyObject_CallFunctionObjArgs(gbo->keyfunc, newvalue, NULL);
|
||||
if (newkey == NULL) {
|
||||
Py_DECREF(newvalue);
|
||||
return NULL;
|
||||
|
@ -293,7 +293,7 @@ _grouper_next(_grouperobject *igo)
|
|||
newkey = newvalue;
|
||||
Py_INCREF(newvalue);
|
||||
} else {
|
||||
newkey = _PyObject_CallArg1(gbo->keyfunc, newvalue);
|
||||
newkey = PyObject_CallFunctionObjArgs(gbo->keyfunc, newvalue, NULL);
|
||||
if (newkey == NULL) {
|
||||
Py_DECREF(newvalue);
|
||||
return NULL;
|
||||
|
@ -1130,7 +1130,7 @@ dropwhile_next(dropwhileobject *lz)
|
|||
if (lz->start == 1)
|
||||
return item;
|
||||
|
||||
good = _PyObject_CallArg1(lz->func, item);
|
||||
good = PyObject_CallFunctionObjArgs(lz->func, item, NULL);
|
||||
if (good == NULL) {
|
||||
Py_DECREF(item);
|
||||
return NULL;
|
||||
|
@ -1296,7 +1296,7 @@ takewhile_next(takewhileobject *lz)
|
|||
if (item == NULL)
|
||||
return NULL;
|
||||
|
||||
good = _PyObject_CallArg1(lz->func, item);
|
||||
good = PyObject_CallFunctionObjArgs(lz->func, item, NULL);
|
||||
if (good == NULL) {
|
||||
Py_DECREF(item);
|
||||
return NULL;
|
||||
|
@ -3824,7 +3824,7 @@ filterfalse_next(filterfalseobject *lz)
|
|||
ok = PyObject_IsTrue(item);
|
||||
} else {
|
||||
PyObject *good;
|
||||
good = _PyObject_CallArg1(lz->func, item);
|
||||
good = PyObject_CallFunctionObjArgs(lz->func, item, NULL);
|
||||
if (good == NULL) {
|
||||
Py_DECREF(item);
|
||||
return NULL;
|
||||
|
|
|
@ -951,7 +951,7 @@ static PyObject * math_ceil(PyObject *self, PyObject *number) {
|
|||
return NULL;
|
||||
return math_1_to_int(number, ceil, 0);
|
||||
}
|
||||
result = _PyObject_CallNoArg(method);
|
||||
result = PyObject_CallFunctionObjArgs(method, NULL);
|
||||
Py_DECREF(method);
|
||||
return result;
|
||||
}
|
||||
|
@ -991,7 +991,7 @@ static PyObject * math_floor(PyObject *self, PyObject *number) {
|
|||
return NULL;
|
||||
return math_1_to_int(number, floor, 0);
|
||||
}
|
||||
result = _PyObject_CallNoArg(method);
|
||||
result = PyObject_CallFunctionObjArgs(method, NULL);
|
||||
Py_DECREF(method);
|
||||
return result;
|
||||
}
|
||||
|
@ -1542,7 +1542,7 @@ math_trunc(PyObject *self, PyObject *number)
|
|||
Py_TYPE(number)->tp_name);
|
||||
return NULL;
|
||||
}
|
||||
result = _PyObject_CallNoArg(trunc);
|
||||
result = PyObject_CallFunctionObjArgs(trunc, NULL);
|
||||
Py_DECREF(trunc);
|
||||
return result;
|
||||
}
|
||||
|
|
|
@ -902,7 +902,7 @@ path_converter(PyObject *o, void *p)
|
|||
goto error_exit;
|
||||
}
|
||||
|
||||
o = to_cleanup = _PyObject_CallNoArg(func);
|
||||
o = to_cleanup = PyObject_CallFunctionObjArgs(func, NULL);
|
||||
Py_DECREF(func);
|
||||
if (NULL == o) {
|
||||
goto error_exit;
|
||||
|
@ -12041,7 +12041,7 @@ PyOS_FSPath(PyObject *path)
|
|||
Py_TYPE(path)->tp_name);
|
||||
}
|
||||
|
||||
path_repr = _PyObject_CallNoArg(func);
|
||||
path_repr = PyObject_CallFunctionObjArgs(func, NULL);
|
||||
Py_DECREF(func);
|
||||
if (NULL == path_repr) {
|
||||
return NULL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue