blob: 3604a55e5a1dc9458346a619f3811737aa698c31 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002/* Method object implementation */
3
Guido van Rossumc0b618a1997-05-02 03:12:38 +00004#include "Python.h"
Victor Stinnerbcda8f12018-11-21 22:27:47 +01005#include "pycore_object.h"
Victor Stinner621cebe2018-11-12 16:53:38 +01006#include "pycore_pymem.h"
7#include "pycore_pystate.h"
Jeremy Hylton4f0dcc92003-01-31 18:33:18 +00008#include "structmember.h"
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00009
Christian Heimes2202f872008-02-06 14:31:34 +000010/* Free list for method objects to safe malloc/free overhead
11 * The m_self element is used to chain the objects.
12 */
Guido van Rossum1f39c5c1997-08-05 02:11:41 +000013static PyCFunctionObject *free_list = NULL;
Christian Heimes2202f872008-02-06 14:31:34 +000014static int numfree = 0;
15#ifndef PyCFunction_MAXFREELIST
16#define PyCFunction_MAXFREELIST 256
17#endif
Guido van Rossum1f39c5c1997-08-05 02:11:41 +000018
Andrew Svetlov4de29242012-12-26 23:08:54 +020019/* undefine macro trampoline to PyCFunction_NewEx */
20#undef PyCFunction_New
21
Jeroen Demeyerbf8e82f2019-07-23 12:39:51 +020022/* Forward declarations */
23static PyObject * cfunction_vectorcall_FASTCALL(
24 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
25static PyObject * cfunction_vectorcall_FASTCALL_KEYWORDS(
26 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
27static PyObject * cfunction_vectorcall_NOARGS(
28 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
29static PyObject * cfunction_vectorcall_O(
30 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames);
31
32
Benjamin Petersone5024512018-09-12 12:06:42 -070033PyObject *
Andrew Svetlov3ba3a3e2012-12-25 13:32:35 +020034PyCFunction_New(PyMethodDef *ml, PyObject *self)
35{
36 return PyCFunction_NewEx(ml, self, NULL);
37}
38
39PyObject *
Jeremy Hylton4f0dcc92003-01-31 18:33:18 +000040PyCFunction_NewEx(PyMethodDef *ml, PyObject *self, PyObject *module)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000041{
Jeroen Demeyerbf8e82f2019-07-23 12:39:51 +020042 /* Figure out correct vectorcall function to use */
43 vectorcallfunc vectorcall;
44 switch (ml->ml_flags & (METH_VARARGS | METH_FASTCALL | METH_NOARGS | METH_O | METH_KEYWORDS))
45 {
46 case METH_VARARGS:
47 case METH_VARARGS | METH_KEYWORDS:
48 /* For METH_VARARGS functions, it's more efficient to use tp_call
49 * instead of vectorcall. */
50 vectorcall = NULL;
51 break;
52 case METH_FASTCALL:
53 vectorcall = cfunction_vectorcall_FASTCALL;
54 break;
55 case METH_FASTCALL | METH_KEYWORDS:
56 vectorcall = cfunction_vectorcall_FASTCALL_KEYWORDS;
57 break;
58 case METH_NOARGS:
59 vectorcall = cfunction_vectorcall_NOARGS;
60 break;
61 case METH_O:
62 vectorcall = cfunction_vectorcall_O;
63 break;
64 default:
Victor Stinner03ac0902020-03-12 13:37:02 +010065 PyErr_Format(PyExc_SystemError,
66 "%s() method: bad call flags", ml->ml_name);
Jeroen Demeyerbf8e82f2019-07-23 12:39:51 +020067 return NULL;
68 }
69
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000070 PyCFunctionObject *op;
71 op = free_list;
72 if (op != NULL) {
73 free_list = (PyCFunctionObject *)(op->m_self);
Victor Stinnerb509d522018-11-23 14:27:38 +010074 (void)PyObject_INIT(op, &PyCFunction_Type);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000075 numfree--;
76 }
77 else {
78 op = PyObject_GC_New(PyCFunctionObject, &PyCFunction_Type);
79 if (op == NULL)
80 return NULL;
81 }
Antoine Pitroub349e4c2014-08-06 19:31:40 -040082 op->m_weakreflist = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000083 op->m_ml = ml;
84 Py_XINCREF(self);
85 op->m_self = self;
86 Py_XINCREF(module);
87 op->m_module = module;
Jeroen Demeyerbf8e82f2019-07-23 12:39:51 +020088 op->vectorcall = vectorcall;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000089 _PyObject_GC_TRACK(op);
90 return (PyObject *)op;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000091}
92
Guido van Rossumc0b618a1997-05-02 03:12:38 +000093PyCFunction
Fred Drakeee238b92000-07-09 06:03:25 +000094PyCFunction_GetFunction(PyObject *op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000095{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000096 if (!PyCFunction_Check(op)) {
97 PyErr_BadInternalCall();
98 return NULL;
99 }
Antoine Pitrou5b629422011-12-23 12:40:16 +0100100 return PyCFunction_GET_FUNCTION(op);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000101}
102
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000103PyObject *
Fred Drakeee238b92000-07-09 06:03:25 +0000104PyCFunction_GetSelf(PyObject *op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000105{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000106 if (!PyCFunction_Check(op)) {
107 PyErr_BadInternalCall();
108 return NULL;
109 }
Antoine Pitrou5b629422011-12-23 12:40:16 +0100110 return PyCFunction_GET_SELF(op);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000111}
112
Guido van Rossumc0602291991-12-16 13:07:24 +0000113int
Fred Drakeee238b92000-07-09 06:03:25 +0000114PyCFunction_GetFlags(PyObject *op)
Guido van Rossumc0602291991-12-16 13:07:24 +0000115{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000116 if (!PyCFunction_Check(op)) {
117 PyErr_BadInternalCall();
118 return -1;
119 }
Antoine Pitrou5b629422011-12-23 12:40:16 +0100120 return PyCFunction_GET_FLAGS(op);
Guido van Rossumc0602291991-12-16 13:07:24 +0000121}
122
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000123/* Methods (the standard built-in methods, that is) */
124
125static void
Fred Drakeee238b92000-07-09 06:03:25 +0000126meth_dealloc(PyCFunctionObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000127{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000128 _PyObject_GC_UNTRACK(m);
Antoine Pitroub349e4c2014-08-06 19:31:40 -0400129 if (m->m_weakreflist != NULL) {
130 PyObject_ClearWeakRefs((PyObject*) m);
131 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000132 Py_XDECREF(m->m_self);
133 Py_XDECREF(m->m_module);
134 if (numfree < PyCFunction_MAXFREELIST) {
135 m->m_self = (PyObject *)free_list;
136 free_list = m;
137 numfree++;
138 }
139 else {
140 PyObject_GC_Del(m);
141 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000142}
143
Alexandre Vassalotti4c05d3b2013-11-24 02:41:05 -0800144static PyObject *
Siddhesh Poyarekar55edd0c2018-04-30 00:29:33 +0530145meth_reduce(PyCFunctionObject *m, PyObject *Py_UNUSED(ignored))
Alexandre Vassalotti4c05d3b2013-11-24 02:41:05 -0800146{
Alexandre Vassalotti4c05d3b2013-11-24 02:41:05 -0800147 _Py_IDENTIFIER(getattr);
148
149 if (m->m_self == NULL || PyModule_Check(m->m_self))
150 return PyUnicode_FromString(m->m_ml->ml_name);
151
Serhiy Storchakabb86bf42018-12-11 08:28:18 +0200152 return Py_BuildValue("N(Os)", _PyEval_GetBuiltinId(&PyId_getattr),
153 m->m_self, m->m_ml->ml_name);
Alexandre Vassalotti4c05d3b2013-11-24 02:41:05 -0800154}
155
156static PyMethodDef meth_methods[] = {
157 {"__reduce__", (PyCFunction)meth_reduce, METH_NOARGS, NULL},
158 {NULL, NULL}
159};
160
Larry Hastings44e2eaa2013-11-23 15:37:55 -0800161static PyObject *
162meth_get__text_signature__(PyCFunctionObject *m, void *closure)
163{
Larry Hastings2623c8c2014-02-08 22:15:29 -0800164 return _PyType_GetTextSignatureFromInternalDoc(m->m_ml->ml_name, m->m_ml->ml_doc);
Larry Hastings44e2eaa2013-11-23 15:37:55 -0800165}
166
Tim Peters6d6c1a32001-08-02 04:15:00 +0000167static PyObject *
168meth_get__doc__(PyCFunctionObject *m, void *closure)
169{
Larry Hastings2623c8c2014-02-08 22:15:29 -0800170 return _PyType_GetDocFromInternalDoc(m->m_ml->ml_name, m->m_ml->ml_doc);
Tim Peters6d6c1a32001-08-02 04:15:00 +0000171}
172
173static PyObject *
174meth_get__name__(PyCFunctionObject *m, void *closure)
175{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000176 return PyUnicode_FromString(m->m_ml->ml_name);
Tim Peters6d6c1a32001-08-02 04:15:00 +0000177}
178
Antoine Pitrou5b629422011-12-23 12:40:16 +0100179static PyObject *
180meth_get__qualname__(PyCFunctionObject *m, void *closure)
181{
182 /* If __self__ is a module or NULL, return m.__name__
183 (e.g. len.__qualname__ == 'len')
184
185 If __self__ is a type, return m.__self__.__qualname__ + '.' + m.__name__
186 (e.g. dict.fromkeys.__qualname__ == 'dict.fromkeys')
187
188 Otherwise return type(m.__self__).__qualname__ + '.' + m.__name__
189 (e.g. [].append.__qualname__ == 'list.append') */
190 PyObject *type, *type_qualname, *res;
191 _Py_IDENTIFIER(__qualname__);
192
193 if (m->m_self == NULL || PyModule_Check(m->m_self))
194 return PyUnicode_FromString(m->m_ml->ml_name);
195
196 type = PyType_Check(m->m_self) ? m->m_self : (PyObject*)Py_TYPE(m->m_self);
197
198 type_qualname = _PyObject_GetAttrId(type, &PyId___qualname__);
199 if (type_qualname == NULL)
200 return NULL;
201
202 if (!PyUnicode_Check(type_qualname)) {
203 PyErr_SetString(PyExc_TypeError, "<method>.__class__."
204 "__qualname__ is not a unicode object");
205 Py_XDECREF(type_qualname);
206 return NULL;
207 }
208
209 res = PyUnicode_FromFormat("%S.%s", type_qualname, m->m_ml->ml_name);
210 Py_DECREF(type_qualname);
211 return res;
212}
213
Neil Schemenauer10c66922001-07-12 13:27:35 +0000214static int
215meth_traverse(PyCFunctionObject *m, visitproc visit, void *arg)
216{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000217 Py_VISIT(m->m_self);
218 Py_VISIT(m->m_module);
219 return 0;
Neil Schemenauer10c66922001-07-12 13:27:35 +0000220}
221
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000222static PyObject *
Tim Peters6d6c1a32001-08-02 04:15:00 +0000223meth_get__self__(PyCFunctionObject *m, void *closure)
Guido van Rossumcab650d1995-01-07 12:34:58 +0000224{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000225 PyObject *self;
Guido van Rossuma8add0e2007-05-14 22:03:55 +0000226
Antoine Pitrou5b629422011-12-23 12:40:16 +0100227 self = PyCFunction_GET_SELF(m);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000228 if (self == NULL)
229 self = Py_None;
230 Py_INCREF(self);
231 return self;
Guido van Rossumcab650d1995-01-07 12:34:58 +0000232}
233
Guido van Rossum32d34c82001-09-20 21:45:26 +0000234static PyGetSetDef meth_getsets [] = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000235 {"__doc__", (getter)meth_get__doc__, NULL, NULL},
236 {"__name__", (getter)meth_get__name__, NULL, NULL},
Antoine Pitrou5b629422011-12-23 12:40:16 +0100237 {"__qualname__", (getter)meth_get__qualname__, NULL, NULL},
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000238 {"__self__", (getter)meth_get__self__, NULL, NULL},
Larry Hastings44e2eaa2013-11-23 15:37:55 -0800239 {"__text_signature__", (getter)meth_get__text_signature__, NULL, NULL},
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000240 {0}
Tim Peters6d6c1a32001-08-02 04:15:00 +0000241};
242
Jeremy Hylton4f0dcc92003-01-31 18:33:18 +0000243#define OFF(x) offsetof(PyCFunctionObject, x)
244
245static PyMemberDef meth_members[] = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000246 {"__module__", T_OBJECT, OFF(m_module), PY_WRITE_RESTRICTED},
247 {NULL}
Jeremy Hylton4f0dcc92003-01-31 18:33:18 +0000248};
249
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000250static PyObject *
Fred Drakeee238b92000-07-09 06:03:25 +0000251meth_repr(PyCFunctionObject *m)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000252{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000253 if (m->m_self == NULL || PyModule_Check(m->m_self))
254 return PyUnicode_FromFormat("<built-in function %s>",
255 m->m_ml->ml_name);
256 return PyUnicode_FromFormat("<built-in method %s of %s object at %p>",
257 m->m_ml->ml_name,
258 m->m_self->ob_type->tp_name,
259 m->m_self);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000260}
261
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000262static PyObject *
263meth_richcompare(PyObject *self, PyObject *other, int op)
Guido van Rossum9bfef441993-03-29 10:43:31 +0000264{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000265 PyCFunctionObject *a, *b;
266 PyObject *res;
267 int eq;
Guido van Rossum47b9ff62006-08-24 00:41:19 +0000268
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000269 if ((op != Py_EQ && op != Py_NE) ||
270 !PyCFunction_Check(self) ||
271 !PyCFunction_Check(other))
272 {
Brian Curtindfc80e32011-08-10 20:28:54 -0500273 Py_RETURN_NOTIMPLEMENTED;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000274 }
275 a = (PyCFunctionObject *)self;
276 b = (PyCFunctionObject *)other;
277 eq = a->m_self == b->m_self;
278 if (eq)
279 eq = a->m_ml->ml_meth == b->m_ml->ml_meth;
280 if (op == Py_EQ)
281 res = eq ? Py_True : Py_False;
282 else
283 res = eq ? Py_False : Py_True;
284 Py_INCREF(res);
285 return res;
Guido van Rossum9bfef441993-03-29 10:43:31 +0000286}
287
Benjamin Peterson8f67d082010-10-17 20:54:53 +0000288static Py_hash_t
Fred Drakeee238b92000-07-09 06:03:25 +0000289meth_hash(PyCFunctionObject *a)
Guido van Rossum9bfef441993-03-29 10:43:31 +0000290{
Benjamin Peterson8f67d082010-10-17 20:54:53 +0000291 Py_hash_t x, y;
Serhiy Storchakaac20e0f2018-07-31 09:18:24 +0300292 x = _Py_HashPointer(a->m_self);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000293 y = _Py_HashPointer((void*)(a->m_ml->ml_meth));
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000294 x ^= y;
295 if (x == -1)
296 x = -2;
297 return x;
Guido van Rossum9bfef441993-03-29 10:43:31 +0000298}
299
Tim Peters6d6c1a32001-08-02 04:15:00 +0000300
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000301PyTypeObject PyCFunction_Type = {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000302 PyVarObject_HEAD_INIT(&PyType_Type, 0)
303 "builtin_function_or_method",
304 sizeof(PyCFunctionObject),
305 0,
306 (destructor)meth_dealloc, /* tp_dealloc */
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +0200307 offsetof(PyCFunctionObject, vectorcall), /* tp_vectorcall_offset */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000308 0, /* tp_getattr */
309 0, /* tp_setattr */
Jeroen Demeyer530f5062019-05-31 04:13:39 +0200310 0, /* tp_as_async */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000311 (reprfunc)meth_repr, /* tp_repr */
312 0, /* tp_as_number */
313 0, /* tp_as_sequence */
314 0, /* tp_as_mapping */
315 (hashfunc)meth_hash, /* tp_hash */
316 PyCFunction_Call, /* tp_call */
317 0, /* tp_str */
318 PyObject_GenericGetAttr, /* tp_getattro */
319 0, /* tp_setattro */
320 0, /* tp_as_buffer */
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +0200321 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC |
322 _Py_TPFLAGS_HAVE_VECTORCALL, /* tp_flags */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000323 0, /* tp_doc */
324 (traverseproc)meth_traverse, /* tp_traverse */
325 0, /* tp_clear */
326 meth_richcompare, /* tp_richcompare */
Antoine Pitroub349e4c2014-08-06 19:31:40 -0400327 offsetof(PyCFunctionObject, m_weakreflist), /* tp_weaklistoffset */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000328 0, /* tp_iter */
329 0, /* tp_iternext */
Alexandre Vassalotti4c05d3b2013-11-24 02:41:05 -0800330 meth_methods, /* tp_methods */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000331 meth_members, /* tp_members */
332 meth_getsets, /* tp_getset */
333 0, /* tp_base */
334 0, /* tp_dict */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000335};
Guido van Rossum3f5da241990-12-20 15:06:42 +0000336
Guido van Rossum1f39c5c1997-08-05 02:11:41 +0000337/* Clear out the free list */
338
Christian Heimesa156e092008-02-16 07:38:31 +0000339int
340PyCFunction_ClearFreeList(void)
Guido van Rossum1f39c5c1997-08-05 02:11:41 +0000341{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000342 int freelist_size = numfree;
343
344 while (free_list) {
345 PyCFunctionObject *v = free_list;
346 free_list = (PyCFunctionObject *)(v->m_self);
347 PyObject_GC_Del(v);
348 numfree--;
349 }
350 assert(numfree == 0);
351 return freelist_size;
Christian Heimesa156e092008-02-16 07:38:31 +0000352}
353
354void
355PyCFunction_Fini(void)
356{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000357 (void)PyCFunction_ClearFreeList();
Guido van Rossum1f39c5c1997-08-05 02:11:41 +0000358}
Jeremy Hylton4f0dcc92003-01-31 18:33:18 +0000359
David Malcolm49526f42012-06-22 14:55:41 -0400360/* Print summary info about the state of the optimized allocator */
361void
362_PyCFunction_DebugMallocStats(FILE *out)
363{
364 _PyDebugAllocatorStats(out,
Antoine Pitrou36b045f2013-04-11 21:01:40 +0200365 "free PyCFunctionObject",
Antoine Pitrou0811f982012-12-30 22:46:04 +0100366 numfree, sizeof(PyCFunctionObject));
David Malcolm49526f42012-06-22 14:55:41 -0400367}
Jeroen Demeyerbf8e82f2019-07-23 12:39:51 +0200368
369
370/* Vectorcall functions for each of the PyCFunction calling conventions,
371 * except for METH_VARARGS (possibly combined with METH_KEYWORDS) which
372 * doesn't use vectorcall.
373 *
374 * First, common helpers
375 */
376static const char *
377get_name(PyObject *func)
378{
379 assert(PyCFunction_Check(func));
380 PyMethodDef *method = ((PyCFunctionObject *)func)->m_ml;
381 return method->ml_name;
382}
383
384typedef void (*funcptr)(void);
385
386static inline int
387cfunction_check_kwargs(PyObject *func, PyObject *kwnames)
388{
389 assert(!PyErr_Occurred());
390 assert(PyCFunction_Check(func));
391 if (kwnames && PyTuple_GET_SIZE(kwnames)) {
392 PyErr_Format(PyExc_TypeError,
393 "%.200s() takes no keyword arguments", get_name(func));
394 return -1;
395 }
396 return 0;
397}
398
399static inline funcptr
400cfunction_enter_call(PyObject *func)
401{
402 if (Py_EnterRecursiveCall(" while calling a Python object")) {
403 return NULL;
404 }
405 return (funcptr)PyCFunction_GET_FUNCTION(func);
406}
407
408/* Now the actual vectorcall functions */
409static PyObject *
410cfunction_vectorcall_FASTCALL(
411 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
412{
413 if (cfunction_check_kwargs(func, kwnames)) {
414 return NULL;
415 }
416 Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
417 _PyCFunctionFast meth = (_PyCFunctionFast)
418 cfunction_enter_call(func);
419 if (meth == NULL) {
420 return NULL;
421 }
422 PyObject *result = meth(PyCFunction_GET_SELF(func), args, nargs);
423 Py_LeaveRecursiveCall();
424 return result;
425}
426
427static PyObject *
428cfunction_vectorcall_FASTCALL_KEYWORDS(
429 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
430{
431 Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
432 _PyCFunctionFastWithKeywords meth = (_PyCFunctionFastWithKeywords)
433 cfunction_enter_call(func);
434 if (meth == NULL) {
435 return NULL;
436 }
437 PyObject *result = meth(PyCFunction_GET_SELF(func), args, nargs, kwnames);
438 Py_LeaveRecursiveCall();
439 return result;
440}
441
442static PyObject *
443cfunction_vectorcall_NOARGS(
444 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
445{
446 if (cfunction_check_kwargs(func, kwnames)) {
447 return NULL;
448 }
449 Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
450 if (nargs != 0) {
451 PyErr_Format(PyExc_TypeError,
452 "%.200s() takes no arguments (%zd given)", get_name(func), nargs);
453 return NULL;
454 }
455 PyCFunction meth = (PyCFunction)cfunction_enter_call(func);
456 if (meth == NULL) {
457 return NULL;
458 }
459 PyObject *result = meth(PyCFunction_GET_SELF(func), NULL);
460 Py_LeaveRecursiveCall();
461 return result;
462}
463
464static PyObject *
465cfunction_vectorcall_O(
466 PyObject *func, PyObject *const *args, size_t nargsf, PyObject *kwnames)
467{
468 if (cfunction_check_kwargs(func, kwnames)) {
469 return NULL;
470 }
471 Py_ssize_t nargs = PyVectorcall_NARGS(nargsf);
472 if (nargs != 1) {
473 PyErr_Format(PyExc_TypeError,
474 "%.200s() takes exactly one argument (%zd given)",
475 get_name(func), nargs);
476 return NULL;
477 }
478 PyCFunction meth = (PyCFunction)cfunction_enter_call(func);
479 if (meth == NULL) {
480 return NULL;
481 }
482 PyObject *result = meth(PyCFunction_GET_SELF(func), args[0]);
483 Py_LeaveRecursiveCall();
484 return result;
485}