Files
typthon/Include/internal/pycore_structs.h
copilot-swe-agent[bot] b198f511d2 Rename Py_ to Ty_ throughout C API
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>
2025-12-29 17:37:49 +00:00

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 */