Commit 45e0add3 authored by Raymond Hettinger's avatar Raymond Hettinger

Bug #1648179: set.update() not recognizing __iter__ overrides in dict subclasses.

parent 610a8f36
...@@ -16,6 +16,9 @@ Core and builtins ...@@ -16,6 +16,9 @@ Core and builtins
a weakref on itself during a __del__ call for new-style classes (classic a weakref on itself during a __del__ call for new-style classes (classic
classes still have the bug). classes still have the bug).
- Bug #1648179: set.update() did not recognize an overridden __iter__
method in subclasses of dict.
- Bug #1579370: Make PyTraceBack_Here use the current thread, not the - Bug #1579370: Make PyTraceBack_Here use the current thread, not the
frame's thread state. frame's thread state.
......
...@@ -915,7 +915,7 @@ set_update_internal(PySetObject *so, PyObject *other) ...@@ -915,7 +915,7 @@ set_update_internal(PySetObject *so, PyObject *other)
if (PyAnySet_Check(other)) if (PyAnySet_Check(other))
return set_merge(so, other); return set_merge(so, other);
if (PyDict_Check(other)) { if (PyDict_CheckExact(other)) {
PyObject *value; PyObject *value;
Py_ssize_t pos = 0; Py_ssize_t pos = 0;
while (PyDict_Next(other, &pos, &key, &value)) { while (PyDict_Next(other, &pos, &key, &value)) {
...@@ -1363,7 +1363,7 @@ set_difference(PySetObject *so, PyObject *other) ...@@ -1363,7 +1363,7 @@ set_difference(PySetObject *so, PyObject *other)
setentry *entry; setentry *entry;
Py_ssize_t pos = 0; Py_ssize_t pos = 0;
if (!PyAnySet_Check(other) && !PyDict_Check(other)) { if (!PyAnySet_Check(other) && !PyDict_CheckExact(other)) {
result = set_copy(so); result = set_copy(so);
if (result == NULL) if (result == NULL)
return NULL; return NULL;
...@@ -1377,7 +1377,7 @@ set_difference(PySetObject *so, PyObject *other) ...@@ -1377,7 +1377,7 @@ set_difference(PySetObject *so, PyObject *other)
if (result == NULL) if (result == NULL)
return NULL; return NULL;
if (PyDict_Check(other)) { if (PyDict_CheckExact(other)) {
while (set_next(so, &pos, &entry)) { while (set_next(so, &pos, &entry)) {
setentry entrycopy; setentry entrycopy;
entrycopy.hash = entry->hash; entrycopy.hash = entry->hash;
...@@ -1450,7 +1450,7 @@ set_symmetric_difference_update(PySetObject *so, PyObject *other) ...@@ -1450,7 +1450,7 @@ set_symmetric_difference_update(PySetObject *so, PyObject *other)
if ((PyObject *)so == other) if ((PyObject *)so == other)
return set_clear(so); return set_clear(so);
if (PyDict_Check(other)) { if (PyDict_CheckExact(other)) {
PyObject *value; PyObject *value;
int rv; int rv;
while (PyDict_Next(other, &pos, &key, &value)) { while (PyDict_Next(other, &pos, &key, &value)) {
......
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