1/*[clinic input]
2preserve
3[clinic start generated code]*/
4
5PyDoc_STRVAR(_testmultiphase_StateAccessType_get_defining_module__doc__,
6"get_defining_module($self, /)\n"
7"--\n"
8"\n"
9"Return the module of the defining class.\n"
10"\n"
11"Also tests that result of _PyType_GetModuleByDef matches defining_class\'s\n"
12"module.");
13
14#define _TESTMULTIPHASE_STATEACCESSTYPE_GET_DEFINING_MODULE_METHODDEF \
15 {"get_defining_module", (PyCFunction)(void(*)(void))_testmultiphase_StateAccessType_get_defining_module, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _testmultiphase_StateAccessType_get_defining_module__doc__},
16
17static PyObject *
18_testmultiphase_StateAccessType_get_defining_module_impl(StateAccessTypeObject *self,
19 PyTypeObject *cls);
20
21static PyObject *
22_testmultiphase_StateAccessType_get_defining_module(StateAccessTypeObject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
23{
24 if (nargs) {
25 PyErr_SetString(PyExc_TypeError, "get_defining_module() takes no arguments");
26 return NULL;
27 }
28 return _testmultiphase_StateAccessType_get_defining_module_impl(self, cls);
29}
30
31PyDoc_STRVAR(_testmultiphase_StateAccessType_getmodulebydef_bad_def__doc__,
32"getmodulebydef_bad_def($self, /)\n"
33"--\n"
34"\n"
35"Test that result of _PyType_GetModuleByDef with a bad def is NULL.");
36
37#define _TESTMULTIPHASE_STATEACCESSTYPE_GETMODULEBYDEF_BAD_DEF_METHODDEF \
38 {"getmodulebydef_bad_def", (PyCFunction)(void(*)(void))_testmultiphase_StateAccessType_getmodulebydef_bad_def, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _testmultiphase_StateAccessType_getmodulebydef_bad_def__doc__},
39
40static PyObject *
41_testmultiphase_StateAccessType_getmodulebydef_bad_def_impl(StateAccessTypeObject *self,
42 PyTypeObject *cls);
43
44static PyObject *
45_testmultiphase_StateAccessType_getmodulebydef_bad_def(StateAccessTypeObject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
46{
47 if (nargs) {
48 PyErr_SetString(PyExc_TypeError, "getmodulebydef_bad_def() takes no arguments");
49 return NULL;
50 }
51 return _testmultiphase_StateAccessType_getmodulebydef_bad_def_impl(self, cls);
52}
53
54PyDoc_STRVAR(_testmultiphase_StateAccessType_increment_count_clinic__doc__,
55"increment_count_clinic($self, /, n=1, *, twice=False)\n"
56"--\n"
57"\n"
58"Add \'n\' from the module-state counter.\n"
59"\n"
60"Pass \'twice\' to double that amount.\n"
61"\n"
62"This tests Argument Clinic support for defining_class.");
63
64#define _TESTMULTIPHASE_STATEACCESSTYPE_INCREMENT_COUNT_CLINIC_METHODDEF \
65 {"increment_count_clinic", (PyCFunction)(void(*)(void))_testmultiphase_StateAccessType_increment_count_clinic, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _testmultiphase_StateAccessType_increment_count_clinic__doc__},
66
67static PyObject *
68_testmultiphase_StateAccessType_increment_count_clinic_impl(StateAccessTypeObject *self,
69 PyTypeObject *cls,
70 int n, int twice);
71
72static PyObject *
73_testmultiphase_StateAccessType_increment_count_clinic(StateAccessTypeObject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
74{
75 PyObject *return_value = NULL;
76 static const char * const _keywords[] = {"n", "twice", NULL};
77 static _PyArg_Parser _parser = {NULL, _keywords, "increment_count_clinic", 0};
78 PyObject *argsbuf[2];
79 Py_ssize_t noptargs = nargs + (kwnames ? PyTuple_GET_SIZE(kwnames) : 0) - 0;
80 int n = 1;
81 int twice = 0;
82
83 args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, 0, 1, 0, argsbuf);
84 if (!args) {
85 goto exit;
86 }
87 if (!noptargs) {
88 goto skip_optional_pos;
89 }
90 if (args[0]) {
91 n = _PyLong_AsInt(args[0]);
92 if (n == -1 && PyErr_Occurred()) {
93 goto exit;
94 }
95 if (!--noptargs) {
96 goto skip_optional_pos;
97 }
98 }
99skip_optional_pos:
100 if (!noptargs) {
101 goto skip_optional_kwonly;
102 }
103 twice = PyObject_IsTrue(args[1]);
104 if (twice < 0) {
105 goto exit;
106 }
107skip_optional_kwonly:
108 return_value = _testmultiphase_StateAccessType_increment_count_clinic_impl(self, cls, n, twice);
109
110exit:
111 return return_value;
112}
113
114PyDoc_STRVAR(_testmultiphase_StateAccessType_get_count__doc__,
115"get_count($self, /)\n"
116"--\n"
117"\n"
118"Return the value of the module-state counter.");
119
120#define _TESTMULTIPHASE_STATEACCESSTYPE_GET_COUNT_METHODDEF \
121 {"get_count", (PyCFunction)(void(*)(void))_testmultiphase_StateAccessType_get_count, METH_METHOD|METH_FASTCALL|METH_KEYWORDS, _testmultiphase_StateAccessType_get_count__doc__},
122
123static PyObject *
124_testmultiphase_StateAccessType_get_count_impl(StateAccessTypeObject *self,
125 PyTypeObject *cls);
126
127static PyObject *
128_testmultiphase_StateAccessType_get_count(StateAccessTypeObject *self, PyTypeObject *cls, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames)
129{
130 if (nargs) {
131 PyErr_SetString(PyExc_TypeError, "get_count() takes no arguments");
132 return NULL;
133 }
134 return _testmultiphase_StateAccessType_get_count_impl(self, cls);
135}
136/*[clinic end generated code: output=ec5029d1275cbf94 input=a9049054013a1b77]*/
137