bpo-37219: Remove erroneous optimization for differencing an empty set (GH-13965)
authorRaymond Hettinger <rhettinger@users.noreply.github.com>
Tue, 11 Jun 2019 08:15:24 +0000 (01:15 -0700)
committerGitHub <noreply@github.com>
Tue, 11 Jun 2019 08:15:24 +0000 (01:15 -0700)
Lib/test/test_set.py
Misc/NEWS.d/next/Core and Builtins/2019-06-10-23-18-31.bpo-37219.jPSufq.rst [new file with mode: 0644]
Objects/setobject.c

index bb1081f034fe8043079d7cf924a2d8cae4e38bd8..e4766ab190be011f821faa73558abe1067d8948d 100644 (file)
@@ -895,6 +895,12 @@ class TestBasicOps:
             self.assertEqual(self.set, copy,
                              "%s != %s" % (self.set, copy))
 
+    def test_issue_37219(self):
+        with self.assertRaises(TypeError):
+            set().difference(123)
+        with self.assertRaises(TypeError):
+            set().difference_update(123)
+
 #------------------------------------------------------------------------------
 
 class TestBasicOpsEmpty(TestBasicOps, unittest.TestCase):
diff --git a/Misc/NEWS.d/next/Core and Builtins/2019-06-10-23-18-31.bpo-37219.jPSufq.rst b/Misc/NEWS.d/next/Core and Builtins/2019-06-10-23-18-31.bpo-37219.jPSufq.rst
new file mode 100644 (file)
index 0000000..ef8f52d
--- /dev/null
@@ -0,0 +1 @@
+Remove errorneous optimization for empty set differences.
index bd031600c1be66c71d6fb04fa9483dcfef74b877..8cd95ba890dd5f0a40ef6936bcd8fba12c80b15d 100644 (file)
@@ -1456,10 +1456,6 @@ PyDoc_STRVAR(isdisjoint_doc,
 static int
 set_difference_update_internal(PySetObject *so, PyObject *other)
 {
-    if (PySet_GET_SIZE(so) == 0) {
-        return 0;
-    }
-
     if ((PyObject *)so == other)
         return set_clear_internal(so);
 
@@ -1534,10 +1530,6 @@ set_difference(PySetObject *so, PyObject *other)
     Py_ssize_t pos = 0, other_size;
     int rv;
 
-    if (PySet_GET_SIZE(so) == 0) {
-        return set_copy(so, NULL);
-    }
-
     if (PyAnySet_Check(other)) {
         other_size = PySet_GET_SIZE(other);
     }