]> granicus.if.org Git - python/commitdiff
Merged revisions 84301 via svnmerge from
authorDaniel Stutzbach <daniel@stutzbachenterprises.com>
Tue, 24 Aug 2010 21:09:30 +0000 (21:09 +0000)
committerDaniel Stutzbach <daniel@stutzbachenterprises.com>
Tue, 24 Aug 2010 21:09:30 +0000 (21:09 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r84301 | daniel.stutzbach | 2010-08-24 15:49:57 -0500 (Tue, 24 Aug 2010) | 1 line

  Issue 8750: Fixed MutableSet's methods to correctly handle reflexive operations, namely x -= x and x ^= x
........

Lib/_abcoll.py
Lib/test/test_collections.py
Misc/NEWS

index e9234af3822acb0f332211ddee3cea297a9cfbb6..73e668c11c5f23ba075ef36e482fd4c437d71905 100644 (file)
@@ -305,18 +305,24 @@ class MutableSet(Set):
         return self
 
     def __ixor__(self, it):
-        if not isinstance(it, Set):
-            it = self._from_iterable(it)
-        for value in it:
-            if value in self:
-                self.discard(value)
-            else:
-                self.add(value)
+        if it is self:
+            self.clear()
+        else:
+            if not isinstance(it, Set):
+                it = self._from_iterable(it)
+            for value in it:
+                if value in self:
+                    self.discard(value)
+                else:
+                    self.add(value)
         return self
 
     def __isub__(self, it):
-        for value in it:
-            self.discard(value)
+        if it is self:
+            self.clear()
+        else:
+            for value in it:
+                self.discard(value)
         return self
 
 MutableSet.register(set)
index f10f956f9b91db3881e8aed0eb557af93dcd8d49..16c4552e1d3089421447401fa0f994db80b20c1b 100644 (file)
@@ -526,6 +526,21 @@ class TestCollectionABCs(ABCTestCase):
         s = MySet([5,43,2,1])
         self.assertEqual(s.pop(), 1)
 
+    def test_issue8750(self):
+        empty = WithSet()
+        full = WithSet(range(10))
+        s = WithSet(full)
+        s -= s
+        self.assertEqual(s, empty)
+        s = WithSet(full)
+        s ^= s
+        self.assertEqual(s, empty)
+        s = WithSet(full)
+        s &= s
+        self.assertEqual(s, full)
+        s |= s
+        self.assertEqual(s, full)
+
     def test_Mapping(self):
         for sample in [dict]:
             self.assertIsInstance(sample(), Mapping)
index 1e352bce9a6cfc2b608e3d998887f5967c362380..70ed097c66b1c355a446265e99e78922f7957d36 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -31,6 +31,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #8750: Fixed MutableSet's methods to correctly handle
+  reflexive operations, namely x -= x and x ^= x.
+
 - Issue #9129: smtpd.py is vulnerable to DoS attacks deriving from missing 
   error handling when accepting a new connection.