404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.147.8.200: ~ $
#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


#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;


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


PyAPI_DATA(PyTypeObject) _PyHamt_Type;
PyAPI_DATA(PyTypeObject) _PyHamt_ArrayNode_Type;
PyAPI_DATA(PyTypeObject) _PyHamt_BitmapNode_Type;
PyAPI_DATA(PyTypeObject) _PyHamt_CollisionNode_Type;
PyAPI_DATA(PyTypeObject) _PyHamtKeys_Type;
PyAPI_DATA(PyTypeObject) _PyHamtValues_Type;
PyAPI_DATA(PyTypeObject) _PyHamtItems_Type;


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

int _PyHamt_Init(void);
void _PyHamt_Fini(void);

#endif /* !Py_INTERNAL_HAMT_H */

Filemanager

Name Type Size Permission Actions
pycore_abstract.h File 479 B 0644
pycore_accu.h File 1.1 KB 0644
pycore_asdl.h File 2.9 KB 0644
pycore_ast.h File 28.15 KB 0644
pycore_ast_state.h File 6.31 KB 0644
pycore_atomic.h File 16.58 KB 0644
pycore_atomic_funcs.h File 2.38 KB 0644
pycore_bitutils.h File 5.15 KB 0644
pycore_blocks_output_buffer.h File 8.48 KB 0644
pycore_bytes_methods.h File 3.3 KB 0644
pycore_call.h File 870 B 0644
pycore_ceval.h File 3.4 KB 0644
pycore_code.h File 696 B 0644
pycore_compile.h File 1.02 KB 0644
pycore_condvar.h File 2.74 KB 0644
pycore_context.h File 822 B 0644
pycore_dtoa.h File 646 B 0644
pycore_fileutils.h File 1.66 KB 0644
pycore_format.h File 480 B 0644
pycore_gc.h File 6.7 KB 0644
pycore_getopt.h File 490 B 0644
pycore_gil.h File 1.53 KB 0644
pycore_hamt.h File 3.61 KB 0644
pycore_hashtable.h File 4.1 KB 0644
pycore_import.h File 346 B 0644
pycore_initconfig.h File 5.49 KB 0644
pycore_interp.h File 9.07 KB 0644
pycore_list.h File 350 B 0644
pycore_long.h File 2.53 KB 0644
pycore_moduleobject.h File 1.02 KB 0644
pycore_object.h File 5.85 KB 0644
pycore_parser.h File 626 B 0644
pycore_pathconfig.h File 1.93 KB 0644
pycore_pyarena.h File 2.67 KB 0644
pycore_pyerrors.h File 2.26 KB 0644
pycore_pyhash.h File 206 B 0644
pycore_pylifecycle.h File 4.82 KB 0644
pycore_pymem.h File 3.14 KB 0644
pycore_pystate.h File 3.85 KB 0644
pycore_runtime.h File 4.79 KB 0644
pycore_structseq.h File 386 B 0644
pycore_symtable.h File 5.45 KB 0644
pycore_sysmodule.h File 548 B 0644
pycore_traceback.h File 2.9 KB 0644
pycore_tuple.h File 425 B 0644
pycore_ucnhash.h File 898 B 0644
pycore_unionobject.h File 629 B 0644
pycore_warnings.h File 633 B 0644