/* Set object interface */ #ifndef Py_SETOBJECT_H #define Py_SETOBJECT_H #ifdef __cplusplus extern "C" { #endif /* There are three kinds of slots in the table: 1. Unused: key == NULL 2. Active: key != NULL and key != dummy 3. Dummy: key == dummy Note: .pop() abuses the hash field of an Unused or Dummy slot to hold a search finger. The hash field of Unused or Dummy slots has no meaning otherwise. */ #ifndef Py_LIMITED_API #define PySet_MINSIZE 8 typedef struct { /* Cached hash code of the key. */ PyObject *key; Py_hash_t hash; } setentry; /* This data structure is shared by set and frozenset objects. */ typedef struct _setobject PySetObject; struct _setobject { PyObject_HEAD Py_ssize_t fill; /* # Active + # Dummy */ Py_ssize_t used; /* # Active */ /* 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; /* table points to smalltable for small tables, else to * additional malloc'ed memory. table is never NULL! This rule * saves repeated runtime null-tests. */ setentry *table; setentry *(*lookup)(PySetObject *so, PyObject *key, Py_hash_t hash); Py_hash_t hash; /* only used by frozenset objects */ setentry smalltable[PySet_MINSIZE]; PyObject *weakreflist; /* List of weak references */ }; #endif /* Py_LIMITED_API */ PyAPI_DATA(PyTypeObject) PySet_Type; PyAPI_DATA(PyTypeObject) PyFrozenSet_Type; PyAPI_DATA(PyTypeObject) PySetIter_Type; #ifndef Py_LIMITED_API PyAPI_DATA(PyObject *) _PySet_Dummy; #endif /* Invariants for frozensets: * data is immutable. * hash is the hash of the frozenset or -1 if not computed yet. * Invariants for sets: * hash is -1 */ #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)) PyAPI_FUNC(PyObject *) PySet_New(PyObject *); PyAPI_FUNC(PyObject *) PyFrozenSet_New(PyObject *); PyAPI_FUNC(Py_ssize_t) PySet_Size(PyObject *anyset); #ifndef Py_LIMITED_API #define PySet_GET_SIZE(so) (((PySetObject *)(so))->used) #endif 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(int) PySet_Add(PyObject *set, PyObject *key); #ifndef Py_LIMITED_API PyAPI_FUNC(int) _PySet_NextEntry(PyObject *set, Py_ssize_t *pos, PyObject **key, Py_hash_t *hash); #endif PyAPI_FUNC(PyObject *) PySet_Pop(PyObject *set); #ifndef Py_LIMITED_API PyAPI_FUNC(int) _PySet_Update(PyObject *set, PyObject *iterable); PyAPI_FUNC(int) PySet_ClearFreeList(void); #endif #ifdef __cplusplus } #endif #endif /* !Py_SETOBJECT_H */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Python-ast.h | File | 19.03 KB | 0644 |
|
Python.h | File | 2.79 KB | 0644 |
|
abstract.h | File | 42.07 KB | 0644 |
|
accu.h | File | 1016 B | 0644 |
|
asdl.h | File | 1.16 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 | 1.98 KB | 0644 |
|
bytesobject.h | File | 4.81 KB | 0644 |
|
cellobject.h | File | 701 B | 0644 |
|
ceval.h | File | 7.03 KB | 0644 |
|
classobject.h | File | 1.63 KB | 0644 |
|
code.h | File | 4.13 KB | 0644 |
|
codecs.h | File | 6.4 KB | 0644 |
|
compile.h | File | 2.07 KB | 0644 |
|
complexobject.h | File | 1.91 KB | 0644 |
|
datetime.h | File | 8.34 KB | 0644 |
|
descrobject.h | File | 2.84 KB | 0644 |
|
dictobject.h | File | 5.06 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.82 KB | 0644 |
|
fileutils.h | File | 1.47 KB | 0644 |
|
floatobject.h | File | 4.53 KB | 0644 |
|
frameobject.h | File | 3.47 KB | 0644 |
|
funcobject.h | File | 3.68 KB | 0644 |
|
genobject.h | File | 1.1 KB | 0644 |
|
graminit.h | File | 1.83 KB | 0644 |
|
grammar.h | File | 2 KB | 0644 |
|
import.h | File | 3.81 KB | 0644 |
|
intrcheck.h | File | 460 B | 0644 |
|
iterobject.h | File | 567 B | 0644 |
|
listobject.h | File | 2.77 KB | 0644 |
|
longintrepr.h | File | 3.9 KB | 0644 |
|
longobject.h | File | 7.98 KB | 0644 |
|
marshal.h | File | 803 B | 0644 |
|
memoryobject.h | File | 2.79 KB | 0644 |
|
metagrammar.h | File | 253 B | 0644 |
|
methodobject.h | File | 3.23 KB | 0644 |
|
modsupport.h | File | 4.78 KB | 0644 |
|
moduleobject.h | File | 1.58 KB | 0644 |
|
namespaceobject.h | File | 297 B | 0644 |
|
node.h | File | 1008 B | 0644 |
|
object.h | File | 37.62 KB | 0644 |
|
objimpl.h | File | 13.52 KB | 0644 |
|
opcode.h | File | 5.09 KB | 0644 |
|
osdefs.h | File | 848 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.12 KB | 0644 |
|
py_curses.h | File | 4.08 KB | 0644 |
|
pyarena.h | File | 2.68 KB | 0644 |
|
pyatomic.h | File | 5.8 KB | 0644 |
|
pycapsule.h | File | 1.69 KB | 0644 |
|
pyconfig-64.h | File | 42.32 KB | 0644 |
|
pyconfig.h | File | 162 B | 0644 |
|
pyctype.h | File | 1.29 KB | 0644 |
|
pydebug.h | File | 1019 B | 0644 |
|
pyerrors.h | File | 15.65 KB | 0644 |
|
pyexpat.h | File | 2.39 KB | 0644 |
|
pyfpe.h | File | 8.29 KB | 0644 |
|
pygetopt.h | File | 388 B | 0644 |
|
pyhash.h | File | 4.17 KB | 0644 |
|
pymacconfig.h | File | 2.92 KB | 0644 |
|
pymacro.h | File | 2.75 KB | 0644 |
|
pymath.h | File | 7.05 KB | 0644 |
|
pymem.h | File | 6.62 KB | 0644 |
|
pyport.h | File | 30.15 KB | 0644 |
|
pystate.h | File | 8.91 KB | 0644 |
|
pystrcmp.h | File | 436 B | 0644 |
|
pystrtod.h | File | 1.25 KB | 0644 |
|
pythonrun.h | File | 9.95 KB | 0644 |
|
pythread.h | File | 2.96 KB | 0644 |
|
pytime.h | File | 2.85 KB | 0644 |
|
rangeobject.h | File | 629 B | 0644 |
|
setobject.h | File | 3.22 KB | 0644 |
|
sliceobject.h | File | 1.55 KB | 0644 |
|
structmember.h | File | 2.02 KB | 0644 |
|
structseq.h | File | 1.32 KB | 0644 |
|
symtable.h | File | 4.98 KB | 0644 |
|
sysmodule.h | File | 1.32 KB | 0644 |
|
token.h | File | 1.84 KB | 0644 |
|
traceback.h | File | 2.16 KB | 0644 |
|
tupleobject.h | File | 2.39 KB | 0644 |
|
typeslots.h | File | 1.95 KB | 0644 |
|
ucnhash.h | File | 1.03 KB | 0644 |
|
unicodeobject.h | File | 76.3 KB | 0644 |
|
warnings.h | File | 1.39 KB | 0644 |
|
weakrefobject.h | File | 2.8 KB | 0644 |
|