Current Path: > > opt > alt > python310 > include > > python3.10 > cpython >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
abstract.h | File | 14054 bytes | June 03 2025 18:23:41. | |
bytearrayobject.h | File | 769 bytes | June 03 2025 18:23:41. | |
bytesobject.h | File | 4353 bytes | June 03 2025 18:23:41. | |
ceval.h | File | 1468 bytes | June 03 2025 18:23:41. | |
code.h | File | 7570 bytes | June 03 2025 18:23:41. | |
compile.h | File | 2218 bytes | June 03 2025 18:23:41. | |
dictobject.h | File | 3734 bytes | June 03 2025 18:23:41. | |
fileobject.h | File | 723 bytes | June 03 2025 18:23:41. | |
fileutils.h | File | 4267 bytes | June 03 2025 18:23:41. | |
frameobject.h | File | 3152 bytes | June 03 2025 18:23:41. | |
import.h | File | 1630 bytes | June 03 2025 18:23:41. | |
initconfig.h | File | 7597 bytes | June 03 2025 18:23:41. | |
interpreteridobject.h | File | 387 bytes | June 03 2025 18:23:41. | |
listobject.h | File | 1243 bytes | June 03 2025 18:23:41. | |
methodobject.h | File | 1399 bytes | June 03 2025 18:23:41. | |
object.h | File | 19613 bytes | June 03 2025 18:23:41. | |
objimpl.h | File | 3356 bytes | June 03 2025 18:23:41. | |
odictobject.h | File | 1299 bytes | June 03 2025 18:23:41. | |
picklebufobject.h | File | 846 bytes | June 03 2025 18:23:41. | |
pyctype.h | File | 1387 bytes | June 03 2025 18:23:41. | |
pydebug.h | File | 1093 bytes | June 03 2025 18:23:41. | |
pyerrors.h | File | 5476 bytes | June 03 2025 18:23:41. | |
pyfpe.h | File | 444 bytes | June 03 2025 18:23:41. | |
pylifecycle.h | File | 2095 bytes | June 03 2025 18:23:41. | |
pymem.h | File | 3379 bytes | June 03 2025 18:23:41. | |
pystate.h | File | 11914 bytes | June 03 2025 18:23:41. | |
pythonrun.h | File | 4811 bytes | June 03 2025 18:23:41. | |
pytime.h | File | 9196 bytes | June 03 2025 18:23:41. | |
sysmodule.h | File | 506 bytes | June 03 2025 18:23:41. | |
traceback.h | File | 404 bytes | June 03 2025 18:23:41. | |
tupleobject.h | File | 975 bytes | June 03 2025 18:23:41. | |
unicodeobject.h | File | 45113 bytes | June 03 2025 18:23:41. |
#ifndef Py_CPYTHON_OBJIMPL_H # error "this header file must not be included directly" #endif #define _PyObject_SIZE(typeobj) ( (typeobj)->tp_basicsize ) /* _PyObject_VAR_SIZE returns the number of bytes (as size_t) allocated for a vrbl-size object with nitems items, exclusive of gc overhead (if any). The value is rounded up to the closest multiple of sizeof(void *), in order to ensure that pointer fields at the end of the object are correctly aligned for the platform (this is of special importance for subclasses of, e.g., str or int, so that pointers can be stored after the embedded data). Note that there's no memory wastage in doing this, as malloc has to return (at worst) pointer-aligned memory anyway. */ #if ((SIZEOF_VOID_P - 1) & SIZEOF_VOID_P) != 0 # error "_PyObject_VAR_SIZE requires SIZEOF_VOID_P be a power of 2" #endif #define _PyObject_VAR_SIZE(typeobj, nitems) \ _Py_SIZE_ROUND_UP((typeobj)->tp_basicsize + \ (nitems)*(typeobj)->tp_itemsize, \ SIZEOF_VOID_P) /* This example code implements an object constructor with a custom allocator, where PyObject_New is inlined, and shows the important distinction between two steps (at least): 1) the actual allocation of the object storage; 2) the initialization of the Python specific fields in this storage with PyObject_{Init, InitVar}. PyObject * YourObject_New(...) { PyObject *op; op = (PyObject *) Your_Allocator(_PyObject_SIZE(YourTypeStruct)); if (op == NULL) { return PyErr_NoMemory(); } PyObject_Init(op, &YourTypeStruct); op->ob_field = value; ... return op; } Note that in C++, the use of the new operator usually implies that the 1st step is performed automatically for you, so in a C++ class constructor you would start directly with PyObject_Init/InitVar. */ /* This function returns the number of allocated memory blocks, regardless of size */ PyAPI_FUNC(Py_ssize_t) _Py_GetAllocatedBlocks(void); /* Macros */ #ifdef WITH_PYMALLOC PyAPI_FUNC(int) _PyObject_DebugMallocStats(FILE *out); #endif typedef struct { /* user context passed as the first argument to the 2 functions */ void *ctx; /* allocate an arena of size bytes */ void* (*alloc) (void *ctx, size_t size); /* free an arena */ void (*free) (void *ctx, void *ptr, size_t size); } PyObjectArenaAllocator; /* Get the arena allocator. */ PyAPI_FUNC(void) PyObject_GetArenaAllocator(PyObjectArenaAllocator *allocator); /* Set the arena allocator. */ PyAPI_FUNC(void) PyObject_SetArenaAllocator(PyObjectArenaAllocator *allocator); /* Test if an object implements the garbage collector protocol */ PyAPI_FUNC(int) PyObject_IS_GC(PyObject *obj); /* Code built with Py_BUILD_CORE must include pycore_gc.h instead which defines a different _PyGC_FINALIZED() macro. */ #ifndef Py_BUILD_CORE // Kept for backward compatibility with Python 3.8 # define _PyGC_FINALIZED(o) PyObject_GC_IsFinalized(o) #endif PyAPI_FUNC(PyObject *) _PyObject_GC_Malloc(size_t size); PyAPI_FUNC(PyObject *) _PyObject_GC_Calloc(size_t size); /* Test if a type supports weak references */ #define PyType_SUPPORTS_WEAKREFS(t) ((t)->tp_weaklistoffset > 0) PyAPI_FUNC(PyObject **) PyObject_GET_WEAKREFS_LISTPTR(PyObject *op);
SILENT KILLER Tool