]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-104469: Convert _testcapi/vectorcall_limited.c to use AC (#109691)
authorVictor Stinner <vstinner@python.org>
Mon, 25 Sep 2023 11:24:19 +0000 (13:24 +0200)
committerGitHub <noreply@github.com>
Mon, 25 Sep 2023 11:24:19 +0000 (13:24 +0200)
Co-authored-by: nahyeon <55136494+nahyeon-an@users.noreply.github.com>
Modules/_testcapi/clinic/vectorcall_limited.c.h [new file with mode: 0644]
Modules/_testcapi/vectorcall_limited.c

diff --git a/Modules/_testcapi/clinic/vectorcall_limited.c.h b/Modules/_testcapi/clinic/vectorcall_limited.c.h
new file mode 100644 (file)
index 0000000..a233aef
--- /dev/null
@@ -0,0 +1,20 @@
+/*[clinic input]
+preserve
+[clinic start generated code]*/
+
+PyDoc_STRVAR(_testcapi_call_vectorcall__doc__,
+"call_vectorcall($module, callable, /)\n"
+"--\n"
+"\n");
+
+#define _TESTCAPI_CALL_VECTORCALL_METHODDEF    \
+    {"call_vectorcall", (PyCFunction)_testcapi_call_vectorcall, METH_O, _testcapi_call_vectorcall__doc__},
+
+PyDoc_STRVAR(_testcapi_call_vectorcall_method__doc__,
+"call_vectorcall_method($module, callable, /)\n"
+"--\n"
+"\n");
+
+#define _TESTCAPI_CALL_VECTORCALL_METHOD_METHODDEF    \
+    {"call_vectorcall_method", (PyCFunction)_testcapi_call_vectorcall_method, METH_O, _testcapi_call_vectorcall_method__doc__},
+/*[clinic end generated code: output=e980906a39602528 input=a9049054013a1b77]*/
index e981c8625c2fb23b995a6c7a4cc1006eaf4bc5f6..3e81903098f95489a41648cba3262a2080fde94c 100644 (file)
@@ -1,7 +1,13 @@
+/* Test Vectorcall in the limited API */
+
 #define Py_LIMITED_API 0x030c0000 // 3.12
 #include "parts.h"
+#include "clinic/vectorcall_limited.c.h"
 
-/* Test Vectorcall in the limited API */
+/*[clinic input]
+module _testcapi
+[clinic start generated code]*/
+/*[clinic end generated code: output=da39a3ee5e6b4b0d input=6361033e795369fc]*/
 
 static PyObject *
 LimitedVectorCallClass_tpcall(PyObject *self, PyObject *args, PyObject *kwargs) {
@@ -28,8 +34,16 @@ LimitedVectorCallClass_new(PyTypeObject *tp, PyTypeObject *a, PyTypeObject *kw)
     return self;
 }
 
+/*[clinic input]
+_testcapi.call_vectorcall
+
+    callable: object
+    /
+[clinic start generated code]*/
+
 static PyObject *
-call_vectorcall(PyObject* self, PyObject *callable)
+_testcapi_call_vectorcall(PyObject *module, PyObject *callable)
+/*[clinic end generated code: output=bae81eec97fcaad7 input=55d88f92240957ee]*/
 {
     PyObject *args[3] = { NULL, NULL, NULL };
     PyObject *kwname = NULL, *kwnames = NULL, *result = NULL;
@@ -73,8 +87,16 @@ leave:
     return result;
 }
 
+/*[clinic input]
+_testcapi.call_vectorcall_method
+
+    callable: object
+    /
+[clinic start generated code]*/
+
 static PyObject *
-call_vectorcall_method(PyObject* self, PyObject *callable)
+_testcapi_call_vectorcall_method(PyObject *module, PyObject *callable)
+/*[clinic end generated code: output=e661f48dda08b6fb input=5ba81c27511395b6]*/
 {
     PyObject *args[3] = { NULL, NULL, NULL };
     PyObject *name = NULL, *kwname = NULL,
@@ -149,8 +171,8 @@ static PyType_Spec LimitedVectorCallClass_spec = {
 };
 
 static PyMethodDef TestMethods[] = {
-    {"call_vectorcall", call_vectorcall, METH_O},
-    {"call_vectorcall_method", call_vectorcall_method, METH_O},
+    _TESTCAPI_CALL_VECTORCALL_METHODDEF
+    _TESTCAPI_CALL_VECTORCALL_METHOD_METHODDEF
     {NULL},
 };