]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Issue #26766: Fix _PyBytesWriter_Finish()
authorVictor Stinner <victor.stinner@gmail.com>
Fri, 15 Apr 2016 15:52:27 +0000 (17:52 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Fri, 15 Apr 2016 15:52:27 +0000 (17:52 +0200)
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.

Lib/test/test_bytes.py
Objects/bytesobject.c

index 966e287afee43ca45ef4fdbd8c58e93439301539..a10ad5e8932e40001838ba91df97f75ea0650cd4 100644 (file)
@@ -492,7 +492,7 @@ class BaseBytesTest:
         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 @@ class BaseBytesTest:
         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):
index ec03233ba384a391e670f35b08a7372148669c43..701ae9df8a808513e910d1a6fb59df7d15f6c918 100644 (file)
@@ -4150,7 +4150,12 @@ _PyBytesWriter_Finish(_PyBytesWriter *writer, void *str)
         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;