diff options
Diffstat (limited to 'Objects/dictobject.c')
| -rw-r--r-- | Objects/dictobject.c | 63 | 
1 files changed, 33 insertions, 30 deletions
| diff --git a/Objects/dictobject.c b/Objects/dictobject.c index e04ab2b92f..7a3ed42f0f 100644 --- a/Objects/dictobject.c +++ b/Objects/dictobject.c @@ -321,7 +321,7 @@ static PyDictKeysObject *new_keys_object(Py_ssize_t size)      assert(size >= PyDict_MINSIZE_SPLIT);      assert(IS_POWER_OF_2(size)); -    dk = PyMem_MALLOC(sizeof(PyDictKeysObject) + +    dk = PyObject_MALLOC(sizeof(PyDictKeysObject) +                        sizeof(PyDictKeyEntry) * (size-1));      if (dk == NULL) {          PyErr_NoMemory(); @@ -350,7 +350,7 @@ free_keys_object(PyDictKeysObject *keys)          Py_XDECREF(entries[i].me_key);          Py_XDECREF(entries[i].me_value);      } -    PyMem_FREE(keys); +    PyObject_FREE(keys);  }  #define new_values(size) PyMem_NEW(PyObject *, size) @@ -961,7 +961,7 @@ dictresize(PyDictObject *mp, Py_ssize_t minused)              }          }          assert(oldkeys->dk_refcnt == 1); -        DK_DEBUG_DECREF PyMem_FREE(oldkeys); +        DK_DEBUG_DECREF PyObject_FREE(oldkeys);      }      return 0;  } @@ -1160,39 +1160,42 @@ _PyDict_GetItemIdWithError(PyObject *dp, struct _Py_Identifier *key)      return PyDict_GetItemWithError(dp, kv);  } -/* Fast version of global value lookup. +/* Fast version of global value lookup (LOAD_GLOBAL).   * Lookup in globals, then builtins. + * + * Raise an exception and return NULL if an error occurred (ex: computing the + * key hash failed, key comparison failed, ...). Return NULL if the key doesn't + * exist. Return the value if the key exists.   */  PyObject *  _PyDict_LoadGlobal(PyDictObject *globals, PyDictObject *builtins, PyObject *key)  { -    PyObject *x; -    if (PyUnicode_CheckExact(key)) { -        PyObject **value_addr; -        Py_hash_t hash = ((PyASCIIObject *)key)->hash; -        if (hash != -1) { -            PyDictKeyEntry *e; -            e = globals->ma_keys->dk_lookup(globals, key, hash, &value_addr); -            if (e == NULL) { -                return NULL; -            } -            x = *value_addr; -            if (x != NULL) -                return x; -            e = builtins->ma_keys->dk_lookup(builtins, key, hash, &value_addr); -            if (e == NULL) { -                return NULL; -            } -            x = *value_addr; -            return x; -        } +    Py_hash_t hash; +    PyDictKeyEntry *entry; +    PyObject **value_addr; +    PyObject *value; + +    if (!PyUnicode_CheckExact(key) || +        (hash = ((PyASCIIObject *) key)->hash) == -1) +    { +        hash = PyObject_Hash(key); +        if (hash == -1) +            return NULL;      } -    x = PyDict_GetItemWithError((PyObject *)globals, key); -    if (x != NULL) -        return x; -    if (PyErr_Occurred()) + +    /* namespace 1: globals */ +    entry = globals->ma_keys->dk_lookup(globals, key, hash, &value_addr); +    if (entry == NULL)          return NULL; -    return PyDict_GetItemWithError((PyObject *)builtins, key); +    value = *value_addr; +    if (value != NULL) +        return value; + +    /* namespace 2: builtins */ +    entry = builtins->ma_keys->dk_lookup(builtins, key, hash, &value_addr); +    if (entry == NULL) +        return NULL; +    return *value_addr;  }  /* CAUTION: PyDict_SetItem() must guarantee that it won't resize the @@ -1917,7 +1920,7 @@ dict_fromkeys_impl(PyTypeObject *type, PyObject *iterable, PyObject *value)  }  static int -dict_update_common(PyObject *self, PyObject *args, PyObject *kwds, char *methname) +dict_update_common(PyObject *self, PyObject *args, PyObject *kwds, const char *methname)  {      PyObject *arg = NULL;      int result = 0; | 
