Spaces:
Runtime error
Runtime error
| typedef uint16_t _Py_CODEUNIT; | |
| typedef struct _PyOpcache _PyOpcache; | |
| /* Bytecode object */ | |
| struct PyCodeObject { | |
| PyObject_HEAD | |
| int co_argcount; /* #arguments, except *args */ | |
| int co_posonlyargcount; /* #positional only arguments */ | |
| int co_kwonlyargcount; /* #keyword only arguments */ | |
| int co_nlocals; /* #local variables */ | |
| int co_stacksize; /* #entries needed for evaluation stack */ | |
| int co_flags; /* CO_..., see below */ | |
| int co_firstlineno; /* first source line number */ | |
| PyObject *co_code; /* instruction opcodes */ | |
| PyObject *co_consts; /* list (constants used) */ | |
| PyObject *co_names; /* list of strings (names used) */ | |
| PyObject *co_varnames; /* tuple of strings (local variable names) */ | |
| PyObject *co_freevars; /* tuple of strings (free variable names) */ | |
| PyObject *co_cellvars; /* tuple of strings (cell variable names) */ | |
| /* The rest aren't used in either hash or comparisons, except for co_name, | |
| used in both. This is done to preserve the name and line number | |
| for tracebacks and debuggers; otherwise, constant de-duplication | |
| would collapse identical functions/lambdas defined on different lines. | |
| */ | |
| Py_ssize_t *co_cell2arg; /* Maps cell vars which are arguments. */ | |
| PyObject *co_filename; /* unicode (where it was loaded from) */ | |
| PyObject *co_name; /* unicode (name, for reference) */ | |
| PyObject *co_linetable; /* string (encoding addr<->lineno mapping) See | |
| Objects/lnotab_notes.txt for details. */ | |
| void *co_zombieframe; /* for optimization only (see frameobject.c) */ | |
| PyObject *co_weakreflist; /* to support weakrefs to code objects */ | |
| /* Scratch space for extra data relating to the code object. | |
| Type is a void* to keep the format private in codeobject.c to force | |
| people to go through the proper APIs. */ | |
| void *co_extra; | |
| /* Per opcodes just-in-time cache | |
| * | |
| * To reduce cache size, we use indirect mapping from opcode index to | |
| * cache object: | |
| * cache = co_opcache[co_opcache_map[next_instr - first_instr] - 1] | |
| */ | |
| // co_opcache_map is indexed by (next_instr - first_instr). | |
| // * 0 means there is no cache for this opcode. | |
| // * n > 0 means there is cache in co_opcache[n-1]. | |
| unsigned char *co_opcache_map; | |
| _PyOpcache *co_opcache; | |
| int co_opcache_flag; // used to determine when create a cache. | |
| unsigned char co_opcache_size; // length of co_opcache. | |
| }; | |
| /* Masks for co_flags above */ | |
| /* The CO_NOFREE flag is set if there are no free or cell variables. | |
| This information is redundant, but it allows a single flag test | |
| to determine whether there is any extra work to be done when the | |
| call frame it setup. | |
| */ | |
| /* The CO_COROUTINE flag is set for coroutine functions (defined with | |
| ``async def`` keywords) */ | |
| /* bpo-39562: These constant values are changed in Python 3.9 | |
| to prevent collision with compiler flags. CO_FUTURE_ and PyCF_ | |
| constants must be kept unique. PyCF_ constants can use bits from | |
| 0x0100 to 0x10000. CO_FUTURE_ constants use bits starting at 0x20000. */ | |
| /* This value is found in the co_cell2arg array when the associated cell | |
| variable does not correspond to an argument. */ | |
| /* This should be defined if a future statement modifies the syntax. | |
| For example, when a keyword is added. | |
| */ | |
| PyAPI_DATA(PyTypeObject) PyCode_Type; | |
| /* Public interface */ | |
| PyAPI_FUNC(PyCodeObject *) PyCode_New( | |
| int, int, int, int, int, PyObject *, PyObject *, | |
| PyObject *, PyObject *, PyObject *, PyObject *, | |
| PyObject *, PyObject *, int, PyObject *); | |
| PyAPI_FUNC(PyCodeObject *) PyCode_NewWithPosOnlyArgs( | |
| int, int, int, int, int, int, PyObject *, PyObject *, | |
| PyObject *, PyObject *, PyObject *, PyObject *, | |
| PyObject *, PyObject *, int, PyObject *); | |
| /* same as struct above */ | |
| /* Creates a new empty code object with the specified source location. */ | |
| PyAPI_FUNC(PyCodeObject *) | |
| PyCode_NewEmpty(const char *filename, const char *funcname, int firstlineno); | |
| /* Return the line number associated with the specified bytecode index | |
| in this code object. If you just need the line number of a frame, | |
| use PyFrame_GetLineNumber() instead. */ | |
| PyAPI_FUNC(int) PyCode_Addr2Line(PyCodeObject *, int); | |
| /* for internal use only */ | |
| struct _opaque { | |
| int computed_line; | |
| const char *lo_next; | |
| const char *limit; | |
| }; | |
| typedef struct _line_offsets { | |
| int ar_start; | |
| int ar_end; | |
| int ar_line; | |
| struct _opaque opaque; | |
| } PyCodeAddressRange; | |
| /* Update *bounds to describe the first and one-past-the-last instructions in the | |
| same line as lasti. Return the number of that line. | |
| */ | |
| PyAPI_FUNC(int) _PyCode_CheckLineNumber(int lasti, PyCodeAddressRange *bounds); | |
| /* Create a comparable key used to compare constants taking in account the | |
| * object type. It is used to make sure types are not coerced (e.g., float and | |
| * complex) _and_ to distinguish 0.0 from -0.0 e.g. on IEEE platforms | |
| * | |
| * Return (type(obj), obj, ...): a tuple with variable size (at least 2 items) | |
| * depending on the type and the value. The type is the first item to not | |
| * compare bytes and str which can raise a BytesWarning exception. */ | |
| PyAPI_FUNC(PyObject*) _PyCode_ConstantKey(PyObject *obj); | |
| PyAPI_FUNC(PyObject*) PyCode_Optimize(PyObject *code, PyObject* consts, | |
| PyObject *names, PyObject *lnotab); | |
| PyAPI_FUNC(int) _PyCode_GetExtra(PyObject *code, Py_ssize_t index, | |
| void **extra); | |
| PyAPI_FUNC(int) _PyCode_SetExtra(PyObject *code, Py_ssize_t index, | |
| void *extra); | |
| /** API for initializing the line number table. */ | |
| int _PyCode_InitAddressRange(PyCodeObject* co, PyCodeAddressRange *bounds); | |
| /** Out of process API for initializing the line number table. */ | |
| void PyLineTable_InitAddressRange(const char *linetable, Py_ssize_t length, int firstlineno, PyCodeAddressRange *range); | |
| /** API for traversing the line number table. */ | |
| int PyLineTable_NextAddressRange(PyCodeAddressRange *range); | |
| int PyLineTable_PreviousAddressRange(PyCodeAddressRange *range); | |