]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.14] gh-140939: Fix memory leak in `_PyBytes_FormatEx` error path (GH-140957) ...
authorStan Ulbrych <89152624+StanFromIreland@users.noreply.github.com>
Thu, 6 Nov 2025 16:20:03 +0000 (16:20 +0000)
committerGitHub <noreply@github.com>
Thu, 6 Nov 2025 16:20:03 +0000 (16:20 +0000)
(cherry picked from commit d6c89a2df2c8b7603125883494e9058a88348f66)

Lib/test/test_bytes.py
Misc/NEWS.d/next/Core_and_Builtins/2025-11-03-17-21-38.gh-issue-140939.FVboAw.rst [new file with mode: 0644]
Objects/bytesobject.c

index 5e57b6d0eee5ba743512c8ea5fc4be2962064cd4..08119f5f7697112c804b8a19b2a442d1f1d67771 100644 (file)
@@ -802,6 +802,13 @@ class BaseBytesTest:
             with self.assertRaisesRegex(TypeError, msg):
                 operator.mod(format_bytes, value)
 
+    def test_memory_leak_gh_140939(self):
+        # gh-140939: MemoryError is raised without leaking
+        _testcapi = import_helper.import_module('_testcapi')
+        with self.assertRaises(MemoryError):
+            b = self.type2test(b'%*b')
+            b % (_testcapi.PY_SSIZE_T_MAX, b'abc')
+
     def test_imod(self):
         b = self.type2test(b'hello, %b!')
         orig = b
diff --git a/Misc/NEWS.d/next/Core_and_Builtins/2025-11-03-17-21-38.gh-issue-140939.FVboAw.rst b/Misc/NEWS.d/next/Core_and_Builtins/2025-11-03-17-21-38.gh-issue-140939.FVboAw.rst
new file mode 100644 (file)
index 0000000..a292176
--- /dev/null
@@ -0,0 +1,2 @@
+Fix memory leak when :class:`bytearray` or :class:`bytes` is formated with the
+``%*b`` format with a large width that results in a :exc:`MemoryError`.
index 5dd1a1f09c82f1c5e14d165f6784a988b6756621..eb13f16f67295c60febba6c8e0929fb28ba4fd9c 100644 (file)
@@ -975,8 +975,10 @@ _PyBytes_FormatEx(const char *format, Py_ssize_t format_len,
             /* 2: size preallocated for %s */
             if (alloc > 2) {
                 res = _PyBytesWriter_Prepare(&writer, res, alloc - 2);
-                if (res == NULL)
+                if (res == NULL) {
+                    Py_XDECREF(temp);
                     goto error;
+                }
             }
 #ifndef NDEBUG
             char *before = res;