Coverage Report

Created: 2026-04-20 06:11

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/cpython/Objects/call.c
Line
Count
Source
1
#include "Python.h"
2
#include "pycore_call.h"          // _PyObject_CallNoArgsTstate()
3
#include "pycore_ceval.h"         // _Py_EnterRecursiveCallTstate()
4
#include "pycore_dict.h"          // _PyDict_FromItems()
5
#include "pycore_function.h"      // _PyFunction_Vectorcall() definition
6
#include "pycore_modsupport.h"    // _Py_VaBuildStack()
7
#include "pycore_object.h"        // _PyCFunctionWithKeywords_TrampolineCall()
8
#include "pycore_pyerrors.h"      // _PyErr_Occurred()
9
#include "pycore_pystate.h"       // _PyThreadState_GET()
10
#include "pycore_tuple.h"         // _PyTuple_ITEMS()
11
12
13
static PyObject *
14
null_error(PyThreadState *tstate)
15
0
{
16
0
    if (!_PyErr_Occurred(tstate)) {
17
0
        _PyErr_SetString(tstate, PyExc_SystemError,
18
0
                         "null argument to internal routine");
19
0
    }
20
0
    return NULL;
21
0
}
22
23
24
PyObject*
25
_Py_CheckFunctionResult(PyThreadState *tstate, PyObject *callable,
26
                        PyObject *result, const char *where)
27
856M
{
28
856M
    assert((callable != NULL) ^ (where != NULL));
29
30
856M
    if (result == NULL) {
31
19.7M
        if (!_PyErr_Occurred(tstate)) {
32
0
            if (callable)
33
0
                _PyErr_Format(tstate, PyExc_SystemError,
34
0
                              "%R returned NULL without setting an exception",
35
0
                              callable);
36
0
            else
37
0
                _PyErr_Format(tstate, PyExc_SystemError,
38
0
                              "%s returned NULL without setting an exception",
39
0
                              where);
40
#ifdef Py_DEBUG
41
            /* Ensure that the bug is caught in debug mode.
42
               Py_FatalError() logs the SystemError exception raised above. */
43
            Py_FatalError("a function returned NULL without setting an exception");
44
#endif
45
0
            return NULL;
46
0
        }
47
19.7M
    }
48
836M
    else {
49
836M
        if (_PyErr_Occurred(tstate)) {
50
0
            Py_DECREF(result);
51
52
0
            if (callable) {
53
0
                _PyErr_FormatFromCauseTstate(
54
0
                    tstate, PyExc_SystemError,
55
0
                    "%R returned a result with an exception set", callable);
56
0
            }
57
0
            else {
58
0
                _PyErr_FormatFromCauseTstate(
59
0
                    tstate, PyExc_SystemError,
60
0
                    "%s returned a result with an exception set", where);
61
0
            }
62
#ifdef Py_DEBUG
63
            /* Ensure that the bug is caught in debug mode.
64
               Py_FatalError() logs the SystemError exception raised above. */
65
            Py_FatalError("a function returned a result with an exception set");
66
#endif
67
0
            return NULL;
68
0
        }
69
836M
    }
70
856M
    return result;
71
856M
}
72
73
74
int
75
_Py_CheckSlotResult(PyObject *obj, const char *slot_name, int success)
76
0
{
77
0
    PyThreadState *tstate = _PyThreadState_GET();
78
0
    if (!success) {
79
0
        if (!_PyErr_Occurred(tstate)) {
80
0
            _Py_FatalErrorFormat(__func__,
81
0
                                 "Slot %s of type %s failed "
82
0
                                 "without setting an exception",
83
0
                                 slot_name, Py_TYPE(obj)->tp_name);
84
0
        }
85
0
    }
86
0
    else {
87
0
        if (_PyErr_Occurred(tstate)) {
88
0
            _Py_FatalErrorFormat(__func__,
89
0
                                 "Slot %s of type %s succeeded "
90
0
                                 "with an exception set",
91
0
                                 slot_name, Py_TYPE(obj)->tp_name);
92
0
        }
93
0
    }
94
0
    return 1;
95
0
}
96
97
98
/* --- Core PyObject call functions ------------------------------- */
99
100
/* Call a callable Python object without any arguments */
101
PyObject *
102
PyObject_CallNoArgs(PyObject *func)
103
393
{
104
393
    EVAL_CALL_STAT_INC_IF_FUNCTION(EVAL_CALL_API, func);
105
393
    PyThreadState *tstate = _PyThreadState_GET();
106
393
    return _PyObject_VectorcallTstate(tstate, func, NULL, 0, NULL);
107
393
}
108
109
110
PyObject *
111
_PyObject_VectorcallDictTstate(PyThreadState *tstate, PyObject *callable,
112
                               PyObject *const *args, size_t nargsf,
113
                               PyObject *kwargs)
114
53.4M
{
115
53.4M
    assert(callable != NULL);
116
117
    /* PyObject_VectorcallDict() must not be called with an exception set,
118
       because it can clear it (directly or indirectly) and so the
119
       caller loses its exception */
120
53.4M
    assert(!_PyErr_Occurred(tstate));
121
122
53.4M
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
123
53.4M
    assert(nargs >= 0);
124
53.4M
    assert(nargs == 0 || args != NULL);
125
53.4M
    assert(kwargs == NULL || PyDict_Check(kwargs));
126
127
53.4M
    vectorcallfunc func = PyVectorcall_Function(callable);
128
53.4M
    if (func == NULL) {
129
        /* Use tp_call instead */
130
5.65k
        return _PyObject_MakeTpCall(tstate, callable, args, nargs, kwargs);
131
5.65k
    }
132
133
53.4M
    PyObject *res;
134
53.4M
    if (kwargs == NULL || PyDict_GET_SIZE(kwargs) == 0) {
135
44.8M
        res = func(callable, args, nargsf, NULL);
136
44.8M
    }
137
8.62M
    else {
138
8.62M
        PyObject *kwnames;
139
8.62M
        PyObject *const *newargs;
140
8.62M
        newargs = _PyStack_UnpackDict(tstate,
141
8.62M
                                      args, nargs,
142
8.62M
                                      kwargs, &kwnames);
143
8.62M
        if (newargs == NULL) {
144
0
            return NULL;
145
0
        }
146
8.62M
        res = func(callable, newargs,
147
8.62M
                   nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
148
8.62M
        _PyStack_UnpackDict_Free(newargs, nargs, kwnames);
149
8.62M
    }
150
53.4M
    return _Py_CheckFunctionResult(tstate, callable, res, NULL);
151
53.4M
}
152
153
154
PyObject *
155
PyObject_VectorcallDict(PyObject *callable, PyObject *const *args,
156
                       size_t nargsf, PyObject *kwargs)
157
253k
{
158
253k
    PyThreadState *tstate = _PyThreadState_GET();
159
253k
    return _PyObject_VectorcallDictTstate(tstate, callable, args, nargsf, kwargs);
160
253k
}
161
162
static void
163
object_is_not_callable(PyThreadState *tstate, PyObject *callable)
164
0
{
165
0
    if (Py_IS_TYPE(callable, &PyModule_Type)) {
166
        // >>> import pprint
167
        // >>> pprint(thing)
168
        // Traceback (most recent call last):
169
        //   File "<stdin>", line 1, in <module>
170
        // TypeError: 'module' object is not callable. Did you mean: 'pprint.pprint(...)'?
171
0
        PyObject *name = PyModule_GetNameObject(callable);
172
0
        if (name == NULL) {
173
0
            _PyErr_Clear(tstate);
174
0
            goto basic_type_error;
175
0
        }
176
0
        PyObject *attr;
177
0
        int res = PyObject_GetOptionalAttr(callable, name, &attr);
178
0
        if (res < 0) {
179
0
            _PyErr_Clear(tstate);
180
0
        }
181
0
        else if (res > 0 && PyCallable_Check(attr)) {
182
0
            _PyErr_Format(tstate, PyExc_TypeError,
183
0
                          "'%.200s' object is not callable. "
184
0
                          "Did you mean: '%U.%U(...)'?",
185
0
                          Py_TYPE(callable)->tp_name, name, name);
186
0
            Py_DECREF(attr);
187
0
            Py_DECREF(name);
188
0
            return;
189
0
        }
190
0
        Py_XDECREF(attr);
191
0
        Py_DECREF(name);
192
0
    }
193
0
basic_type_error:
194
0
    _PyErr_Format(tstate, PyExc_TypeError, "'%.200s' object is not callable",
195
0
                  Py_TYPE(callable)->tp_name);
196
0
}
197
198
199
PyObject *
200
_PyObject_MakeTpCall(PyThreadState *tstate, PyObject *callable,
201
                     PyObject *const *args, Py_ssize_t nargs,
202
                     PyObject *keywords)
203
159M
{
204
159M
    assert(nargs >= 0);
205
159M
    assert(nargs == 0 || args != NULL);
206
159M
    assert(keywords == NULL || PyTuple_Check(keywords) || PyDict_Check(keywords));
207
208
    /* Slow path: build a temporary tuple for positional arguments and a
209
     * temporary dictionary for keyword arguments (if any) */
210
159M
    ternaryfunc call = Py_TYPE(callable)->tp_call;
211
159M
    if (call == NULL) {
212
0
        object_is_not_callable(tstate, callable);
213
0
        return NULL;
214
0
    }
215
216
159M
    PyObject *argstuple = PyTuple_FromArray(args, nargs);
217
159M
    if (argstuple == NULL) {
218
0
        return NULL;
219
0
    }
220
221
159M
    PyObject *kwdict;
222
159M
    if (keywords == NULL || PyDict_Check(keywords)) {
223
150M
        kwdict = keywords;
224
150M
    }
225
8.91M
    else {
226
8.91M
        if (PyTuple_GET_SIZE(keywords)) {
227
8.91M
            assert(args != NULL);
228
8.91M
            kwdict = _PyStack_AsDict(args + nargs, keywords);
229
8.91M
            if (kwdict == NULL) {
230
0
                Py_DECREF(argstuple);
231
0
                return NULL;
232
0
            }
233
8.91M
        }
234
0
        else {
235
0
            keywords = kwdict = NULL;
236
0
        }
237
8.91M
    }
238
239
159M
    PyObject *result = NULL;
240
159M
    if (_Py_EnterRecursiveCallTstate(tstate, " while calling a Python object") == 0)
241
159M
    {
242
159M
        result = _PyCFunctionWithKeywords_TrampolineCall(
243
159M
            (PyCFunctionWithKeywords)call, callable, argstuple, kwdict);
244
159M
        _Py_LeaveRecursiveCallTstate(tstate);
245
159M
    }
246
247
159M
    Py_DECREF(argstuple);
248
159M
    if (kwdict != keywords) {
249
8.91M
        Py_DECREF(kwdict);
250
8.91M
    }
251
252
159M
    return _Py_CheckFunctionResult(tstate, callable, result, NULL);
253
159M
}
254
255
256
vectorcallfunc
257
PyVectorcall_Function(PyObject *callable)
258
91.5M
{
259
91.5M
    return _PyVectorcall_FunctionInline(callable);
260
91.5M
}
261
262
263
static PyObject *
264
_PyVectorcall_Call(PyThreadState *tstate, vectorcallfunc func,
265
                   PyObject *callable, PyObject *tuple, PyObject *kwargs)
266
27.1M
{
267
27.1M
    assert(func != NULL);
268
269
27.1M
    Py_ssize_t nargs = PyTuple_GET_SIZE(tuple);
270
271
    /* Fast path for no keywords */
272
27.1M
    if (kwargs == NULL || PyDict_GET_SIZE(kwargs) == 0) {
273
23.6M
        return func(callable, _PyTuple_ITEMS(tuple), nargs, NULL);
274
23.6M
    }
275
276
    /* Convert arguments & call */
277
3.48M
    PyObject *const *args;
278
3.48M
    PyObject *kwnames;
279
3.48M
    args = _PyStack_UnpackDict(tstate,
280
3.48M
                               _PyTuple_ITEMS(tuple), nargs,
281
3.48M
                               kwargs, &kwnames);
282
3.48M
    if (args == NULL) {
283
0
        return NULL;
284
0
    }
285
3.48M
    PyObject *result = func(callable, args,
286
3.48M
                            nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
287
3.48M
    _PyStack_UnpackDict_Free(args, nargs, kwnames);
288
289
3.48M
    return _Py_CheckFunctionResult(tstate, callable, result, NULL);
290
3.48M
}
291
292
293
PyObject *
294
PyVectorcall_Call(PyObject *callable, PyObject *tuple, PyObject *kwargs)
295
0
{
296
0
    PyThreadState *tstate = _PyThreadState_GET();
297
298
    /* get vectorcallfunc as in _PyVectorcall_Function, but without
299
     * the Py_TPFLAGS_HAVE_VECTORCALL check */
300
0
    Py_ssize_t offset = Py_TYPE(callable)->tp_vectorcall_offset;
301
0
    if (offset <= 0) {
302
0
        _PyErr_Format(tstate, PyExc_TypeError,
303
0
                      "'%.200s' object does not support vectorcall",
304
0
                      Py_TYPE(callable)->tp_name);
305
0
        return NULL;
306
0
    }
307
0
    assert(PyCallable_Check(callable));
308
309
0
    vectorcallfunc func;
310
0
    memcpy(&func, (char *) callable + offset, sizeof(func));
311
0
    if (func == NULL) {
312
0
        _PyErr_Format(tstate, PyExc_TypeError,
313
0
                      "'%.200s' object does not support vectorcall",
314
0
                      Py_TYPE(callable)->tp_name);
315
0
        return NULL;
316
0
    }
317
318
0
    return _PyVectorcall_Call(tstate, func, callable, tuple, kwargs);
319
0
}
320
321
322
PyObject *
323
PyObject_Vectorcall(PyObject *callable, PyObject *const *args,
324
                     size_t nargsf, PyObject *kwnames)
325
305M
{
326
305M
    PyThreadState *tstate = _PyThreadState_GET();
327
305M
    return _PyObject_VectorcallTstate(tstate, callable,
328
305M
                                      args, nargsf, kwnames);
329
305M
}
330
331
332
PyObject *
333
_PyObject_Call(PyThreadState *tstate, PyObject *callable,
334
               PyObject *args, PyObject *kwargs)
335
37.7M
{
336
37.7M
    ternaryfunc call;
337
37.7M
    PyObject *result;
338
339
    /* PyObject_Call() must not be called with an exception set,
340
       because it can clear it (directly or indirectly) and so the
341
       caller loses its exception */
342
37.7M
    assert(!_PyErr_Occurred(tstate));
343
37.7M
    assert(PyTuple_Check(args));
344
37.7M
    assert(kwargs == NULL || PyDict_Check(kwargs));
345
37.7M
    EVAL_CALL_STAT_INC_IF_FUNCTION(EVAL_CALL_API, callable);
346
37.7M
    vectorcallfunc vector_func = PyVectorcall_Function(callable);
347
37.7M
    if (vector_func != NULL) {
348
27.1M
        return _PyVectorcall_Call(tstate, vector_func, callable, args, kwargs);
349
27.1M
    }
350
10.6M
    else {
351
10.6M
        call = Py_TYPE(callable)->tp_call;
352
10.6M
        if (call == NULL) {
353
0
            object_is_not_callable(tstate, callable);
354
0
            return NULL;
355
0
        }
356
357
10.6M
        if (_Py_EnterRecursiveCallTstate(tstate, " while calling a Python object")) {
358
0
            return NULL;
359
0
        }
360
361
10.6M
        result = (*call)(callable, args, kwargs);
362
363
10.6M
        _Py_LeaveRecursiveCallTstate(tstate);
364
365
10.6M
        return _Py_CheckFunctionResult(tstate, callable, result, NULL);
366
10.6M
    }
367
37.7M
}
368
369
PyObject *
370
PyObject_Call(PyObject *callable, PyObject *args, PyObject *kwargs)
371
37.6M
{
372
37.6M
    PyThreadState *tstate = _PyThreadState_GET();
373
37.6M
    return _PyObject_Call(tstate, callable, args, kwargs);
374
37.6M
}
375
376
377
/* Function removed in the Python 3.13 API but kept in the stable ABI. */
378
PyAPI_FUNC(PyObject *)
379
PyCFunction_Call(PyObject *callable, PyObject *args, PyObject *kwargs)
380
0
{
381
0
    return PyObject_Call(callable, args, kwargs);
382
0
}
383
384
385
PyObject *
386
PyObject_CallOneArg(PyObject *func, PyObject *arg)
387
75.1M
{
388
75.1M
    EVAL_CALL_STAT_INC_IF_FUNCTION(EVAL_CALL_API, func);
389
75.1M
    assert(arg != NULL);
390
75.1M
    PyObject *_args[2];
391
75.1M
    PyObject **args = _args + 1;  // For PY_VECTORCALL_ARGUMENTS_OFFSET
392
75.1M
    args[0] = arg;
393
75.1M
    PyThreadState *tstate = _PyThreadState_GET();
394
75.1M
    size_t nargsf = 1 | PY_VECTORCALL_ARGUMENTS_OFFSET;
395
75.1M
    return _PyObject_VectorcallTstate(tstate, func, args, nargsf, NULL);
396
75.1M
}
397
398
399
/* --- PyFunction call functions ---------------------------------- */
400
401
PyObject *
402
_PyFunction_Vectorcall(PyObject *func, PyObject* const* stack,
403
                       size_t nargsf, PyObject *kwnames)
404
201M
{
405
201M
    assert(PyFunction_Check(func));
406
201M
    PyFunctionObject *f = (PyFunctionObject *)func;
407
201M
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
408
201M
    assert(nargs >= 0);
409
201M
    PyThreadState *tstate = _PyThreadState_GET();
410
201M
    assert(nargs == 0 || stack != NULL);
411
201M
    EVAL_CALL_STAT_INC(EVAL_CALL_FUNCTION_VECTORCALL);
412
201M
    if (((PyCodeObject *)f->func_code)->co_flags & CO_OPTIMIZED) {
413
201M
        return _PyEval_Vector(tstate, f, NULL, stack, nargs, kwnames);
414
201M
    }
415
0
    else {
416
0
        return _PyEval_Vector(tstate, f, f->func_globals, stack, nargs, kwnames);
417
0
    }
418
201M
}
419
420
/* --- More complex call functions -------------------------------- */
421
422
/* External interface to call any callable object.
423
   The args must be a tuple or NULL.  The kwargs must be a dict or NULL.
424
   Function removed in Python 3.13 API but kept in the stable ABI. */
425
PyAPI_FUNC(PyObject*)
426
PyEval_CallObjectWithKeywords(PyObject *callable,
427
                              PyObject *args, PyObject *kwargs)
428
0
{
429
0
    PyThreadState *tstate = _PyThreadState_GET();
430
#ifdef Py_DEBUG
431
    /* PyEval_CallObjectWithKeywords() must not be called with an exception
432
       set. It raises a new exception if parameters are invalid or if
433
       PyTuple_New() fails, and so the original exception is lost. */
434
    assert(!_PyErr_Occurred(tstate));
435
#endif
436
437
0
    if (args != NULL && !PyTuple_Check(args)) {
438
0
        _PyErr_SetString(tstate, PyExc_TypeError,
439
0
                         "argument list must be a tuple");
440
0
        return NULL;
441
0
    }
442
443
0
    if (kwargs != NULL && !PyDict_Check(kwargs)) {
444
0
        _PyErr_SetString(tstate, PyExc_TypeError,
445
0
                         "keyword list must be a dictionary");
446
0
        return NULL;
447
0
    }
448
449
0
    if (args == NULL) {
450
0
        return _PyObject_VectorcallDictTstate(tstate, callable,
451
0
                                              NULL, 0, kwargs);
452
0
    }
453
0
    else {
454
0
        return _PyObject_Call(tstate, callable, args, kwargs);
455
0
    }
456
0
}
457
458
459
PyObject *
460
PyObject_CallObject(PyObject *callable, PyObject *args)
461
141k
{
462
141k
    PyThreadState *tstate = _PyThreadState_GET();
463
141k
    assert(!_PyErr_Occurred(tstate));
464
141k
    if (args == NULL) {
465
0
        return _PyObject_CallNoArgsTstate(tstate, callable);
466
0
    }
467
141k
    if (!PyTuple_Check(args)) {
468
0
        _PyErr_SetString(tstate, PyExc_TypeError,
469
0
                         "argument list must be a tuple");
470
0
        return NULL;
471
0
    }
472
141k
    return _PyObject_Call(tstate, callable, args, NULL);
473
141k
}
474
475
476
/* Call callable(obj, *args, **kwargs). */
477
PyObject *
478
_PyObject_Call_Prepend(PyThreadState *tstate, PyObject *callable,
479
                       PyObject *obj, PyObject *args, PyObject *kwargs)
480
53.2M
{
481
53.2M
    assert(PyTuple_Check(args));
482
483
53.2M
    PyObject *small_stack[_PY_FASTCALL_SMALL_STACK];
484
53.2M
    PyObject **stack;
485
486
53.2M
    Py_ssize_t argcount = PyTuple_GET_SIZE(args);
487
53.2M
    if (argcount + 1 <= (Py_ssize_t)Py_ARRAY_LENGTH(small_stack)) {
488
52.9M
        stack = small_stack;
489
52.9M
    }
490
275k
    else {
491
275k
        stack = PyMem_Malloc((argcount + 1) * sizeof(PyObject *));
492
275k
        if (stack == NULL) {
493
0
            PyErr_NoMemory();
494
0
            return NULL;
495
0
        }
496
275k
    }
497
498
    /* use borrowed references */
499
53.2M
    stack[0] = obj;
500
53.2M
    memcpy(&stack[1],
501
53.2M
           _PyTuple_ITEMS(args),
502
53.2M
           argcount * sizeof(PyObject *));
503
504
53.2M
    PyObject *result = _PyObject_VectorcallDictTstate(tstate, callable,
505
53.2M
                                                      stack, argcount + 1,
506
53.2M
                                                      kwargs);
507
53.2M
    if (stack != small_stack) {
508
275k
        PyMem_Free(stack);
509
275k
    }
510
53.2M
    return result;
511
53.2M
}
512
513
514
/* --- Call with a format string ---------------------------------- */
515
516
static PyObject *
517
_PyObject_CallFunctionVa(PyThreadState *tstate, PyObject *callable,
518
                         const char *format, va_list va)
519
5.89M
{
520
5.89M
    PyObject* small_stack[_PY_FASTCALL_SMALL_STACK];
521
5.89M
    const Py_ssize_t small_stack_len = Py_ARRAY_LENGTH(small_stack);
522
5.89M
    PyObject **stack;
523
5.89M
    Py_ssize_t nargs, i;
524
5.89M
    PyObject *result;
525
526
5.89M
    if (callable == NULL) {
527
0
        return null_error(tstate);
528
0
    }
529
530
5.89M
    if (!format || !*format) {
531
1.97k
        return _PyObject_CallNoArgsTstate(tstate, callable);
532
1.97k
    }
533
534
5.89M
    stack = _Py_VaBuildStack(small_stack, small_stack_len,
535
5.89M
                             format, va, &nargs);
536
5.89M
    if (stack == NULL) {
537
0
        return NULL;
538
0
    }
539
5.89M
    EVAL_CALL_STAT_INC_IF_FUNCTION(EVAL_CALL_API, callable);
540
5.89M
    if (nargs == 1 && PyTuple_Check(stack[0])) {
541
        /* Special cases for backward compatibility:
542
           - PyObject_CallFunction(func, "O", tuple) calls func(*tuple)
543
           - PyObject_CallFunction(func, "(OOO)", arg1, arg2, arg3) calls
544
             func(*(arg1, arg2, arg3)): func(arg1, arg2, arg3) */
545
10.7k
        PyObject *args = stack[0];
546
10.7k
        result = _PyObject_VectorcallTstate(tstate, callable,
547
10.7k
                                            _PyTuple_ITEMS(args),
548
10.7k
                                            PyTuple_GET_SIZE(args),
549
10.7k
                                            NULL);
550
10.7k
    }
551
5.88M
    else {
552
5.88M
        result = _PyObject_VectorcallTstate(tstate, callable,
553
5.88M
                                            stack, nargs, NULL);
554
5.88M
    }
555
556
27.8M
    for (i = 0; i < nargs; ++i) {
557
21.9M
        Py_DECREF(stack[i]);
558
21.9M
    }
559
5.89M
    if (stack != small_stack) {
560
216
        PyMem_Free(stack);
561
216
    }
562
5.89M
    return result;
563
5.89M
}
564
565
566
PyObject *
567
PyObject_CallFunction(PyObject *callable, const char *format, ...)
568
3.57M
{
569
3.57M
    va_list va;
570
3.57M
    PyObject *result;
571
3.57M
    PyThreadState *tstate = _PyThreadState_GET();
572
573
3.57M
    va_start(va, format);
574
3.57M
    result = _PyObject_CallFunctionVa(tstate, callable, format, va);
575
3.57M
    va_end(va);
576
577
3.57M
    return result;
578
3.57M
}
579
580
581
/* PyEval_CallFunction is exact copy of PyObject_CallFunction.
582
   Function removed in Python 3.13 API but kept in the stable ABI. */
583
PyAPI_FUNC(PyObject*)
584
PyEval_CallFunction(PyObject *callable, const char *format, ...)
585
0
{
586
0
    va_list va;
587
0
    PyObject *result;
588
0
    PyThreadState *tstate = _PyThreadState_GET();
589
590
0
    va_start(va, format);
591
0
    result = _PyObject_CallFunctionVa(tstate, callable, format, va);
592
0
    va_end(va);
593
594
0
    return result;
595
0
}
596
597
598
/* _PyObject_CallFunction_SizeT is exact copy of PyObject_CallFunction.
599
 * This function must be kept because it is part of the stable ABI.
600
 */
601
PyAPI_FUNC(PyObject *)  /* abi_only */
602
_PyObject_CallFunction_SizeT(PyObject *callable, const char *format, ...)
603
0
{
604
0
    PyThreadState *tstate = _PyThreadState_GET();
605
606
0
    va_list va;
607
0
    va_start(va, format);
608
0
    PyObject *result = _PyObject_CallFunctionVa(tstate, callable, format, va);
609
0
    va_end(va);
610
611
0
    return result;
612
0
}
613
614
615
static PyObject*
616
callmethod(PyThreadState *tstate, PyObject* callable, const char *format, va_list va)
617
2.32M
{
618
2.32M
    assert(callable != NULL);
619
2.32M
    if (!PyCallable_Check(callable)) {
620
0
        _PyErr_Format(tstate, PyExc_TypeError,
621
0
                      "attribute of type '%.200s' is not callable",
622
0
                      Py_TYPE(callable)->tp_name);
623
0
        return NULL;
624
0
    }
625
626
2.32M
    return _PyObject_CallFunctionVa(tstate, callable, format, va);
627
2.32M
}
628
629
PyObject *
630
PyObject_CallMethod(PyObject *obj, const char *name, const char *format, ...)
631
4.94k
{
632
4.94k
    PyThreadState *tstate = _PyThreadState_GET();
633
634
4.94k
    if (obj == NULL || name == NULL) {
635
0
        return null_error(tstate);
636
0
    }
637
638
4.94k
    PyObject *callable = PyObject_GetAttrString(obj, name);
639
4.94k
    if (callable == NULL) {
640
0
        return NULL;
641
0
    }
642
643
4.94k
    va_list va;
644
4.94k
    va_start(va, format);
645
4.94k
    PyObject *retval = callmethod(tstate, callable, format, va);
646
4.94k
    va_end(va);
647
648
4.94k
    Py_DECREF(callable);
649
4.94k
    return retval;
650
4.94k
}
651
652
653
/* PyEval_CallMethod is exact copy of PyObject_CallMethod.
654
   Function removed in Python 3.13 API but kept in the stable ABI. */
655
PyAPI_FUNC(PyObject*)
656
PyEval_CallMethod(PyObject *obj, const char *name, const char *format, ...)
657
0
{
658
0
    PyThreadState *tstate = _PyThreadState_GET();
659
0
    if (obj == NULL || name == NULL) {
660
0
        return null_error(tstate);
661
0
    }
662
663
0
    PyObject *callable = PyObject_GetAttrString(obj, name);
664
0
    if (callable == NULL) {
665
0
        return NULL;
666
0
    }
667
668
0
    va_list va;
669
0
    va_start(va, format);
670
0
    PyObject *retval = callmethod(tstate, callable, format, va);
671
0
    va_end(va);
672
673
0
    Py_DECREF(callable);
674
0
    return retval;
675
0
}
676
677
678
PyObject *
679
_PyObject_CallMethod(PyObject *obj, PyObject *name,
680
                     const char *format, ...)
681
2.31M
{
682
2.31M
    PyThreadState *tstate = _PyThreadState_GET();
683
2.31M
    if (obj == NULL || name == NULL) {
684
0
        return null_error(tstate);
685
0
    }
686
687
2.31M
    PyObject *callable = PyObject_GetAttr(obj, name);
688
2.31M
    if (callable == NULL) {
689
0
        return NULL;
690
0
    }
691
692
2.31M
    va_list va;
693
2.31M
    va_start(va, format);
694
2.31M
    PyObject *retval = callmethod(tstate, callable, format, va);
695
2.31M
    va_end(va);
696
697
2.31M
    Py_DECREF(callable);
698
2.31M
    return retval;
699
2.31M
}
700
701
702
PyObject *
703
_PyObject_CallMethodId(PyObject *obj, _Py_Identifier *name,
704
                       const char *format, ...)
705
0
{
706
0
    PyThreadState *tstate = _PyThreadState_GET();
707
0
    if (obj == NULL || name == NULL) {
708
0
        return null_error(tstate);
709
0
    }
710
711
0
_Py_COMP_DIAG_PUSH
712
0
_Py_COMP_DIAG_IGNORE_DEPR_DECLS
713
0
    PyObject *callable = _PyObject_GetAttrId(obj, name);
714
0
_Py_COMP_DIAG_POP
715
0
    if (callable == NULL) {
716
0
        return NULL;
717
0
    }
718
719
0
    va_list va;
720
0
    va_start(va, format);
721
0
    PyObject *retval = callmethod(tstate, callable, format, va);
722
0
    va_end(va);
723
724
0
    Py_DECREF(callable);
725
0
    return retval;
726
0
}
727
728
729
PyObject * _PyObject_CallMethodFormat(PyThreadState *tstate, PyObject *callable,
730
                                      const char *format, ...)
731
0
{
732
0
    assert(callable != NULL);
733
0
    va_list va;
734
0
    va_start(va, format);
735
0
    PyObject *retval = callmethod(tstate, callable, format, va);
736
0
    va_end(va);
737
0
    return retval;
738
0
}
739
740
741
// _PyObject_CallMethod_SizeT is exact copy of PyObject_CallMethod.
742
// This function must be kept because it is part of the stable ABI.
743
PyAPI_FUNC(PyObject *)  /* abi_only */
744
_PyObject_CallMethod_SizeT(PyObject *obj, const char *name,
745
                           const char *format, ...)
746
0
{
747
0
    PyThreadState *tstate = _PyThreadState_GET();
748
0
    if (obj == NULL || name == NULL) {
749
0
        return null_error(tstate);
750
0
    }
751
752
0
    PyObject *callable = PyObject_GetAttrString(obj, name);
753
0
    if (callable == NULL) {
754
0
        return NULL;
755
0
    }
756
757
0
    va_list va;
758
0
    va_start(va, format);
759
0
    PyObject *retval = callmethod(tstate, callable, format, va);
760
0
    va_end(va);
761
762
0
    Py_DECREF(callable);
763
0
    return retval;
764
0
}
765
766
767
/* --- Call with "..." arguments ---------------------------------- */
768
769
static PyObject *
770
object_vacall(PyThreadState *tstate, PyObject *base,
771
              PyObject *callable, va_list vargs)
772
334k
{
773
334k
    PyObject *small_stack[_PY_FASTCALL_SMALL_STACK];
774
334k
    PyObject **stack;
775
334k
    Py_ssize_t nargs;
776
334k
    PyObject *result;
777
334k
    Py_ssize_t i;
778
334k
    va_list countva;
779
780
334k
    if (callable == NULL) {
781
0
        return null_error(tstate);
782
0
    }
783
784
    /* Count the number of arguments */
785
334k
    va_copy(countva, vargs);
786
334k
    nargs = base ? 1 : 0;
787
1.96M
    while (1) {
788
1.96M
        PyObject *arg = va_arg(countva, PyObject *);
789
1.96M
        if (arg == NULL) {
790
334k
            break;
791
334k
        }
792
1.62M
        nargs++;
793
1.62M
    }
794
334k
    va_end(countva);
795
796
    /* Copy arguments */
797
334k
    if (nargs <= (Py_ssize_t)Py_ARRAY_LENGTH(small_stack)) {
798
87.5k
        stack = small_stack;
799
87.5k
    }
800
246k
    else {
801
246k
        stack = PyMem_Malloc(nargs * sizeof(stack[0]));
802
246k
        if (stack == NULL) {
803
0
            PyErr_NoMemory();
804
0
            return NULL;
805
0
        }
806
246k
    }
807
808
334k
    i = 0;
809
334k
    if (base) {
810
46.0k
        stack[i++] = base;
811
46.0k
    }
812
813
1.96M
    for (; i < nargs; ++i) {
814
1.62M
        stack[i] = va_arg(vargs, PyObject *);
815
1.62M
    }
816
817
#ifdef Py_STATS
818
    if (PyFunction_Check(callable)) {
819
        EVAL_CALL_STAT_INC(EVAL_CALL_API);
820
    }
821
#endif
822
    /* Call the function */
823
334k
    result = _PyObject_VectorcallTstate(tstate, callable, stack, nargs, NULL);
824
825
334k
    if (stack != small_stack) {
826
246k
        PyMem_Free(stack);
827
246k
    }
828
334k
    return result;
829
334k
}
830
831
PyObject *
832
_PyObject_VectorcallPrepend(PyThreadState *tstate, PyObject *callable,
833
                            PyObject *arg, PyObject *const *args,
834
                            size_t nargsf, PyObject *kwnames)
835
34.5M
{
836
34.5M
    Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
837
34.5M
    assert(nargs == 0 || args[nargs-1]);
838
839
34.5M
    PyObject *result;
840
34.5M
    if (nargsf & PY_VECTORCALL_ARGUMENTS_OFFSET) {
841
        /* PY_VECTORCALL_ARGUMENTS_OFFSET is set, so we are allowed to mutate the vector */
842
3.62M
        PyObject **newargs = (PyObject**)args - 1;
843
3.62M
        nargs += 1;
844
3.62M
        PyObject *tmp = newargs[0];
845
3.62M
        newargs[0] = arg;
846
3.62M
        assert(newargs[nargs-1]);
847
3.62M
        result = _PyObject_VectorcallTstate(tstate, callable, newargs,
848
3.62M
                                            nargs, kwnames);
849
3.62M
        newargs[0] = tmp;
850
3.62M
    }
851
30.9M
    else {
852
30.9M
        Py_ssize_t nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames);
853
30.9M
        Py_ssize_t totalargs = nargs + nkwargs;
854
30.9M
        if (totalargs == 0) {
855
633
            return _PyObject_VectorcallTstate(tstate, callable, &arg, 1, NULL);
856
633
        }
857
858
30.9M
        PyObject *newargs_stack[_PY_FASTCALL_SMALL_STACK];
859
30.9M
        PyObject **newargs;
860
30.9M
        if (totalargs <= (Py_ssize_t)Py_ARRAY_LENGTH(newargs_stack) - 1) {
861
30.9M
            newargs = newargs_stack;
862
30.9M
        }
863
2.69k
        else {
864
2.69k
            newargs = PyMem_Malloc((totalargs+1) * sizeof(PyObject *));
865
2.69k
            if (newargs == NULL) {
866
0
                _PyErr_NoMemory(tstate);
867
0
                return NULL;
868
0
            }
869
2.69k
        }
870
        /* use borrowed references */
871
30.9M
        newargs[0] = arg;
872
        /* bpo-37138: since totalargs > 0, it's impossible that args is NULL.
873
         * We need this, since calling memcpy() with a NULL pointer is
874
         * undefined behaviour. */
875
30.9M
        assert(args != NULL);
876
30.9M
        memcpy(newargs + 1, args, totalargs * sizeof(PyObject *));
877
30.9M
        result = _PyObject_VectorcallTstate(tstate, callable,
878
30.9M
                                            newargs, nargs+1, kwnames);
879
30.9M
        if (newargs != newargs_stack) {
880
2.69k
            PyMem_Free(newargs);
881
2.69k
        }
882
30.9M
    }
883
34.5M
    return result;
884
34.5M
}
885
886
PyObject *
887
PyObject_VectorcallMethod(PyObject *name, PyObject *const *args,
888
                           size_t nargsf, PyObject *kwnames)
889
6.09M
{
890
6.09M
    assert(name != NULL);
891
6.09M
    assert(args != NULL);
892
6.09M
    assert(PyVectorcall_NARGS(nargsf) >= 1);
893
894
6.09M
    PyThreadState *tstate = _PyThreadState_GET();
895
6.09M
    _PyCStackRef self, method;
896
6.09M
    _PyThreadState_PushCStackRef(tstate, &self);
897
6.09M
    _PyThreadState_PushCStackRef(tstate, &method);
898
    /* Use args[0] as "self" argument */
899
6.09M
    self.ref = PyStackRef_FromPyObjectBorrow(args[0]);
900
6.09M
    int unbound = _PyObject_GetMethodStackRef(tstate, &self.ref, name, &method.ref);
901
6.09M
    if (unbound < 0) {
902
5
        _PyThreadState_PopCStackRef(tstate, &method);
903
5
        _PyThreadState_PopCStackRef(tstate, &self);
904
5
        return NULL;
905
5
    }
906
907
6.09M
    PyObject *callable = PyStackRef_AsPyObjectBorrow(method.ref);
908
6.09M
    PyObject *self_obj = PyStackRef_AsPyObjectBorrow(self.ref);
909
6.09M
    PyObject *result;
910
911
6.09M
    EVAL_CALL_STAT_INC_IF_FUNCTION(EVAL_CALL_METHOD, callable);
912
6.09M
    if (self_obj == NULL) {
913
        /* Skip "self". We can keep PY_VECTORCALL_ARGUMENTS_OFFSET since
914
         * args[-1] in the onward call is args[0] here. */
915
91.9k
        result = _PyObject_VectorcallTstate(tstate, callable,
916
91.9k
                                            args + 1, nargsf - 1, kwnames);
917
91.9k
    }
918
6.00M
    else if (self_obj == args[0]) {
919
        /* We must remove PY_VECTORCALL_ARGUMENTS_OFFSET since
920
         * that would be interpreted as allowing to change args[-1] */
921
6.00M
        result = _PyObject_VectorcallTstate(tstate, callable, args,
922
6.00M
                                            nargsf & ~PY_VECTORCALL_ARGUMENTS_OFFSET,
923
6.00M
                                            kwnames);
924
6.00M
    }
925
0
    else {
926
        /* classmethod: self_obj is the type, not args[0]. Replace
927
         * args[0] with self_obj and call the underlying callable. */
928
0
        result = _PyObject_VectorcallPrepend(tstate, callable, self_obj,
929
0
                                             args + 1, nargsf - 1, kwnames);
930
0
    }
931
6.09M
    _PyThreadState_PopCStackRef(tstate, &method);
932
6.09M
    _PyThreadState_PopCStackRef(tstate, &self);
933
6.09M
    return result;
934
6.09M
}
935
936
937
PyObject *
938
PyObject_CallMethodObjArgs(PyObject *obj, PyObject *name, ...)
939
66.9k
{
940
66.9k
    PyThreadState *tstate = _PyThreadState_GET();
941
66.9k
    if (obj == NULL || name == NULL) {
942
0
        return null_error(tstate);
943
0
    }
944
945
66.9k
    _PyCStackRef self, method;
946
66.9k
    _PyThreadState_PushCStackRef(tstate, &self);
947
66.9k
    _PyThreadState_PushCStackRef(tstate, &method);
948
66.9k
    self.ref = PyStackRef_FromPyObjectBorrow(obj);
949
66.9k
    int res = _PyObject_GetMethodStackRef(tstate, &self.ref, name, &method.ref);
950
66.9k
    if (res < 0) {
951
0
        _PyThreadState_PopCStackRef(tstate, &method);
952
0
        _PyThreadState_PopCStackRef(tstate, &self);
953
0
        return NULL;
954
0
    }
955
66.9k
    PyObject *callable = PyStackRef_AsPyObjectBorrow(method.ref);
956
66.9k
    PyObject *self_obj = PyStackRef_AsPyObjectBorrow(self.ref);
957
958
66.9k
    va_list vargs;
959
66.9k
    va_start(vargs, name);
960
66.9k
    PyObject *result = object_vacall(tstate, self_obj, callable, vargs);
961
66.9k
    va_end(vargs);
962
963
66.9k
    _PyThreadState_PopCStackRef(tstate, &method);
964
66.9k
    _PyThreadState_PopCStackRef(tstate, &self);
965
66.9k
    return result;
966
66.9k
}
967
968
969
PyObject *
970
PyObject_CallFunctionObjArgs(PyObject *callable, ...)
971
267k
{
972
267k
    PyThreadState *tstate = _PyThreadState_GET();
973
267k
    va_list vargs;
974
267k
    PyObject *result;
975
976
267k
    va_start(vargs, callable);
977
267k
    result = object_vacall(tstate, NULL, callable, vargs);
978
267k
    va_end(vargs);
979
980
267k
    return result;
981
267k
}
982
983
984
/* --- PyStack functions ------------------------------------------ */
985
986
PyObject *
987
_PyStack_AsDict(PyObject *const *values, PyObject *kwnames)
988
8.92M
{
989
8.92M
    Py_ssize_t nkwargs;
990
991
8.92M
    assert(kwnames != NULL);
992
8.92M
    nkwargs = PyTuple_GET_SIZE(kwnames);
993
8.92M
    return _PyDict_FromItems(&PyTuple_GET_ITEM(kwnames, 0), 1,
994
8.92M
                             values, 1, nkwargs);
995
8.92M
}
996
997
998
/* Convert (args, nargs, kwargs: dict) into a (stack, nargs, kwnames: tuple).
999
1000
   Allocate a new argument vector and keyword names tuple. Return the argument
1001
   vector; return NULL with exception set on error. Return the keyword names
1002
   tuple in *p_kwnames.
1003
1004
   This also checks that all keyword names are strings. If not, a TypeError is
1005
   raised.
1006
1007
   The newly allocated argument vector supports PY_VECTORCALL_ARGUMENTS_OFFSET.
1008
1009
   The positional arguments are borrowed references from the input array
1010
   (which must be kept alive by the caller). The keyword argument values
1011
   are new references.
1012
1013
   When done, you must call _PyStack_UnpackDict_Free(stack, nargs, kwnames) */
1014
PyObject *const *
1015
_PyStack_UnpackDict(PyThreadState *tstate,
1016
                    PyObject *const *args, Py_ssize_t nargs,
1017
                    PyObject *kwargs, PyObject **p_kwnames)
1018
12.1M
{
1019
12.1M
    assert(nargs >= 0);
1020
12.1M
    assert(kwargs != NULL);
1021
12.1M
    assert(PyDict_Check(kwargs));
1022
1023
12.1M
    Py_ssize_t nkwargs = PyDict_GET_SIZE(kwargs);
1024
    /* Check for overflow in the PyMem_Malloc() call below. The subtraction
1025
     * in this check cannot overflow: both maxnargs and nkwargs are
1026
     * non-negative signed integers, so their difference fits in the type. */
1027
12.1M
    Py_ssize_t maxnargs = PY_SSIZE_T_MAX / sizeof(args[0]) - 1;
1028
12.1M
    if (nargs > maxnargs - nkwargs) {
1029
0
        _PyErr_NoMemory(tstate);
1030
0
        return NULL;
1031
0
    }
1032
1033
    /* Add 1 to support PY_VECTORCALL_ARGUMENTS_OFFSET */
1034
12.1M
    PyObject **stack = PyMem_Malloc((1 + nargs + nkwargs) * sizeof(args[0]));
1035
12.1M
    if (stack == NULL) {
1036
0
        _PyErr_NoMemory(tstate);
1037
0
        return NULL;
1038
0
    }
1039
1040
12.1M
    PyObject *kwnames = PyTuple_New(nkwargs);
1041
12.1M
    if (kwnames == NULL) {
1042
0
        PyMem_Free(stack);
1043
0
        return NULL;
1044
0
    }
1045
1046
12.1M
    stack++;  /* For PY_VECTORCALL_ARGUMENTS_OFFSET */
1047
1048
    /* Copy positional arguments (borrowed references) */
1049
22.1M
    for (Py_ssize_t i = 0; i < nargs; i++) {
1050
9.94M
        stack[i] = args[i];
1051
9.94M
    }
1052
1053
12.1M
    PyObject **kwstack = stack + nargs;
1054
    /* This loop doesn't support lookup function mutating the dictionary
1055
       to change its size. It's a deliberate choice for speed, this function is
1056
       called in the performance critical hot code. */
1057
12.1M
    Py_ssize_t pos = 0, i = 0;
1058
12.1M
    PyObject *key, *value;
1059
12.1M
    unsigned long keys_are_strings = Py_TPFLAGS_UNICODE_SUBCLASS;
1060
27.4M
    while (PyDict_Next(kwargs, &pos, &key, &value)) {
1061
15.2M
        keys_are_strings &= Py_TYPE(key)->tp_flags;
1062
15.2M
        PyTuple_SET_ITEM(kwnames, i, Py_NewRef(key));
1063
15.2M
        kwstack[i] = Py_NewRef(value);
1064
15.2M
        i++;
1065
15.2M
    }
1066
1067
    /* keys_are_strings has the value Py_TPFLAGS_UNICODE_SUBCLASS if that
1068
     * flag is set for all keys. Otherwise, keys_are_strings equals 0.
1069
     * We do this check once at the end instead of inside the loop above
1070
     * because it simplifies the deallocation in the failing case.
1071
     * It happens to also make the loop above slightly more efficient. */
1072
12.1M
    if (!keys_are_strings) {
1073
0
        _PyErr_SetString(tstate, PyExc_TypeError,
1074
0
                         "keywords must be strings");
1075
0
        _PyStack_UnpackDict_Free(stack, nargs, kwnames);
1076
0
        return NULL;
1077
0
    }
1078
1079
12.1M
    *p_kwnames = kwnames;
1080
12.1M
    return stack;
1081
12.1M
}
1082
1083
void
1084
_PyStack_UnpackDict_Free(PyObject *const *stack, Py_ssize_t nargs,
1085
                         PyObject *kwnames)
1086
12.1M
{
1087
    /* Only decref kwargs values, positional args are borrowed */
1088
12.1M
    Py_ssize_t nkwargs = PyTuple_GET_SIZE(kwnames);
1089
27.1M
    for (Py_ssize_t i = 0; i < nkwargs; i++) {
1090
15.0M
        Py_DECREF(stack[nargs + i]);
1091
15.0M
    }
1092
12.1M
    _PyStack_UnpackDict_FreeNoDecRef(stack, kwnames);
1093
12.1M
}
1094
1095
void
1096
_PyStack_UnpackDict_FreeNoDecRef(PyObject *const *stack, PyObject *kwnames)
1097
12.1M
{
1098
12.1M
    PyMem_Free((PyObject **)stack - 1);
1099
12.1M
    Py_DECREF(kwnames);
1100
12.1M
}
1101
1102
// Export for the stable ABI
1103
#undef PyVectorcall_NARGS
1104
Py_ssize_t
1105
PyVectorcall_NARGS(size_t n)
1106
0
{
1107
0
    return _PyVectorcall_NARGS(n);
1108
0
}