[Python-checkins] cpython (merge 3.5 -> default): Issue #27443: __length_hint__() of bytearray itearator no longer return

serhiy.storchaka python-checkins at python.org
Sun Jul 3 07:42:40 EDT 2016


https://hg.python.org/cpython/rev/03192909160d
changeset:   102249:03192909160d
parent:      102247:6c4c0a23fabb
parent:      102248:6b084bb6c38b
user:        Serhiy Storchaka <storchaka at gmail.com>
date:        Sun Jul 03 14:42:17 2016 +0300
summary:
  Issue #27443: __length_hint__() of bytearray itearator no longer return
negative integer for resized bytearray.

files:
  Lib/test/test_bytes.py    |  10 ++++++++++
  Misc/NEWS                 |   3 +++
  Objects/bytearrayobject.c |   6 +++++-
  3 files changed, 18 insertions(+), 1 deletions(-)


diff --git a/Lib/test/test_bytes.py b/Lib/test/test_bytes.py
--- a/Lib/test/test_bytes.py
+++ b/Lib/test/test_bytes.py
@@ -1328,6 +1328,16 @@
 
     test_exhausted_iterator = test.list_tests.CommonTest.test_exhausted_iterator
 
+    def test_iterator_length_hint(self):
+        # Issue 27443: __length_hint__ can return negative integer
+        ba = bytearray(b'ab')
+        it = iter(ba)
+        next(it)
+        ba.clear()
+        # Shouldn't raise an error
+        self.assertEqual(list(it), [])
+
+
 class AssortedBytesTest(unittest.TestCase):
     #
     # Test various combinations of bytes and bytearray
diff --git a/Misc/NEWS b/Misc/NEWS
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,9 @@
 Core and Builtins
 -----------------
 
+- Issue #27443: __length_hint__() of bytearray itearator no longer return
+  negative integer for resized bytearray.
+
 - Issue #27007: The fromhex() class methods of bytes and bytearray subclasses
   now return an instance of corresponding subclass.
 
diff --git a/Objects/bytearrayobject.c b/Objects/bytearrayobject.c
--- a/Objects/bytearrayobject.c
+++ b/Objects/bytearrayobject.c
@@ -2303,8 +2303,12 @@
 bytearrayiter_length_hint(bytesiterobject *it)
 {
     Py_ssize_t len = 0;
-    if (it->it_seq)
+    if (it->it_seq) {
         len = PyByteArray_GET_SIZE(it->it_seq) - it->it_index;
+        if (len < 0) {
+            len = 0;
+        }
+    }
     return PyLong_FromSsize_t(len);
 }
 

-- 
Repository URL: https://hg.python.org/cpython


More information about the Python-checkins mailing list