Commit 83e7a2b7 authored by Éric Araujo's avatar Éric Araujo

Merge from 3.2

parents c28af1f0 bd626d4e
...@@ -365,11 +365,12 @@ set_add_entry(register PySetObject *so, setentry *entry) ...@@ -365,11 +365,12 @@ set_add_entry(register PySetObject *so, setentry *entry)
{ {
register Py_ssize_t n_used; register Py_ssize_t n_used;
PyObject *key = entry->key; PyObject *key = entry->key;
Py_hash_t hash = entry->hash;
assert(so->fill <= so->mask); /* at least one empty slot */ assert(so->fill <= so->mask); /* at least one empty slot */
n_used = so->used; n_used = so->used;
Py_INCREF(key); Py_INCREF(key);
if (set_insert_key(so, key, entry->hash) == -1) { if (set_insert_key(so, key, hash) == -1) {
Py_DECREF(key); Py_DECREF(key);
return -1; return -1;
} }
...@@ -639,6 +640,7 @@ set_merge(PySetObject *so, PyObject *otherset) ...@@ -639,6 +640,7 @@ set_merge(PySetObject *so, PyObject *otherset)
{ {
PySetObject *other; PySetObject *other;
PyObject *key; PyObject *key;
Py_hash_t hash;
register Py_ssize_t i; register Py_ssize_t i;
register setentry *entry; register setentry *entry;
...@@ -660,10 +662,11 @@ set_merge(PySetObject *so, PyObject *otherset) ...@@ -660,10 +662,11 @@ set_merge(PySetObject *so, PyObject *otherset)
for (i = 0; i <= other->mask; i++) { for (i = 0; i <= other->mask; i++) {
entry = &other->table[i]; entry = &other->table[i];
key = entry->key; key = entry->key;
hash = entry->hash;
if (key != NULL && if (key != NULL &&
key != dummy) { key != dummy) {
Py_INCREF(key); Py_INCREF(key);
if (set_insert_key(so, key, entry->hash) == -1) { if (set_insert_key(so, key, hash) == -1) {
Py_DECREF(key); Py_DECREF(key);
return -1; return -1;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment