/opt/alt/python311/include/python3.11/internal
#ifndef Py_INTERNAL_TUPLE_H #define Py_INTERNAL_TUPLE_H #ifdef __cplusplus extern "C" { #endif #ifndef Py_BUILD_CORE # error "this header requires Py_BUILD_CORE define" #endif #include "tupleobject.h" /* _PyTuple_CAST() */ /* runtime lifecycle */ extern PyStatus _PyTuple_InitGlobalObjects(PyInterpreterState *); extern PyStatus _PyTuple_InitTypes(PyInterpreterState *); extern void _PyTuple_Fini(PyInterpreterState *); /* other API */ // PyTuple_MAXSAVESIZE - largest tuple to save on free list // PyTuple_MAXFREELIST - maximum number of tuples of each size to save #if defined(PyTuple_MAXSAVESIZE) && PyTuple_MAXSAVESIZE <= 0 // A build indicated that tuple freelists should not be used. # define PyTuple_NFREELISTS 0 # undef PyTuple_MAXSAVESIZE # undef PyTuple_MAXFREELIST #elif !defined(WITH_FREELISTS) # define PyTuple_NFREELISTS 0 # undef PyTuple_MAXSAVESIZE # undef PyTuple_MAXFREELIST #else // We are using a freelist for tuples. # ifndef PyTuple_MAXSAVESIZE # define PyTuple_MAXSAVESIZE 20 # endif # define PyTuple_NFREELISTS PyTuple_MAXSAVESIZE # ifndef PyTuple_MAXFREELIST # define PyTuple_MAXFREELIST 2000 # endif #endif struct _Py_tuple_state { #if PyTuple_NFREELISTS > 0 /* There is one freelist for each size from 1 to PyTuple_MAXSAVESIZE. The empty tuple is handled separately. Each tuple stored in the array is the head of the linked list (and the next available tuple) for that size. The actual tuple object is used as the linked list node, with its first item (ob_item[0]) pointing to the next node (i.e. the previous head). Each linked list is initially NULL. */ PyTupleObject *free_list[PyTuple_NFREELISTS]; int numfree[PyTuple_NFREELISTS]; #else char _unused; // Empty structs are not allowed. #endif }; #define _PyTuple_ITEMS(op) (_PyTuple_CAST(op)->ob_item) extern PyObject *_PyTuple_FromArray(PyObject *const *, Py_ssize_t); extern PyObject *_PyTuple_FromArraySteal(PyObject *const *, Py_ssize_t); #ifdef __cplusplus } #endif #endif /* !Py_INTERNAL_TUPLE_H */
.
Edit
..
Edit
pycore_abstract.h
Edit
pycore_accu.h
Edit
pycore_asdl.h
Edit
pycore_ast.h
Edit
pycore_ast_state.h
Edit
pycore_atomic.h
Edit
pycore_atomic_funcs.h
Edit
pycore_bitutils.h
Edit
pycore_blocks_output_buffer.h
Edit
pycore_bytes_methods.h
Edit
pycore_bytesobject.h
Edit
pycore_call.h
Edit
pycore_ceval.h
Edit
pycore_code.h
Edit
pycore_compile.h
Edit
pycore_condvar.h
Edit
pycore_context.h
Edit
pycore_dict.h
Edit
pycore_dtoa.h
Edit
pycore_emscripten_signal.h
Edit
pycore_exceptions.h
Edit
pycore_fileutils.h
Edit
pycore_floatobject.h
Edit
pycore_format.h
Edit
pycore_frame.h
Edit
pycore_function.h
Edit
pycore_gc.h
Edit
pycore_genobject.h
Edit
pycore_getopt.h
Edit
pycore_gil.h
Edit
pycore_global_objects.h
Edit
pycore_global_strings.h
Edit
pycore_hamt.h
Edit
pycore_hashtable.h
Edit
pycore_import.h
Edit
pycore_initconfig.h
Edit
pycore_interp.h
Edit
pycore_interpreteridobject.h
Edit
pycore_list.h
Edit
pycore_long.h
Edit
pycore_moduleobject.h
Edit
pycore_namespace.h
Edit
pycore_object.h
Edit
pycore_opcode.h
Edit
pycore_parser.h
Edit
pycore_pathconfig.h
Edit
pycore_pyarena.h
Edit
pycore_pyerrors.h
Edit
pycore_pyhash.h
Edit
pycore_pylifecycle.h
Edit
pycore_pymath.h
Edit
pycore_pymem.h
Edit
pycore_pystate.h
Edit
pycore_runtime.h
Edit
pycore_runtime_init.h
Edit
pycore_signal.h
Edit
pycore_sliceobject.h
Edit
pycore_strhex.h
Edit
pycore_structseq.h
Edit
pycore_symtable.h
Edit
pycore_sysmodule.h
Edit
pycore_traceback.h
Edit
pycore_tuple.h
Edit
pycore_typeobject.h
Edit
pycore_ucnhash.h
Edit
pycore_unicodeobject.h
Edit
pycore_unionobject.h
Edit
pycore_warnings.h
Edit