48 lines
1.3 KiB
C
48 lines
1.3 KiB
C
#ifndef Py_CPYTHON_HASH_H
|
|
# error "this header file must not be included directly"
|
|
#endif
|
|
|
|
/* Prime multiplier used in string and various other hashes. */
|
|
#define PyHASH_MULTIPLIER 1000003UL /* 0xf4243 */
|
|
|
|
/* Parameters used for the numeric hash implementation. See notes for
|
|
_Py_HashDouble in Python/pyhash.c. Numeric hashes are based on
|
|
reduction modulo the prime 2**_PyHASH_BITS - 1. */
|
|
|
|
#if SIZEOF_VOID_P >= 8
|
|
# define PyHASH_BITS 61
|
|
#else
|
|
# define PyHASH_BITS 31
|
|
#endif
|
|
|
|
#define PyHASH_MODULUS (((size_t)1 << _PyHASH_BITS) - 1)
|
|
#define PyHASH_INF 314159
|
|
#define PyHASH_IMAG PyHASH_MULTIPLIER
|
|
|
|
/* Aliases kept for backward compatibility with Python 3.12 */
|
|
#define _PyHASH_MULTIPLIER PyHASH_MULTIPLIER
|
|
#define _PyHASH_BITS PyHASH_BITS
|
|
#define _PyHASH_MODULUS PyHASH_MODULUS
|
|
#define _PyHASH_INF PyHASH_INF
|
|
#define _PyHASH_IMAG PyHASH_IMAG
|
|
|
|
/* Helpers for hash functions */
|
|
PyAPI_FUNC(Py_hash_t) _Py_HashDouble(PyObject *, double);
|
|
|
|
// Kept for backward compatibility
|
|
#define _Py_HashPointer Py_HashPointer
|
|
|
|
|
|
/* hash function definition */
|
|
typedef struct {
|
|
Py_hash_t (*const hash)(const void *, Py_ssize_t);
|
|
const char *name;
|
|
const int hash_bits;
|
|
const int seed_bits;
|
|
} PyHash_FuncDef;
|
|
|
|
PyAPI_FUNC(PyHash_FuncDef*) PyHash_GetFuncDef(void);
|
|
|
|
PyAPI_FUNC(Py_hash_t) Py_HashPointer(const void *ptr);
|
|
PyAPI_FUNC(Py_hash_t) PyObject_GenericHash(PyObject *);
|