[Python-checkins] cpython: Issue #26766: Fix _PyBytesWriter_Finish()

victor.stinner python-checkins at python.org
Fri Apr 15 11:52:46 EDT 2016


https://hg.python.org/cpython/rev/1eb586d5b321
changeset:   100985:1eb586d5b321
user:        Victor Stinner <victor.stinner at gmail.com>
date:        Fri Apr 15 17:52:27 2016 +0200
summary:
  Issue #26766: Fix _PyBytesWriter_Finish()

Return a bytearray object when bytearray is requested and when the small buffer
is used.

Fix also test_bytes: bytearray%args must return a bytearray type.

files:
  Lib/test/test_bytes.py |  4 ++--
  Objects/bytesobject.c  |  7 ++++++-
  2 files changed, 8 insertions(+), 3 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
@@ -492,7 +492,7 @@
         b = self.type2test(b'%s / 100 = %d%%')
         a = b % (b'seventy-nine', 79)
         self.assertEqual(a, b'seventy-nine / 100 = 79%')
-        self.assertIs(type(a), bytes)
+        self.assertIs(type(a), self.type2test)
 
     def test_imod(self):
         b = self.type2test(b'hello, %b!')
@@ -504,7 +504,7 @@
         b = self.type2test(b'%s / 100 = %d%%')
         b %= (b'seventy-nine', 79)
         self.assertEqual(b, b'seventy-nine / 100 = 79%')
-        self.assertIs(type(b), bytes)
+        self.assertIs(type(b), self.type2test)
 
     def test_rmod(self):
         with self.assertRaises(TypeError):
diff --git a/Objects/bytesobject.c b/Objects/bytesobject.c
--- a/Objects/bytesobject.c
+++ b/Objects/bytesobject.c
@@ -4150,7 +4150,12 @@
         result = PyBytes_FromStringAndSize(NULL, 0);
     }
     else if (writer->use_small_buffer) {
-        result = PyBytes_FromStringAndSize(writer->small_buffer, size);
+        if (writer->use_bytearray) {
+            result = PyByteArray_FromStringAndSize(writer->small_buffer, size);
+        }
+        else {
+            result = PyBytes_FromStringAndSize(writer->small_buffer, size);
+        }
     }
     else {
         result = writer->buffer;

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


More information about the Python-checkins mailing list