Commit 262b6793 authored by Raymond Hettinger's avatar Raymond Hettinger

Issue #26020: Fix evaluation order for set literals

parent 5dc504c3
...@@ -388,6 +388,21 @@ class TestSet(TestJointOps, unittest.TestCase): ...@@ -388,6 +388,21 @@ class TestSet(TestJointOps, unittest.TestCase):
t = {1,2,3} t = {1,2,3}
self.assertEqual(s, t) self.assertEqual(s, t)
def test_set_literal_insertion_order(self):
# SF Issue #26020 -- Expect left to right insertion
s = {1, 1.0, True}
self.assertEqual(len(s), 1)
stored_value = s.pop()
self.assertEqual(type(stored_value), int)
def test_set_literal_evaluation_order(self):
# Expect left to right expression evaluation
events = []
def record(obj):
events.append(obj)
s = {record(1), record(2), record(3)}
self.assertEqual(events, [1, 2, 3])
def test_hash(self): def test_hash(self):
self.assertRaises(TypeError, hash, self.s) self.assertRaises(TypeError, hash, self.s)
......
...@@ -20,6 +20,8 @@ Core and Builtins ...@@ -20,6 +20,8 @@ Core and Builtins
after use of 'def' in _PyState_AddModule(). after use of 'def' in _PyState_AddModule().
Initial patch by Christian Heimes. Initial patch by Christian Heimes.
- Issue #26020: set literal evaluation order did not match documented behaviour.
- Issue #27782: Multi-phase extension module import now correctly allows the - Issue #27782: Multi-phase extension module import now correctly allows the
``m_methods`` field to be used to add module level functions to instances ``m_methods`` field to be used to add module level functions to instances
of non-module types returned from ``Py_create_mod``. Patch by Xiang Zhang. of non-module types returned from ``Py_create_mod``. Patch by Xiang Zhang.
......
...@@ -2580,14 +2580,16 @@ PyEval_EvalFrameEx(PyFrameObject *f, int throwflag) ...@@ -2580,14 +2580,16 @@ PyEval_EvalFrameEx(PyFrameObject *f, int throwflag)
TARGET(BUILD_SET) { TARGET(BUILD_SET) {
PyObject *set = PySet_New(NULL); PyObject *set = PySet_New(NULL);
int err = 0; int err = 0;
int i;
if (set == NULL) if (set == NULL)
goto error; goto error;
while (--oparg >= 0) { for (i = oparg; i > 0; i--) {
PyObject *item = POP(); PyObject *item = PEEK(i);
if (err == 0) if (err == 0)
err = PySet_Add(set, item); err = PySet_Add(set, item);
Py_DECREF(item); Py_DECREF(item);
} }
STACKADJ(-oparg);
if (err != 0) { if (err != 0) {
Py_DECREF(set); Py_DECREF(set);
goto error; goto error;
......
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