Submit
Path:
~
/
/
opt
/
alt
/
python312
/
include
/
python3.12
/
internal
/
File Content:
pycore_hamt.h
#ifndef Py_INTERNAL_HAMT_H #define Py_INTERNAL_HAMT_H #ifndef Py_BUILD_CORE # error "this header requires Py_BUILD_CORE define" #endif /* HAMT tree is shaped by hashes of keys. Every group of 5 bits of a hash denotes the exact position of the key in one level of the tree. Since we're using 32 bit hashes, we can have at most 7 such levels. Although if there are two distinct keys with equal hashes, they will have to occupy the same cell in the 7th level of the tree -- so we'd put them in a "collision" node. Which brings the total possible tree depth to 8. Read more about the actual layout of the HAMT tree in `hamt.c`. This constant is used to define a datastucture for storing iteration state. */ #define _Py_HAMT_MAX_TREE_DEPTH 8 extern PyTypeObject _PyHamt_Type; extern PyTypeObject _PyHamt_ArrayNode_Type; extern PyTypeObject _PyHamt_BitmapNode_Type; extern PyTypeObject _PyHamt_CollisionNode_Type; extern PyTypeObject _PyHamtKeys_Type; extern PyTypeObject _PyHamtValues_Type; extern PyTypeObject _PyHamtItems_Type; /* other API */ #define PyHamt_Check(o) Py_IS_TYPE((o), &_PyHamt_Type) /* Abstract tree node. */ typedef struct { PyObject_HEAD } PyHamtNode; /* An HAMT immutable mapping collection. */ typedef struct { PyObject_HEAD PyHamtNode *h_root; PyObject *h_weakreflist; Py_ssize_t h_count; } PyHamtObject; typedef struct { PyObject_VAR_HEAD uint32_t b_bitmap; PyObject *b_array[1]; } PyHamtNode_Bitmap; /* A struct to hold the state of depth-first traverse of the tree. HAMT is an immutable collection. Iterators will hold a strong reference to it, and every node in the HAMT has strong references to its children. So for iterators, we can implement zero allocations and zero reference inc/dec depth-first iteration. - i_nodes: an array of seven pointers to tree nodes - i_level: the current node in i_nodes - i_pos: an array of positions within nodes in i_nodes. */ typedef struct { PyHamtNode *i_nodes[_Py_HAMT_MAX_TREE_DEPTH]; Py_ssize_t i_pos[_Py_HAMT_MAX_TREE_DEPTH]; int8_t i_level; } PyHamtIteratorState; /* Base iterator object. Contains the iteration state, a pointer to the HAMT tree, and a pointer to the 'yield function'. The latter is a simple function that returns a key/value tuple for the 'Items' iterator, just a key for the 'Keys' iterator, and a value for the 'Values' iterator. */ typedef struct { PyObject_HEAD PyHamtObject *hi_obj; PyHamtIteratorState hi_iter; binaryfunc hi_yield; } PyHamtIterator; /* Create a new HAMT immutable mapping. */ PyHamtObject * _PyHamt_New(void); /* Return a new collection based on "o", but with an additional key/val pair. */ PyHamtObject * _PyHamt_Assoc(PyHamtObject *o, PyObject *key, PyObject *val); /* Return a new collection based on "o", but without "key". */ PyHamtObject * _PyHamt_Without(PyHamtObject *o, PyObject *key); /* Find "key" in the "o" collection. Return: - -1: An error occurred. - 0: "key" wasn't found in "o". - 1: "key" is in "o"; "*val" is set to its value (a borrowed ref). */ int _PyHamt_Find(PyHamtObject *o, PyObject *key, PyObject **val); /* Check if "v" is equal to "w". Return: - 0: v != w - 1: v == w - -1: An error occurred. */ int _PyHamt_Eq(PyHamtObject *v, PyHamtObject *w); /* Return the size of "o"; equivalent of "len(o)". */ Py_ssize_t _PyHamt_Len(PyHamtObject *o); /* Return a Keys iterator over "o". */ PyObject * _PyHamt_NewIterKeys(PyHamtObject *o); /* Return a Values iterator over "o". */ PyObject * _PyHamt_NewIterValues(PyHamtObject *o); /* Return a Items iterator over "o". */ PyObject * _PyHamt_NewIterItems(PyHamtObject *o); #endif /* !Py_INTERNAL_HAMT_H */
Submit
FILE
FOLDER
Name
Size
Permission
Action
pycore_abstract.h
611 bytes
0644
pycore_asdl.h
3035 bytes
0644
pycore_ast.h
31288 bytes
0644
pycore_ast_state.h
6749 bytes
0644
pycore_atexit.h
1149 bytes
0644
pycore_atomic.h
16979 bytes
0644
pycore_atomic_funcs.h
2438 bytes
0644
pycore_bitutils.h
6062 bytes
0644
pycore_blocks_output_buffer.h
8688 bytes
0644
pycore_bytes_methods.h
3384 bytes
0644
pycore_bytesobject.h
1339 bytes
0644
pycore_call.h
3920 bytes
0644
pycore_ceval.h
5265 bytes
0644
pycore_ceval_state.h
2744 bytes
0644
pycore_code.h
15835 bytes
0644
pycore_compile.h
3453 bytes
0644
pycore_condvar.h
2909 bytes
0644
pycore_context.h
1301 bytes
0644
pycore_descrobject.h
499 bytes
0644
pycore_dict.h
6384 bytes
0644
pycore_dict_state.h
1095 bytes
0644
pycore_dtoa.h
1615 bytes
0644
pycore_emscripten_signal.h
562 bytes
0644
pycore_exceptions.h
842 bytes
0644
pycore_faulthandler.h
2220 bytes
0644
pycore_fileutils.h
7910 bytes
0644
pycore_fileutils_windows.h
2724 bytes
0644
pycore_floatobject.h
1578 bytes
0644
pycore_flowgraph.h
4630 bytes
0644
pycore_format.h
480 bytes
0644
pycore_frame.h
9255 bytes
0644
pycore_function.h
611 bytes
0644
pycore_gc.h
7658 bytes
0644
pycore_genobject.h
1186 bytes
0644
pycore_getopt.h
490 bytes
0644
pycore_gil.h
1565 bytes
0644
pycore_global_objects.h
3035 bytes
0644
pycore_global_objects_fini_generated.h
115361 bytes
0644
pycore_global_strings.h
25438 bytes
0644
pycore_hamt.h
3742 bytes
0644
pycore_hashtable.h
4286 bytes
0644
pycore_import.h
6358 bytes
0644
pycore_initconfig.h
5706 bytes
0644
pycore_instruments.h
2998 bytes
0644
pycore_interp.h
9086 bytes
0644
pycore_intrinsics.h
1397 bytes
0644
pycore_list.h
1980 bytes
0644
pycore_long.h
7805 bytes
0644
pycore_memoryobject.h
383 bytes
0644
pycore_moduleobject.h
1192 bytes
0644
pycore_namespace.h
392 bytes
0644
pycore_object.h
14917 bytes
0644
pycore_object_state.h
1016 bytes
0644
pycore_obmalloc.h
27284 bytes
0644
pycore_obmalloc_init.h
2085 bytes
0644
pycore_opcode.h
20081 bytes
0644
pycore_opcode_utils.h
2686 bytes
0644
pycore_parser.h
1358 bytes
0644
pycore_pathconfig.h
606 bytes
0644
pycore_pyarena.h
2733 bytes
0644
pycore_pyerrors.h
3110 bytes
0644
pycore_pyhash.h
709 bytes
0644
pycore_pylifecycle.h
3365 bytes
0644
pycore_pymath.h
8600 bytes
0644
pycore_pymem.h
3040 bytes
0644
pycore_pymem_init.h
2654 bytes
0644
pycore_pystate.h
4982 bytes
0644
pycore_pythread.h
2075 bytes
0644
pycore_range.h
346 bytes
0644
pycore_runtime.h
8429 bytes
0644
pycore_runtime_init.h
5912 bytes
0644
pycore_runtime_init_generated.h
45751 bytes
0644
pycore_signal.h
2611 bytes
0644
pycore_sliceobject.h
414 bytes
0644
pycore_strhex.h
937 bytes
0644
pycore_structseq.h
923 bytes
0644
pycore_symtable.h
7035 bytes
0644
pycore_sysmodule.h
999 bytes
0644
pycore_time.h
388 bytes
0644
pycore_token.h
3050 bytes
0644
pycore_traceback.h
3501 bytes
0644
pycore_tracemalloc.h
3075 bytes
0644
pycore_tuple.h
2197 bytes
0644
pycore_typeobject.h
4731 bytes
0644
pycore_typevarobject.h
763 bytes
0644
pycore_ucnhash.h
898 bytes
0644
pycore_unicodeobject.h
2657 bytes
0644
pycore_unicodeobject_generated.h
125516 bytes
0644
pycore_unionobject.h
682 bytes
0644
pycore_warnings.h
740 bytes
0644
N4ST4R_ID | Naxtarrr