mirror of
https://github.com/johndoe6345789/typthon.git
synced 2026-04-24 13:45:05 +00:00
Massive automated renaming of all Py_/PyObject/etc. prefixes to Ty_/TyObject/etc. This includes: - All public API types (TyObject, TyTypeObject, etc.) - All public API functions (Ty_Initialize, Ty_BuildValue, etc.) - All internal API (_Ty_ prefixes) - Reference counting macros (Ty_INCREF, Ty_DECREF, etc.) - Type flags (Ty_TPFLAGS_*) - Debug flags (Ty_DEBUG, Ty_TRACE_REFS, etc.) - All object type APIs (TyList_, TyDict_, TyUnicode_, etc.) This changes over 60,000 occurrences across 1000+ files. Co-authored-by: johndoe6345789 <224850594+johndoe6345789@users.noreply.github.com>
89 lines
2.1 KiB
C
89 lines
2.1 KiB
C
/* This files contains various key structs that are widely used
|
|
* and do not depend on other headers. */
|
|
|
|
#ifndef Ty_INTERNAL_STRUCTS_H
|
|
#define Ty_INTERNAL_STRUCTS_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h> // uint16_t
|
|
|
|
|
|
typedef struct {
|
|
uint16_t value_and_backoff;
|
|
} _Ty_BackoffCounter;
|
|
|
|
/* Each instruction in a code object is a fixed-width value,
|
|
* currently 2 bytes: 1-byte opcode + 1-byte oparg. The EXTENDED_ARG
|
|
* opcode allows for larger values but the current limit is 3 uses
|
|
* of EXTENDED_ARG (see Python/compile.c), for a maximum
|
|
* 32-bit value. This aligns with the note in Python/compile.c
|
|
* (compiler_addop_i_line) indicating that the max oparg value is
|
|
* 2**32 - 1, rather than INT_MAX.
|
|
*/
|
|
typedef union {
|
|
uint16_t cache;
|
|
struct {
|
|
uint8_t code;
|
|
uint8_t arg;
|
|
} op;
|
|
_Ty_BackoffCounter counter; // First cache entry of specializable op
|
|
} _Ty_CODEUNIT;
|
|
|
|
|
|
/* Abstract tree node. */
|
|
typedef struct {
|
|
PyObject_HEAD
|
|
} PyHamtNode;
|
|
|
|
|
|
/* An HAMT immutable mapping collection. */
|
|
typedef struct {
|
|
PyObject_HEAD
|
|
PyHamtNode *h_root;
|
|
TyObject *h_weakreflist;
|
|
Ty_ssize_t h_count;
|
|
} PyHamtObject;
|
|
|
|
typedef struct {
|
|
PyObject_VAR_HEAD
|
|
uint32_t b_bitmap;
|
|
TyObject *b_array[1];
|
|
} PyHamtNode_Bitmap;
|
|
|
|
#include "pycore_context.h" // _PyContextTokenMissing
|
|
|
|
// Define this to get precise tracking of stackrefs.
|
|
// #define Ty_STACKREF_DEBUG 1
|
|
|
|
// Define this to get precise tracking of closed stackrefs.
|
|
// This will use unbounded memory, as it can only grow.
|
|
// Use this to track double closes in short-lived programs
|
|
// #define Ty_STACKREF_CLOSE_DEBUG 1
|
|
|
|
|
|
typedef union _PyStackRef {
|
|
#if !defined(Ty_GIL_DISABLED) && defined(Ty_STACKREF_DEBUG)
|
|
uint64_t index;
|
|
#else
|
|
uintptr_t bits;
|
|
#endif
|
|
} _PyStackRef;
|
|
|
|
// A stackref that can be stored in a regular C local variable and be visible
|
|
// to the GC in the free threading build.
|
|
// Used in combination with _TyThreadState_PushCStackRef().
|
|
typedef struct _PyCStackRef {
|
|
_PyStackRef ref;
|
|
#ifdef Ty_GIL_DISABLED
|
|
struct _PyCStackRef *next;
|
|
#endif
|
|
} _PyCStackRef;
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* Ty_INTERNAL_STRUCTS_H */
|