/* Set object interface */ #ifndef Py_SETOBJECT_H #define Py_SETOBJECT_H #ifdef __cplusplus extern "C" { #endif #ifndef Py_LIMITED_API /* There are three kinds of entries in the table: 1. Unused: key == NULL and hash == 0 2. Dummy: key == dummy and hash == -1 3. Active: key != NULL and key != dummy and hash != -1 The hash field of Unused slots is always zero. The hash field of Dummy slots are set to -1 meaning that dummy entries can be detected by either entry->key==dummy or by entry->hash==-1. */ #define PySet_MINSIZE 8 typedef struct { PyObject *key; Py_hash_t hash; /* Cached hash code of the key */ } setentry; /* The SetObject data structure is shared by set and frozenset objects. Invariant for sets: - hash is -1 Invariants for frozensets: - data is immutable. - hash is the hash of the frozenset or -1 if not computed yet. */ typedef struct { PyObject_HEAD Py_ssize_t fill; /* Number active and dummy entries*/ Py_ssize_t used; /* Number active entries */ /* The table contains mask + 1 slots, and that's a power of 2. * We store the mask instead of the size because the mask is more * frequently needed. */ Py_ssize_t mask; /* The table points to a fixed-size smalltable for small tables * or to additional malloc'ed memory for bigger tables. * The table pointer is never NULL which saves us from repeated * runtime null-tests. */ setentry *table; Py_hash_t hash; /* Only used by frozenset objects */ Py_ssize_t finger; /* Search finger for pop() */ setentry smalltable[PySet_MINSIZE]; PyObject *weakreflist; /* List of weak references */ } PySetObject; #define PySet_GET_SIZE(so) (((PySetObject *)(so))->used) PyAPI_DATA(PyObject *) _PySet_Dummy; PyAPI_FUNC(int) _PySet_NextEntry(PyObject *set, Py_ssize_t *pos, PyObject **key, Py_hash_t *hash); PyAPI_FUNC(int) _PySet_Update(PyObject *set, PyObject *iterable); PyAPI_FUNC(int) PySet_ClearFreeList(void); #endif /* Section excluded by Py_LIMITED_API */ PyAPI_DATA(PyTypeObject) PySet_Type; PyAPI_DATA(PyTypeObject) PyFrozenSet_Type; PyAPI_DATA(PyTypeObject) PySetIter_Type; PyAPI_FUNC(PyObject *) PySet_New(PyObject *); PyAPI_FUNC(PyObject *) PyFrozenSet_New(PyObject *); PyAPI_FUNC(int) PySet_Add(PyObject *set, PyObject *key); PyAPI_FUNC(int) PySet_Clear(PyObject *set); PyAPI_FUNC(int) PySet_Contains(PyObject *anyset, PyObject *key); PyAPI_FUNC(int) PySet_Discard(PyObject *set, PyObject *key); PyAPI_FUNC(PyObject *) PySet_Pop(PyObject *set); PyAPI_FUNC(Py_ssize_t) PySet_Size(PyObject *anyset); #define PyFrozenSet_CheckExact(ob) (Py_TYPE(ob) == &PyFrozenSet_Type) #define PyAnySet_CheckExact(ob) \ (Py_TYPE(ob) == &PySet_Type || Py_TYPE(ob) == &PyFrozenSet_Type) #define PyAnySet_Check(ob) \ (Py_TYPE(ob) == &PySet_Type || Py_TYPE(ob) == &PyFrozenSet_Type || \ PyType_IsSubtype(Py_TYPE(ob), &PySet_Type) || \ PyType_IsSubtype(Py_TYPE(ob), &PyFrozenSet_Type)) #define PySet_Check(ob) \ (Py_TYPE(ob) == &PySet_Type || \ PyType_IsSubtype(Py_TYPE(ob), &PySet_Type)) #define PyFrozenSet_Check(ob) \ (Py_TYPE(ob) == &PyFrozenSet_Type || \ PyType_IsSubtype(Py_TYPE(ob), &PyFrozenSet_Type)) #ifdef __cplusplus } #endif #endif /* !Py_SETOBJECT_H */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Python-ast.h | File | 21.75 KB | 0644 |
|
Python.h | File | 3.15 KB | 0644 |
|
abstract.h | File | 46.34 KB | 0644 |
|
accu.h | File | 1016 B | 0644 |
|
asdl.h | File | 1.18 KB | 0644 |
|
ast.h | File | 477 B | 0644 |
|
bitset.h | File | 792 B | 0644 |
|
bltinmodule.h | File | 264 B | 0644 |
|
boolobject.h | File | 886 B | 0644 |
|
bytearrayobject.h | File | 2.06 KB | 0644 |
|
bytes_methods.h | File | 3.12 KB | 0644 |
|
bytesobject.h | File | 8.17 KB | 0644 |
|
cellobject.h | File | 701 B | 0644 |
|
ceval.h | File | 8.32 KB | 0644 |
|
classobject.h | File | 1.63 KB | 0644 |
|
code.h | File | 5.81 KB | 0644 |
|
codecs.h | File | 6.63 KB | 0644 |
|
compile.h | File | 2.11 KB | 0644 |
|
complexobject.h | File | 1.76 KB | 0644 |
|
datetime.h | File | 9.19 KB | 0644 |
|
descrobject.h | File | 2.89 KB | 0644 |
|
dictobject.h | File | 7.01 KB | 0644 |
|
dtoa.h | File | 458 B | 0644 |
|
dynamic_annotations.h | File | 21.94 KB | 0644 |
|
enumobject.h | File | 253 B | 0644 |
|
errcode.h | File | 1.46 KB | 0644 |
|
eval.h | File | 597 B | 0644 |
|
fileobject.h | File | 1.61 KB | 0644 |
|
fileutils.h | File | 3.44 KB | 0644 |
|
floatobject.h | File | 4.68 KB | 0644 |
|
frameobject.h | File | 3.45 KB | 0644 |
|
funcobject.h | File | 3.98 KB | 0644 |
|
genobject.h | File | 3.5 KB | 0644 |
|
graminit.h | File | 1.92 KB | 0644 |
|
grammar.h | File | 2.03 KB | 0644 |
|
import.h | File | 4.13 KB | 0644 |
|
intrcheck.h | File | 513 B | 0644 |
|
iterobject.h | File | 567 B | 0644 |
|
listobject.h | File | 2.83 KB | 0644 |
|
longintrepr.h | File | 3.67 KB | 0644 |
|
longobject.h | File | 8.27 KB | 0644 |
|
marshal.h | File | 803 B | 0644 |
|
memoryobject.h | File | 2.7 KB | 0644 |
|
metagrammar.h | File | 253 B | 0644 |
|
methodobject.h | File | 3.76 KB | 0644 |
|
modsupport.h | File | 7.15 KB | 0644 |
|
moduleobject.h | File | 2.23 KB | 0644 |
|
namespaceobject.h | File | 349 B | 0644 |
|
node.h | File | 1007 B | 0644 |
|
object.h | File | 39.43 KB | 0644 |
|
objimpl.h | File | 13.91 KB | 0644 |
|
odictobject.h | File | 1.26 KB | 0644 |
|
opcode.h | File | 4.95 KB | 0644 |
|
osdefs.h | File | 691 B | 0644 |
|
osmodule.h | File | 291 B | 0644 |
|
parsetok.h | File | 2.82 KB | 0644 |
|
patchlevel.h | File | 1.1 KB | 0644 |
|
pgen.h | File | 253 B | 0644 |
|
pgenheaders.h | File | 1.15 KB | 0644 |
|
py_curses.h | File | 4.21 KB | 0644 |
|
pyarena.h | File | 2.68 KB | 0644 |
|
pyatomic.h | File | 7.94 KB | 0644 |
|
pycapsule.h | File | 1.69 KB | 0644 |
|
pyconfig.h | File | 3.99 KB | 0644 |
|
pyctype.h | File | 1.29 KB | 0644 |
|
pydebug.h | File | 1.18 KB | 0644 |
|
pydtrace.h | File | 1.92 KB | 0644 |
|
pyerrors.h | File | 16.82 KB | 0644 |
|
pyexpat.h | File | 2.39 KB | 0644 |
|
pyfpe.h | File | 8.27 KB | 0644 |
|
pygetopt.h | File | 410 B | 0644 |
|
pyhash.h | File | 4.04 KB | 0644 |
|
pylifecycle.h | File | 3.98 KB | 0644 |
|
pymacconfig.h | File | 2.92 KB | 0644 |
|
pymacro.h | File | 3.42 KB | 0644 |
|
pymath.h | File | 8.12 KB | 0644 |
|
pymem.h | File | 8.36 KB | 0644 |
|
pyport.h | File | 26.93 KB | 0644 |
|
pystate.h | File | 10.88 KB | 0644 |
|
pystrcmp.h | File | 436 B | 0644 |
|
pystrhex.h | File | 495 B | 0644 |
|
pystrtod.h | File | 1.45 KB | 0644 |
|
pythonrun.h | File | 6.62 KB | 0644 |
|
pythread.h | File | 2.92 KB | 0644 |
|
pytime.h | File | 7.43 KB | 0644 |
|
rangeobject.h | File | 629 B | 0644 |
|
setobject.h | File | 3.25 KB | 0644 |
|
sliceobject.h | File | 2.43 KB | 0644 |
|
structmember.h | File | 1.97 KB | 0644 |
|
structseq.h | File | 1.32 KB | 0644 |
|
symtable.h | File | 4.88 KB | 0644 |
|
sysmodule.h | File | 1.32 KB | 0644 |
|
token.h | File | 1.9 KB | 0644 |
|
traceback.h | File | 3.56 KB | 0644 |
|
tupleobject.h | File | 2.39 KB | 0644 |
|
typeslots.h | File | 2.2 KB | 0644 |
|
ucnhash.h | File | 1.03 KB | 0644 |
|
unicodeobject.h | File | 79.86 KB | 0644 |
|
warnings.h | File | 1.65 KB | 0644 |
|
weakrefobject.h | File | 2.8 KB | 0644 |
|