summaryrefslogtreecommitdiffstats
path: root/Objects/dictobject.c
diff options
context:
space:
mode:
Diffstat (limited to 'Objects/dictobject.c')
-rw-r--r--Objects/dictobject.c214
1 files changed, 104 insertions, 110 deletions
diff --git a/Objects/dictobject.c b/Objects/dictobject.c
index a749f0a..9cf451f 100644
--- a/Objects/dictobject.c
+++ b/Objects/dictobject.c
@@ -29,19 +29,13 @@ PERFORMANCE OF THIS SOFTWARE.
******************************************************************/
-/* Mapping object implementation; using a hash table */
-
-/* This file should really be called "dictobject.c", since "mapping"
- is the generic name for objects with an unorderred arbitrary key
- set (just like lists are sequences), but since it improves (and was
- originally derived from) a file by that name I had to change its
- name. For the user these objects are still called "dictionaries". */
+/* Dictionaru object implementation using a hash table */
#include "Python.h"
/*
- * MINSIZE is the minimum size of a mapping.
+ * MINSIZE is the minimum size of a dictionary.
*/
#define MINSIZE 4
@@ -84,7 +78,7 @@ static long polys[] = {
};
/* Object used as dummy key to fill deleted entries */
-static PyObject *dummy; /* Initialized by first call to newmappingobject() */
+static PyObject *dummy; /* Initialized by first call to newdictobject() */
/*
Invariant for entries: when in use, de_value is not NULL and de_key is
@@ -99,7 +93,7 @@ typedef struct {
#ifdef USE_CACHE_ALIGNED
long aligner;
#endif
-} mappingentry;
+} dictentry;
/*
To ensure the lookup algorithm terminates, the table size must be a
@@ -115,19 +109,19 @@ typedef struct {
int ma_used;
int ma_size;
int ma_poly;
- mappingentry *ma_table;
-} mappingobject;
+ dictentry *ma_table;
+} dictobject;
PyObject *
PyDict_New()
{
- register mappingobject *mp;
+ register dictobject *mp;
if (dummy == NULL) { /* Auto-initialize dummy */
dummy = PyString_FromString("<dummy key>");
if (dummy == NULL)
return NULL;
}
- mp = PyObject_NEW(mappingobject, &PyDict_Type);
+ mp = PyObject_NEW(dictobject, &PyDict_Type);
if (mp == NULL)
return NULL;
mp->ma_size = 0;
@@ -159,20 +153,20 @@ where x is a root. The initial value is derived from sum, too.
(This version is due to Reimer Behrends, some ideas are also due to
Jyrki Alakuijala.)
*/
-static mappingentry *lookmapping Py_PROTO((mappingobject *, PyObject *, long));
-static mappingentry *
-lookmapping(mp, key, hash)
- mappingobject *mp;
+static dictentry *lookdict Py_PROTO((dictobject *, PyObject *, long));
+static dictentry *
+lookdict(mp, key, hash)
+ dictobject *mp;
PyObject *key;
long hash;
{
register int i;
register unsigned incr;
register unsigned long sum = (unsigned long) hash;
- register mappingentry *freeslot = NULL;
+ register dictentry *freeslot = NULL;
register unsigned int mask = mp->ma_size-1;
- mappingentry *ep0 = mp->ma_table;
- register mappingentry *ep;
+ dictentry *ep0 = mp->ma_table;
+ register dictentry *ep;
/* We must come up with (i, incr) such that 0 <= i < ma_size
and 0 < incr < ma_size and both are a function of hash */
i = (~sum) & mask;
@@ -227,18 +221,18 @@ Internal routine to insert a new item into the table.
Used both by the internal resize routine and by the public insert routine.
Eats a reference to key and one to value.
*/
-static void insertmapping
- Py_PROTO((mappingobject *, PyObject *, long, PyObject *));
+static void insertdict
+ Py_PROTO((dictobject *, PyObject *, long, PyObject *));
static void
-insertmapping(mp, key, hash, value)
- register mappingobject *mp;
+insertdict(mp, key, hash, value)
+ register dictobject *mp;
PyObject *key;
long hash;
PyObject *value;
{
PyObject *old_value;
- register mappingentry *ep;
- ep = lookmapping(mp, key, hash);
+ register dictentry *ep;
+ ep = lookdict(mp, key, hash);
if (ep->me_value != NULL) {
old_value = ep->me_value;
ep->me_value = value;
@@ -262,16 +256,16 @@ Restructure the table by allocating a new table and reinserting all
items again. When entries have been deleted, the new table may
actually be smaller than the old one.
*/
-static int mappingresize Py_PROTO((mappingobject *));
+static int dictresize Py_PROTO((dictobject *));
static int
-mappingresize(mp)
- mappingobject *mp;
+dictresize(mp)
+ dictobject *mp;
{
register int oldsize = mp->ma_size;
register int newsize, newpoly;
- register mappingentry *oldtable = mp->ma_table;
- register mappingentry *newtable;
- register mappingentry *ep;
+ register dictentry *oldtable = mp->ma_table;
+ register dictentry *newtable;
+ register dictentry *ep;
register int i;
newsize = mp->ma_size;
for (i = 0, newsize = MINSIZE; ; i++, newsize <<= 1) {
@@ -285,7 +279,7 @@ mappingresize(mp)
break;
}
}
- newtable = (mappingentry *) calloc(sizeof(mappingentry), newsize);
+ newtable = (dictentry *) calloc(sizeof(dictentry), newsize);
if (newtable == NULL) {
PyErr_NoMemory();
return -1;
@@ -300,7 +294,7 @@ mappingresize(mp)
(and possible side effects) till the table is copied */
for (i = 0, ep = oldtable; i < oldsize; i++, ep++) {
if (ep->me_value != NULL)
- insertmapping(mp,ep->me_key,ep->me_hash,ep->me_value);
+ insertdict(mp,ep->me_key,ep->me_hash,ep->me_value);
}
for (i = 0, ep = oldtable; i < oldsize; i++, ep++) {
if (ep->me_value == NULL)
@@ -321,7 +315,7 @@ PyDict_GetItem(op, key)
PyErr_BadInternalCall();
return NULL;
}
- if (((mappingobject *)op)->ma_table == NULL)
+ if (((dictobject *)op)->ma_table == NULL)
return NULL;
#ifdef CACHE_HASH
if (!PyString_Check(key) ||
@@ -332,7 +326,7 @@ PyDict_GetItem(op, key)
if (hash == -1)
return NULL;
}
- return lookmapping((mappingobject *)op, key, hash) -> me_value;
+ return lookdict((dictobject *)op, key, hash) -> me_value;
}
int
@@ -341,13 +335,13 @@ PyDict_SetItem(op, key, value)
PyObject *key;
PyObject *value;
{
- register mappingobject *mp;
+ register dictobject *mp;
register long hash;
if (!PyDict_Check(op)) {
PyErr_BadInternalCall();
return -1;
}
- mp = (mappingobject *)op;
+ mp = (dictobject *)op;
#ifdef CACHE_HASH
if (PyString_Check(key)) {
#ifdef INTERN_STRINGS
@@ -372,14 +366,14 @@ PyDict_SetItem(op, key, value)
}
/* if fill >= 2/3 size, resize */
if (mp->ma_fill*3 >= mp->ma_size*2) {
- if (mappingresize(mp) != 0) {
+ if (dictresize(mp) != 0) {
if (mp->ma_fill+1 > mp->ma_size)
return -1;
}
}
Py_INCREF(value);
Py_INCREF(key);
- insertmapping(mp, key, hash, value);
+ insertdict(mp, key, hash, value);
return 0;
}
@@ -388,9 +382,9 @@ PyDict_DelItem(op, key)
PyObject *op;
PyObject *key;
{
- register mappingobject *mp;
+ register dictobject *mp;
register long hash;
- register mappingentry *ep;
+ register dictentry *ep;
PyObject *old_value, *old_key;
if (!PyDict_Check(op)) {
@@ -406,10 +400,10 @@ PyDict_DelItem(op, key)
if (hash == -1)
return -1;
}
- mp = (mappingobject *)op;
- if (((mappingobject *)op)->ma_table == NULL)
+ mp = (dictobject *)op;
+ if (((dictobject *)op)->ma_table == NULL)
goto empty;
- ep = lookmapping(mp, key, hash);
+ ep = lookdict(mp, key, hash);
if (ep->me_value == NULL) {
empty:
PyErr_SetObject(PyExc_KeyError, key);
@@ -431,11 +425,11 @@ PyDict_Clear(op)
PyObject *op;
{
int i, n;
- register mappingentry *table;
- mappingobject *mp;
+ register dictentry *table;
+ dictobject *mp;
if (!PyDict_Check(op))
return;
- mp = (mappingobject *)op;
+ mp = (dictobject *)op;
table = mp->ma_table;
if (table == NULL)
return;
@@ -457,10 +451,10 @@ PyDict_Next(op, ppos, pkey, pvalue)
PyObject **pvalue;
{
int i;
- register mappingobject *mp;
+ register dictobject *mp;
if (!PyDict_Check(op))
return 0;
- mp = (mappingobject *)op;
+ mp = (dictobject *)op;
i = *ppos;
if (i < 0)
return 0;
@@ -479,11 +473,11 @@ PyDict_Next(op, ppos, pkey, pvalue)
/* Methods */
static void
-mapping_dealloc(mp)
- register mappingobject *mp;
+dict_dealloc(mp)
+ register dictobject *mp;
{
register int i;
- register mappingentry *ep;
+ register dictentry *ep;
for (i = 0, ep = mp->ma_table; i < mp->ma_size; i++, ep++) {
if (ep->me_key != NULL)
Py_DECREF(ep->me_key);
@@ -495,14 +489,14 @@ mapping_dealloc(mp)
}
static int
-mapping_print(mp, fp, flags)
- register mappingobject *mp;
+dict_print(mp, fp, flags)
+ register dictobject *mp;
register FILE *fp;
register int flags;
{
register int i;
register int any;
- register mappingentry *ep;
+ register dictentry *ep;
fprintf(fp, "{");
any = 0;
for (i = 0, ep = mp->ma_table; i < mp->ma_size; i++, ep++) {
@@ -521,14 +515,14 @@ mapping_print(mp, fp, flags)
}
static PyObject *
-mapping_repr(mp)
- mappingobject *mp;
+dict_repr(mp)
+ dictobject *mp;
{
auto PyObject *v;
PyObject *sepa, *colon;
register int i;
register int any;
- register mappingentry *ep;
+ register dictentry *ep;
v = PyString_FromString("{");
sepa = PyString_FromString(", ");
colon = PyString_FromString(": ");
@@ -549,15 +543,15 @@ mapping_repr(mp)
}
static int
-mapping_length(mp)
- mappingobject *mp;
+dict_length(mp)
+ dictobject *mp;
{
return mp->ma_used;
}
static PyObject *
-mapping_subscript(mp, key)
- mappingobject *mp;
+dict_subscript(mp, key)
+ dictobject *mp;
register PyObject *key;
{
PyObject *v;
@@ -575,7 +569,7 @@ mapping_subscript(mp, key)
if (hash == -1)
return NULL;
}
- v = lookmapping(mp, key, hash) -> me_value;
+ v = lookdict(mp, key, hash) -> me_value;
if (v == NULL)
PyErr_SetObject(PyExc_KeyError, key);
else
@@ -584,8 +578,8 @@ mapping_subscript(mp, key)
}
static int
-mapping_ass_sub(mp, v, w)
- mappingobject *mp;
+dict_ass_sub(mp, v, w)
+ dictobject *mp;
PyObject *v, *w;
{
if (w == NULL)
@@ -594,15 +588,15 @@ mapping_ass_sub(mp, v, w)
return PyDict_SetItem((PyObject *)mp, v, w);
}
-static PyMappingMethods mapping_as_mapping = {
- (inquiry)mapping_length, /*mp_length*/
- (binaryfunc)mapping_subscript, /*mp_subscript*/
- (objobjargproc)mapping_ass_sub, /*mp_ass_subscript*/
+static PyMappingMethods dict_as_mapping = {
+ (inquiry)dict_length, /*mp_length*/
+ (binaryfunc)dict_subscript, /*mp_subscript*/
+ (objobjargproc)dict_ass_sub, /*mp_ass_subscript*/
};
static PyObject *
-mapping_keys(mp, args)
- register mappingobject *mp;
+dict_keys(mp, args)
+ register dictobject *mp;
PyObject *args;
{
register PyObject *v;
@@ -624,8 +618,8 @@ mapping_keys(mp, args)
}
static PyObject *
-mapping_values(mp, args)
- register mappingobject *mp;
+dict_values(mp, args)
+ register dictobject *mp;
PyObject *args;
{
register PyObject *v;
@@ -647,8 +641,8 @@ mapping_values(mp, args)
}
static PyObject *
-mapping_items(mp, args)
- register mappingobject *mp;
+dict_items(mp, args)
+ register dictobject *mp;
PyObject *args;
{
register PyObject *v;
@@ -686,7 +680,7 @@ PyDict_Size(mp)
PyErr_BadInternalCall();
return 0;
}
- return ((mappingobject *)mp)->ma_used;
+ return ((dictobject *)mp)->ma_used;
}
PyObject *
@@ -697,7 +691,7 @@ PyDict_Keys(mp)
PyErr_BadInternalCall();
return NULL;
}
- return mapping_keys((mappingobject *)mp, (PyObject *)NULL);
+ return dict_keys((dictobject *)mp, (PyObject *)NULL);
}
PyObject *
@@ -708,7 +702,7 @@ PyDict_Values(mp)
PyErr_BadInternalCall();
return NULL;
}
- return mapping_values((mappingobject *)mp, (PyObject *)NULL);
+ return dict_values((dictobject *)mp, (PyObject *)NULL);
}
PyObject *
@@ -719,7 +713,7 @@ PyDict_Items(mp)
PyErr_BadInternalCall();
return NULL;
}
- return mapping_items((mappingobject *)mp, (PyObject *)NULL);
+ return dict_items((dictobject *)mp, (PyObject *)NULL);
}
#define NEWCMP
@@ -732,8 +726,8 @@ PyDict_Items(mp)
static PyObject *
characterize(a, b, pval)
- mappingobject *a;
- mappingobject *b;
+ dictobject *a;
+ dictobject *b;
PyObject **pval;
{
PyObject *diff = NULL;
@@ -759,8 +753,8 @@ characterize(a, b, pval)
}
static int
-mapping_compare(a, b)
- mappingobject *a, *b;
+dict_compare(a, b)
+ dictobject *a, *b;
{
PyObject *adiff, *bdiff, *aval, *bval;
int res;
@@ -785,8 +779,8 @@ mapping_compare(a, b)
#else /* !NEWCMP */
static int
-mapping_compare(a, b)
- mappingobject *a, *b;
+dict_compare(a, b)
+ dictobject *a, *b;
{
PyObject *akeys, *bkeys;
int i, n, res;
@@ -802,8 +796,8 @@ mapping_compare(a, b)
if (b->ma_used == 0)
return 1;
}
- akeys = mapping_keys(a, (PyObject *)NULL);
- bkeys = mapping_keys(b, (PyObject *)NULL);
+ akeys = dict_keys(a, (PyObject *)NULL);
+ bkeys = dict_keys(b, (PyObject *)NULL);
if (akeys == NULL || bkeys == NULL) {
/* Oops, out of memory -- what to do? */
/* For now, sort on address! */
@@ -844,8 +838,8 @@ mapping_compare(a, b)
if (bhash == -1)
PyErr_Clear(); /* Don't want errors here */
}
- aval = lookmapping(a, akey, ahash) -> me_value;
- bval = lookmapping(b, bkey, bhash) -> me_value;
+ aval = lookdict(a, akey, ahash) -> me_value;
+ bval = lookdict(b, bkey, bhash) -> me_value;
res = PyObject_Compare(aval, bval);
if (res != 0)
break;
@@ -864,8 +858,8 @@ mapping_compare(a, b)
#endif /* !NEWCMP */
static PyObject *
-mapping_has_key(mp, args)
- register mappingobject *mp;
+dict_has_key(mp, args)
+ register dictobject *mp;
PyObject *args;
{
PyObject *key;
@@ -882,13 +876,13 @@ mapping_has_key(mp, args)
if (hash == -1)
return NULL;
}
- ok = mp->ma_size != 0 && lookmapping(mp, key, hash)->me_value != NULL;
+ ok = mp->ma_size != 0 && lookdict(mp, key, hash)->me_value != NULL;
return PyInt_FromLong(ok);
}
static PyObject *
-mapping_clear(mp, args)
- register mappingobject *mp;
+dict_clear(mp, args)
+ register dictobject *mp;
PyObject *args;
{
if (!PyArg_NoArgs(args))
@@ -899,17 +893,17 @@ mapping_clear(mp, args)
}
static PyMethodDef mapp_methods[] = {
- {"clear", (PyCFunction)mapping_clear},
- {"has_key", (PyCFunction)mapping_has_key},
- {"items", (PyCFunction)mapping_items},
- {"keys", (PyCFunction)mapping_keys},
- {"values", (PyCFunction)mapping_values},
+ {"clear", (PyCFunction)dict_clear},
+ {"has_key", (PyCFunction)dict_has_key},
+ {"items", (PyCFunction)dict_items},
+ {"keys", (PyCFunction)dict_keys},
+ {"values", (PyCFunction)dict_values},
{NULL, NULL} /* sentinel */
};
static PyObject *
-mapping_getattr(mp, name)
- mappingobject *mp;
+dict_getattr(mp, name)
+ dictobject *mp;
char *name;
{
return Py_FindMethod(mapp_methods, (PyObject *)mp, name);
@@ -919,17 +913,17 @@ PyTypeObject PyDict_Type = {
PyObject_HEAD_INIT(&PyType_Type)
0,
"dictionary",
- sizeof(mappingobject),
+ sizeof(dictobject),
0,
- (destructor)mapping_dealloc, /*tp_dealloc*/
- (printfunc)mapping_print, /*tp_print*/
- (getattrfunc)mapping_getattr, /*tp_getattr*/
+ (destructor)dict_dealloc, /*tp_dealloc*/
+ (printfunc)dict_print, /*tp_print*/
+ (getattrfunc)dict_getattr, /*tp_getattr*/
0, /*tp_setattr*/
- (cmpfunc)mapping_compare, /*tp_compare*/
- (reprfunc)mapping_repr, /*tp_repr*/
+ (cmpfunc)dict_compare, /*tp_compare*/
+ (reprfunc)dict_repr, /*tp_repr*/
0, /*tp_as_number*/
0, /*tp_as_sequence*/
- &mapping_as_mapping, /*tp_as_mapping*/
+ &dict_as_mapping, /*tp_as_mapping*/
};
/* For backward compatibility with old dictionary interface */