]> granicus.if.org Git - python/commitdiff
bpo-33817: Fix _PyBytes_Resize() for empty bytes object. (GH-11516)
authorSerhiy Storchaka <storchaka@gmail.com>
Sat, 12 Jan 2019 07:22:29 +0000 (09:22 +0200)
committerGitHub <noreply@github.com>
Sat, 12 Jan 2019 07:22:29 +0000 (09:22 +0200)
Add also tests for PyUnicode_FromFormat() and PyBytes_FromFormat()
with empty result.

Lib/test/test_bytes.py
Lib/test/test_unicode.py
Misc/NEWS.d/next/C API/2019-01-11-11-16-16.bpo-33817.nJ4yIj.rst [new file with mode: 0644]
Objects/bytesobject.c

index cc433217ce16a1ad1edb929085bee0aae49894cd..f7454d9b36a86a7ab5cfa87035b84f6f96da115a 100644 (file)
@@ -1001,6 +1001,12 @@ class BytesTest(BaseBytesTest, unittest.TestCase):
         self.assertRaises(OverflowError,
                           PyBytes_FromFormat, b'%c', c_int(256))
 
+        # Issue #33817: empty strings
+        self.assertEqual(PyBytes_FromFormat(b''),
+                         b'')
+        self.assertEqual(PyBytes_FromFormat(b'%s', b''),
+                         b'')
+
     def test_bytes_blocking(self):
         class IterationBlocked(list):
             __bytes__ = None
index fb7bb2d523fe6eebc86ce10810373e8741d30ae4..c277e705b9f55e791a503d8022277f588c7537e3 100644 (file)
@@ -2680,6 +2680,12 @@ class CAPITest(unittest.TestCase):
         check_format('%.%s',
                      b'%.%s', b'abc')
 
+        # Issue #33817: empty strings
+        check_format('',
+                     b'')
+        check_format('',
+                     b'%s', b'')
+
     # Test PyUnicode_AsWideChar()
     @support.cpython_only
     def test_aswidechar(self):
diff --git a/Misc/NEWS.d/next/C API/2019-01-11-11-16-16.bpo-33817.nJ4yIj.rst b/Misc/NEWS.d/next/C API/2019-01-11-11-16-16.bpo-33817.nJ4yIj.rst
new file mode 100644 (file)
index 0000000..ca4ccb2
--- /dev/null
@@ -0,0 +1 @@
+Fixed :c:func:`_PyBytes_Resize` for empty bytes objects.
index adf0cff5f3b2730bf30deb8e912d5bb086fc5a97..40ef47144e52eb0914f005038332e0f1392e5c52 100644 (file)
@@ -2991,9 +2991,22 @@ _PyBytes_Resize(PyObject **pv, Py_ssize_t newsize)
         /* return early if newsize equals to v->ob_size */
         return 0;
     }
+    if (Py_SIZE(v) == 0) {
+        if (newsize == 0) {
+            return 0;
+        }
+        *pv = _PyBytes_FromSize(newsize, 0);
+        Py_DECREF(v);
+        return (*pv == NULL) ? -1 : 0;
+    }
     if (Py_REFCNT(v) != 1) {
         goto error;
     }
+    if (newsize == 0) {
+        *pv = _PyBytes_FromSize(0, 0);
+        Py_DECREF(v);
+        return (*pv == NULL) ? -1 : 0;
+    }
     /* XXX UNREF/NEWREF interface should be more symmetrical */
     _Py_DEC_REFTOTAL;
     _Py_ForgetReference(v);