/*[clinic input] preserve [clinic start generated code]*/ #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) # include "pycore_gc.h" // PyGC_Head # include "pycore_runtime.h" // _Py_ID() #endif #include "pycore_modsupport.h" // _PyArg_NoKeywords() PyDoc_STRVAR(inst_seq_new__doc__, "InstructionSequenceType()\n" "--\n" "\n" "Create a new InstructionSequence object."); static PyObject * inst_seq_new_impl(PyTypeObject *type); static PyObject * inst_seq_new(PyTypeObject *type, PyObject *args, PyObject *kwargs) { PyObject *return_value = NULL; PyTypeObject *base_tp = &_PyInstructionSequence_Type; if ((type == base_tp || type->tp_init == base_tp->tp_init) && !_PyArg_NoPositional("InstructionSequenceType", args)) { goto exit; } if ((type == base_tp || type->tp_init == base_tp->tp_init) && !_PyArg_NoKeywords("InstructionSequenceType", kwargs)) { goto exit; } return_value = inst_seq_new_impl(type); exit: return return_value; } PyDoc_STRVAR(InstructionSequenceType_use_label__doc__, "use_label($self, /, label)\n" "--\n" "\n" "Place label at current location."); #define INSTRUCTIONSEQUENCETYPE_USE_LABEL_METHODDEF \ {"use_label", _PyCFunction_CAST(InstructionSequenceType_use_label), METH_FASTCALL|METH_KEYWORDS, InstructionSequenceType_use_label__doc__}, static PyObject * InstructionSequenceType_use_label_impl(_PyInstructionSequence *self, int label); static PyObject * InstructionSequenceType_use_label(_PyInstructionSequence *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) { PyObject *return_value = NULL; #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) #define NUM_KEYWORDS 1 static struct { PyGC_Head _this_is_not_used; PyObject_VAR_HEAD PyObject *ob_item[NUM_KEYWORDS]; } _kwtuple = { .ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS) .ob_item = { &_Py_ID(label), }, }; #undef NUM_KEYWORDS #define KWTUPLE (&_kwtuple.ob_base.ob_base) #else // !Py_BUILD_CORE # define KWTUPLE NULL #endif // !Py_BUILD_CORE static const char * const _keywords[] = {"label", NULL}; static _PyArg_Parser _parser = { .keywords = _keywords, .fname = "use_label", .kwtuple = KWTUPLE, }; #undef KWTUPLE PyObject *argsbuf[1]; int label; args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, /*minpos*/ 1, /*maxpos*/ 1, /*minkw*/ 0, /*varpos*/ 0, argsbuf); if (!args) { goto exit; } label = PyLong_AsInt(args[0]); if (label == -1 && PyErr_Occurred()) { goto exit; } return_value = InstructionSequenceType_use_label_impl(self, label); exit: return return_value; } PyDoc_STRVAR(InstructionSequenceType_addop__doc__, "addop($self, /, opcode, oparg, lineno, col_offset, end_lineno,\n" " end_col_offset)\n" "--\n" "\n" "Append an instruction."); #define INSTRUCTIONSEQUENCETYPE_ADDOP_METHODDEF \ {"addop", _PyCFunction_CAST(InstructionSequenceType_addop), METH_FASTCALL|METH_KEYWORDS, InstructionSequenceType_addop__doc__}, static PyObject * InstructionSequenceType_addop_impl(_PyInstructionSequence *self, int opcode, int oparg, int lineno, int col_offset, int end_lineno, int end_col_offset); static PyObject * InstructionSequenceType_addop(_PyInstructionSequence *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) { PyObject *return_value = NULL; #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) #define NUM_KEYWORDS 6 static struct { PyGC_Head _this_is_not_used; PyObject_VAR_HEAD PyObject *ob_item[NUM_KEYWORDS]; } _kwtuple = { .ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS) .ob_item = { &_Py_ID(opcode), &_Py_ID(oparg), &_Py_ID(lineno), &_Py_ID(col_offset), &_Py_ID(end_lineno), &_Py_ID(end_col_offset), }, }; #undef NUM_KEYWORDS #define KWTUPLE (&_kwtuple.ob_base.ob_base) #else // !Py_BUILD_CORE # define KWTUPLE NULL #endif // !Py_BUILD_CORE static const char * const _keywords[] = {"opcode", "oparg", "lineno", "col_offset", "end_lineno", "end_col_offset", NULL}; static _PyArg_Parser _parser = { .keywords = _keywords, .fname = "addop", .kwtuple = KWTUPLE, }; #undef KWTUPLE PyObject *argsbuf[6]; int opcode; int oparg; int lineno; int col_offset; int end_lineno; int end_col_offset; args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, /*minpos*/ 6, /*maxpos*/ 6, /*minkw*/ 0, /*varpos*/ 0, argsbuf); if (!args) { goto exit; } opcode = PyLong_AsInt(args[0]); if (opcode == -1 && PyErr_Occurred()) { goto exit; } oparg = PyLong_AsInt(args[1]); if (oparg == -1 && PyErr_Occurred()) { goto exit; } lineno = PyLong_AsInt(args[2]); if (lineno == -1 && PyErr_Occurred()) { goto exit; } col_offset = PyLong_AsInt(args[3]); if (col_offset == -1 && PyErr_Occurred()) { goto exit; } end_lineno = PyLong_AsInt(args[4]); if (end_lineno == -1 && PyErr_Occurred()) { goto exit; } end_col_offset = PyLong_AsInt(args[5]); if (end_col_offset == -1 && PyErr_Occurred()) { goto exit; } return_value = InstructionSequenceType_addop_impl(self, opcode, oparg, lineno, col_offset, end_lineno, end_col_offset); exit: return return_value; } PyDoc_STRVAR(InstructionSequenceType_new_label__doc__, "new_label($self, /)\n" "--\n" "\n" "Return a new label."); #define INSTRUCTIONSEQUENCETYPE_NEW_LABEL_METHODDEF \ {"new_label", (PyCFunction)InstructionSequenceType_new_label, METH_NOARGS, InstructionSequenceType_new_label__doc__}, static int InstructionSequenceType_new_label_impl(_PyInstructionSequence *self); static PyObject * InstructionSequenceType_new_label(_PyInstructionSequence *self, PyObject *Py_UNUSED(ignored)) { PyObject *return_value = NULL; int _return_value; _return_value = InstructionSequenceType_new_label_impl(self); if ((_return_value == -1) && PyErr_Occurred()) { goto exit; } return_value = PyLong_FromLong((long)_return_value); exit: return return_value; } PyDoc_STRVAR(InstructionSequenceType_add_nested__doc__, "add_nested($self, /, nested)\n" "--\n" "\n" "Add a nested sequence."); #define INSTRUCTIONSEQUENCETYPE_ADD_NESTED_METHODDEF \ {"add_nested", _PyCFunction_CAST(InstructionSequenceType_add_nested), METH_FASTCALL|METH_KEYWORDS, InstructionSequenceType_add_nested__doc__}, static PyObject * InstructionSequenceType_add_nested_impl(_PyInstructionSequence *self, PyObject *nested); static PyObject * InstructionSequenceType_add_nested(_PyInstructionSequence *self, PyObject *const *args, Py_ssize_t nargs, PyObject *kwnames) { PyObject *return_value = NULL; #if defined(Py_BUILD_CORE) && !defined(Py_BUILD_CORE_MODULE) #define NUM_KEYWORDS 1 static struct { PyGC_Head _this_is_not_used; PyObject_VAR_HEAD PyObject *ob_item[NUM_KEYWORDS]; } _kwtuple = { .ob_base = PyVarObject_HEAD_INIT(&PyTuple_Type, NUM_KEYWORDS) .ob_item = { &_Py_ID(nested), }, }; #undef NUM_KEYWORDS #define KWTUPLE (&_kwtuple.ob_base.ob_base) #else // !Py_BUILD_CORE # define KWTUPLE NULL #endif // !Py_BUILD_CORE static const char * const _keywords[] = {"nested", NULL}; static _PyArg_Parser _parser = { .keywords = _keywords, .fname = "add_nested", .kwtuple = KWTUPLE, }; #undef KWTUPLE PyObject *argsbuf[1]; PyObject *nested; args = _PyArg_UnpackKeywords(args, nargs, NULL, kwnames, &_parser, /*minpos*/ 1, /*maxpos*/ 1, /*minkw*/ 0, /*varpos*/ 0, argsbuf); if (!args) { goto exit; } nested = args[0]; return_value = InstructionSequenceType_add_nested_impl(self, nested); exit: return return_value; } PyDoc_STRVAR(InstructionSequenceType_get_nested__doc__, "get_nested($self, /)\n" "--\n" "\n" "Add a nested sequence."); #define INSTRUCTIONSEQUENCETYPE_GET_NESTED_METHODDEF \ {"get_nested", (PyCFunction)InstructionSequenceType_get_nested, METH_NOARGS, InstructionSequenceType_get_nested__doc__}, static PyObject * InstructionSequenceType_get_nested_impl(_PyInstructionSequence *self); static PyObject * InstructionSequenceType_get_nested(_PyInstructionSequence *self, PyObject *Py_UNUSED(ignored)) { return InstructionSequenceType_get_nested_impl(self); } PyDoc_STRVAR(InstructionSequenceType_get_instructions__doc__, "get_instructions($self, /)\n" "--\n" "\n" "Return the instructions as a list of tuples or labels."); #define INSTRUCTIONSEQUENCETYPE_GET_INSTRUCTIONS_METHODDEF \ {"get_instructions", (PyCFunction)InstructionSequenceType_get_instructions, METH_NOARGS, InstructionSequenceType_get_instructions__doc__}, static PyObject * InstructionSequenceType_get_instructions_impl(_PyInstructionSequence *self); static PyObject * InstructionSequenceType_get_instructions(_PyInstructionSequence *self, PyObject *Py_UNUSED(ignored)) { return InstructionSequenceType_get_instructions_impl(self); } /*[clinic end generated code: output=35163e5b589b4446 input=a9049054013a1b77]*/