| Guido van Rossum | a330996 | 1993-07-28 09:05:47 +0000 | [diff] [blame] | 1 | #ifndef Py_DICTOBJECT_H | 
 | 2 | #define Py_DICTOBJECT_H | 
 | 3 | #ifdef __cplusplus | 
 | 4 | extern "C" { | 
 | 5 | #endif | 
 | 6 |  | 
| Guido van Rossum | f70e43a | 1991-02-19 12:39:46 +0000 | [diff] [blame] | 7 |  | 
| Guido van Rossum | 2ec9031 | 1997-05-13 21:23:32 +0000 | [diff] [blame] | 8 | /* Dictionary object type -- mapping from hashable object to object */ | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 9 |  | 
| Raymond Hettinger | 930427b | 2003-05-03 06:51:59 +0000 | [diff] [blame] | 10 | /* The distribution includes a separate file, Objects/dictnotes.txt, | 
| Thomas Wouters | 4d70c3d | 2006-06-08 14:42:34 +0000 | [diff] [blame] | 11 |    describing explorations into dictionary design and optimization. | 
| Raymond Hettinger | 930427b | 2003-05-03 06:51:59 +0000 | [diff] [blame] | 12 |    It covers typical dictionary use patterns, the parameters for | 
 | 13 |    tuning dictionaries, and several ideas for possible optimizations. | 
 | 14 | */ | 
 | 15 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 16 | #ifndef Py_LIMITED_API | 
| Tim Peters | 6d6c1a3 | 2001-08-02 04:15:00 +0000 | [diff] [blame] | 17 |  | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 18 | typedef struct _dictkeysobject PyDictKeysObject; | 
 | 19 |  | 
 | 20 | /* The ma_values pointer is NULL for a combined table | 
 | 21 |  * or points to an array of PyObject* for a split table | 
 | 22 |  */ | 
| Tim Peters | 6d6c1a3 | 2001-08-02 04:15:00 +0000 | [diff] [blame] | 23 | typedef struct { | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 24 |     PyObject_HEAD | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 25 |     Py_ssize_t ma_used; | 
 | 26 |     PyDictKeysObject *ma_keys; | 
 | 27 |     PyObject **ma_values; | 
 | 28 | } PyDictObject; | 
| Tim Peters | 6d6c1a3 | 2001-08-02 04:15:00 +0000 | [diff] [blame] | 29 |  | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 30 | #endif /* Py_LIMITED_API */ | 
| Tim Peters | 6d6c1a3 | 2001-08-02 04:15:00 +0000 | [diff] [blame] | 31 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 32 | PyAPI_DATA(PyTypeObject) PyDict_Type; | 
| Christian Heimes | a22e8bd | 2007-11-29 22:35:39 +0000 | [diff] [blame] | 33 | PyAPI_DATA(PyTypeObject) PyDictIterKey_Type; | 
 | 34 | PyAPI_DATA(PyTypeObject) PyDictIterValue_Type; | 
 | 35 | PyAPI_DATA(PyTypeObject) PyDictIterItem_Type; | 
 | 36 | PyAPI_DATA(PyTypeObject) PyDictKeys_Type; | 
 | 37 | PyAPI_DATA(PyTypeObject) PyDictItems_Type; | 
 | 38 | PyAPI_DATA(PyTypeObject) PyDictValues_Type; | 
| Guido van Rossum | 2ec9031 | 1997-05-13 21:23:32 +0000 | [diff] [blame] | 39 |  | 
| Thomas Wouters | 27d517b | 2007-02-25 20:39:11 +0000 | [diff] [blame] | 40 | #define PyDict_Check(op) \ | 
| Christian Heimes | 90aa764 | 2007-12-19 02:45:37 +0000 | [diff] [blame] | 41 |                  PyType_FastSubclass(Py_TYPE(op), Py_TPFLAGS_DICT_SUBCLASS) | 
 | 42 | #define PyDict_CheckExact(op) (Py_TYPE(op) == &PyDict_Type) | 
 | 43 | #define PyDictKeys_Check(op) (Py_TYPE(op) == &PyDictKeys_Type) | 
 | 44 | #define PyDictItems_Check(op) (Py_TYPE(op) == &PyDictItems_Type) | 
 | 45 | #define PyDictValues_Check(op) (Py_TYPE(op) == &PyDictValues_Type) | 
| Christian Heimes | a22e8bd | 2007-11-29 22:35:39 +0000 | [diff] [blame] | 46 | /* This excludes Values, since they are not sets. */ | 
 | 47 | # define PyDictViewSet_Check(op) \ | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 48 |     (PyDictKeys_Check(op) || PyDictItems_Check(op)) | 
| Christian Heimes | a22e8bd | 2007-11-29 22:35:39 +0000 | [diff] [blame] | 49 |  | 
| Guido van Rossum | 2ec9031 | 1997-05-13 21:23:32 +0000 | [diff] [blame] | 50 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 51 | PyAPI_FUNC(PyObject *) PyDict_New(void); | 
 | 52 | PyAPI_FUNC(PyObject *) PyDict_GetItem(PyObject *mp, PyObject *key); | 
| Alexandre Vassalotti | cb31433 | 2008-06-01 03:53:03 +0000 | [diff] [blame] | 53 | PyAPI_FUNC(PyObject *) PyDict_GetItemWithError(PyObject *mp, PyObject *key); | 
| Brett Cannon | fd07415 | 2012-04-14 14:10:13 -0400 | [diff] [blame] | 54 | PyAPI_FUNC(PyObject *) _PyDict_GetItemIdWithError(PyObject *dp, | 
 | 55 |                                                   struct _Py_Identifier *key); | 
| Benjamin Peterson | 00e9886 | 2013-03-07 22:16:29 -0500 | [diff] [blame] | 56 | PyAPI_FUNC(PyObject *) PyDict_SetDefault( | 
 | 57 |     PyObject *mp, PyObject *key, PyObject *defaultobj); | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 58 | PyAPI_FUNC(int) PyDict_SetItem(PyObject *mp, PyObject *key, PyObject *item); | 
 | 59 | PyAPI_FUNC(int) PyDict_DelItem(PyObject *mp, PyObject *key); | 
 | 60 | PyAPI_FUNC(void) PyDict_Clear(PyObject *mp); | 
 | 61 | PyAPI_FUNC(int) PyDict_Next( | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 62 |     PyObject *mp, Py_ssize_t *pos, PyObject **key, PyObject **value); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 63 | #ifndef Py_LIMITED_API | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 64 | PyDictKeysObject *_PyDict_NewKeysForClass(void); | 
 | 65 | PyAPI_FUNC(PyObject *) PyObject_GenericGetDict(PyObject *, void *); | 
| Thomas Wouters | cf297e4 | 2007-02-23 15:07:44 +0000 | [diff] [blame] | 66 | PyAPI_FUNC(int) _PyDict_Next( | 
| Benjamin Peterson | 8f67d08 | 2010-10-17 20:54:53 +0000 | [diff] [blame] | 67 |     PyObject *mp, Py_ssize_t *pos, PyObject **key, PyObject **value, Py_hash_t *hash); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 68 | #endif | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 69 | PyAPI_FUNC(PyObject *) PyDict_Keys(PyObject *mp); | 
 | 70 | PyAPI_FUNC(PyObject *) PyDict_Values(PyObject *mp); | 
 | 71 | PyAPI_FUNC(PyObject *) PyDict_Items(PyObject *mp); | 
| Martin v. Löwis | 18e1655 | 2006-02-15 17:27:45 +0000 | [diff] [blame] | 72 | PyAPI_FUNC(Py_ssize_t) PyDict_Size(PyObject *mp); | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 73 | PyAPI_FUNC(PyObject *) PyDict_Copy(PyObject *mp); | 
| Raymond Hettinger | bc0f2ab | 2003-11-25 21:12:14 +0000 | [diff] [blame] | 74 | PyAPI_FUNC(int) PyDict_Contains(PyObject *mp, PyObject *key); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 75 | #ifndef Py_LIMITED_API | 
| Benjamin Peterson | 8f67d08 | 2010-10-17 20:54:53 +0000 | [diff] [blame] | 76 | PyAPI_FUNC(int) _PyDict_Contains(PyObject *mp, PyObject *key, Py_hash_t hash); | 
| Christian Heimes | 99170a5 | 2007-12-19 02:07:34 +0000 | [diff] [blame] | 77 | PyAPI_FUNC(PyObject *) _PyDict_NewPresized(Py_ssize_t minused); | 
| Antoine Pitrou | 3a652b1 | 2009-03-23 18:52:06 +0000 | [diff] [blame] | 78 | PyAPI_FUNC(void) _PyDict_MaybeUntrack(PyObject *mp); | 
| Benjamin Peterson | fb88636 | 2010-04-24 18:21:17 +0000 | [diff] [blame] | 79 | PyAPI_FUNC(int) _PyDict_HasOnlyStringKeys(PyObject *mp); | 
| Martin v. Loewis | 4f2f3b6 | 2012-04-24 19:13:57 +0200 | [diff] [blame] | 80 | Py_ssize_t _PyDict_KeysSize(PyDictKeysObject *keys); | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 81 | #define _PyDict_HasSplitTable(d) ((d)->ma_values != NULL) | 
| Antoine Pitrou | 9a812cb | 2011-11-15 00:00:12 +0100 | [diff] [blame] | 82 |  | 
 | 83 | PyAPI_FUNC(int) PyDict_ClearFreeList(void); | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 84 | #endif | 
| Jeremy Hylton | a12c7a7 | 2000-03-30 22:27:31 +0000 | [diff] [blame] | 85 |  | 
| Tim Peters | f582b82 | 2001-12-11 18:51:08 +0000 | [diff] [blame] | 86 | /* PyDict_Update(mp, other) is equivalent to PyDict_Merge(mp, other, 1). */ | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 87 | PyAPI_FUNC(int) PyDict_Update(PyObject *mp, PyObject *other); | 
| Tim Peters | f582b82 | 2001-12-11 18:51:08 +0000 | [diff] [blame] | 88 |  | 
 | 89 | /* PyDict_Merge updates/merges from a mapping object (an object that | 
 | 90 |    supports PyMapping_Keys() and PyObject_GetItem()).  If override is true, | 
 | 91 |    the last occurrence of a key wins, else the first.  The Python | 
 | 92 |    dict.update(other) is equivalent to PyDict_Merge(dict, other, 1). | 
 | 93 | */ | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 94 | PyAPI_FUNC(int) PyDict_Merge(PyObject *mp, | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 95 |                                    PyObject *other, | 
 | 96 |                                    int override); | 
| Tim Peters | f582b82 | 2001-12-11 18:51:08 +0000 | [diff] [blame] | 97 |  | 
 | 98 | /* PyDict_MergeFromSeq2 updates/merges from an iterable object producing | 
 | 99 |    iterable objects of length 2.  If override is true, the last occurrence | 
 | 100 |    of a key wins, else the first.  The Python dict constructor dict(seq2) | 
 | 101 |    is equivalent to dict={}; PyDict_MergeFromSeq(dict, seq2, 1). | 
 | 102 | */ | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 103 | PyAPI_FUNC(int) PyDict_MergeFromSeq2(PyObject *d, | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 104 |                                            PyObject *seq2, | 
 | 105 |                                            int override); | 
| Guido van Rossum | 2ec9031 | 1997-05-13 21:23:32 +0000 | [diff] [blame] | 106 |  | 
| Martin v. Löwis | 32b4a1b | 2002-12-11 13:21:12 +0000 | [diff] [blame] | 107 | PyAPI_FUNC(PyObject *) PyDict_GetItemString(PyObject *dp, const char *key); | 
| Victor Stinner | 3c1e481 | 2012-03-26 22:10:51 +0200 | [diff] [blame] | 108 | PyAPI_FUNC(PyObject *) _PyDict_GetItemId(PyObject *dp, struct _Py_Identifier *key); | 
| Martin v. Löwis | 32b4a1b | 2002-12-11 13:21:12 +0000 | [diff] [blame] | 109 | PyAPI_FUNC(int) PyDict_SetItemString(PyObject *dp, const char *key, PyObject *item); | 
| Victor Stinner | 3c1e481 | 2012-03-26 22:10:51 +0200 | [diff] [blame] | 110 | PyAPI_FUNC(int) _PyDict_SetItemId(PyObject *dp, struct _Py_Identifier *key, PyObject *item); | 
| Martin v. Löwis | 32b4a1b | 2002-12-11 13:21:12 +0000 | [diff] [blame] | 111 | PyAPI_FUNC(int) PyDict_DelItemString(PyObject *dp, const char *key); | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 112 |  | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 113 | #ifndef Py_LIMITED_API | 
 | 114 | int _PyObjectDict_SetItem(PyTypeObject *tp, PyObject **dictptr, PyObject *name, PyObject *value); | 
 | 115 | PyObject *_PyDict_LoadGlobal(PyDictObject *, PyDictObject *, PyObject *); | 
| David Malcolm | 49526f4 | 2012-06-22 14:55:41 -0400 | [diff] [blame] | 116 | PyAPI_FUNC(void) _PyDict_DebugMallocStats(FILE *out); | 
| Benjamin Peterson | 7d95e40 | 2012-04-23 11:24:50 -0400 | [diff] [blame] | 117 | #endif | 
 | 118 |  | 
| Guido van Rossum | a330996 | 1993-07-28 09:05:47 +0000 | [diff] [blame] | 119 | #ifdef __cplusplus | 
 | 120 | } | 
 | 121 | #endif | 
 | 122 | #endif /* !Py_DICTOBJECT_H */ |