mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			304 lines
		
	
	
	
		
			9.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
		
			Generated
		
	
	
			
		
		
	
	
			304 lines
		
	
	
	
		
			9.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
		
			Generated
		
	
	
/*[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, 1, 1, 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, 6, 6, 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, 1, 1, 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=8809d7aa11d9b2bb input=a9049054013a1b77]*/
 |