mirror of
https://github.com/python/cpython.git
synced 2025-10-21 14:12:27 +00:00
Revert SF #1615701 (rev 53655): dict.update() does *not* call __getitem__() or
keys() if subclassed. This is to remain consistent with 2.5. See discussion here: http://mail.python.org/pipermail/python-dev/2007-April/072565.html
This commit is contained in:
parent
8d61db5a00
commit
e6e383f498
3 changed files with 13 additions and 9 deletions
|
@ -189,14 +189,6 @@ class DictTest(unittest.TestCase):
|
||||||
|
|
||||||
self.assertRaises(ValueError, {}.update, [(1, 2, 3)])
|
self.assertRaises(ValueError, {}.update, [(1, 2, 3)])
|
||||||
|
|
||||||
# SF #1615701: make d.update(m) honor __getitem__() and keys() in dict subclasses
|
|
||||||
class KeyUpperDict(dict):
|
|
||||||
def __getitem__(self, key):
|
|
||||||
return key.upper()
|
|
||||||
d.clear()
|
|
||||||
d.update(KeyUpperDict.fromkeys('abc'))
|
|
||||||
self.assertEqual(d, {'a':'A', 'b':'B', 'c':'C'})
|
|
||||||
|
|
||||||
def test_fromkeys(self):
|
def test_fromkeys(self):
|
||||||
self.assertEqual(dict.fromkeys('abc'), {'a':None, 'b':None, 'c':None})
|
self.assertEqual(dict.fromkeys('abc'), {'a':None, 'b':None, 'c':None})
|
||||||
d = {}
|
d = {}
|
||||||
|
|
12
Misc/NEWS
12
Misc/NEWS
|
@ -4,6 +4,18 @@ Python News
|
||||||
|
|
||||||
(editors: check NEWS.help for information about editing NEWS using ReST.)
|
(editors: check NEWS.help for information about editing NEWS using ReST.)
|
||||||
|
|
||||||
|
What's New in Python 2.5.1?
|
||||||
|
=============================
|
||||||
|
|
||||||
|
*Release date: XX-APR-2007*
|
||||||
|
|
||||||
|
Core and builtins
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
- Revert SF #1615701: dict.update() does *not* call __getitem__() or keys()
|
||||||
|
if subclassed. This is to remain consistent with 2.5.
|
||||||
|
|
||||||
|
|
||||||
What's New in Python 2.5.1c1?
|
What's New in Python 2.5.1c1?
|
||||||
=============================
|
=============================
|
||||||
|
|
||||||
|
|
|
@ -1352,7 +1352,7 @@ PyDict_Merge(PyObject *a, PyObject *b, int override)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
mp = (dictobject*)a;
|
mp = (dictobject*)a;
|
||||||
if (PyDict_CheckExact(b)) {
|
if (PyDict_Check(b)) {
|
||||||
other = (dictobject*)b;
|
other = (dictobject*)b;
|
||||||
if (other == mp || other->ma_used == 0)
|
if (other == mp || other->ma_used == 0)
|
||||||
/* a.update(a) or a.update({}); nothing to do */
|
/* a.update(a) or a.update({}); nothing to do */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue