mirror of
https://github.com/python/cpython.git
synced 2024-11-23 18:04:37 +08:00
bpo-46857: Fix refleak in OSError INIT_ALIAS() (GH-31594)
_Py_GetRefTotal() no longer decrements _PySet_Dummy refcount.
This commit is contained in:
parent
e182c660b6
commit
ad56919c5e
@ -1657,15 +1657,11 @@ class MiscTests(EmbeddingTestsMixin, unittest.TestCase):
|
||||
self.fail(f"unexpected output: {out!a}")
|
||||
refs = int(match.group(1))
|
||||
blocks = int(match.group(2))
|
||||
self.assertEqual(refs, 0, out)
|
||||
if not MS_WINDOWS:
|
||||
# bpo-46417: Tolerate negative reference count which can occur because
|
||||
# of bugs in C extensions. It is only wrong if it's greater than 0.
|
||||
self.assertLessEqual(refs, 0, out)
|
||||
self.assertEqual(blocks, 0, out)
|
||||
else:
|
||||
# bpo-46857: on Windows, Python still leaks 1 reference and 1
|
||||
# memory block at exit.
|
||||
self.assertLessEqual(refs, 1, out)
|
||||
# bpo-46857: on Windows, Python still leaks 1 memory block at exit
|
||||
self.assertIn(blocks, (0, 1), out)
|
||||
|
||||
|
||||
|
@ -15,10 +15,10 @@
|
||||
|
||||
|
||||
/* Compatibility aliases */
|
||||
PyObject *PyExc_EnvironmentError = NULL;
|
||||
PyObject *PyExc_IOError = NULL;
|
||||
PyObject *PyExc_EnvironmentError = NULL; // borrowed ref
|
||||
PyObject *PyExc_IOError = NULL; // borrowed ref
|
||||
#ifdef MS_WINDOWS
|
||||
PyObject *PyExc_WindowsError = NULL;
|
||||
PyObject *PyExc_WindowsError = NULL; // borrowed ref
|
||||
#endif
|
||||
|
||||
|
||||
@ -3647,10 +3647,8 @@ _PyBuiltins_AddExceptions(PyObject *bltinmod)
|
||||
|
||||
#define INIT_ALIAS(NAME, TYPE) \
|
||||
do { \
|
||||
Py_INCREF(PyExc_ ## TYPE); \
|
||||
Py_XDECREF(PyExc_ ## NAME); \
|
||||
PyExc_ ## NAME = PyExc_ ## TYPE; \
|
||||
if (PyDict_SetItemString(mod_dict, # NAME, PyExc_ ## NAME)) { \
|
||||
if (PyDict_SetItemString(mod_dict, # NAME, PyExc_ ## TYPE)) { \
|
||||
return -1; \
|
||||
} \
|
||||
} while (0)
|
||||
|
@ -61,12 +61,7 @@ Py_ssize_t _Py_RefTotal;
|
||||
Py_ssize_t
|
||||
_Py_GetRefTotal(void)
|
||||
{
|
||||
PyObject *o;
|
||||
Py_ssize_t total = _Py_RefTotal;
|
||||
o = _PySet_Dummy;
|
||||
if (o != NULL)
|
||||
total -= Py_REFCNT(o);
|
||||
return total;
|
||||
return _Py_RefTotal;
|
||||
}
|
||||
|
||||
void
|
||||
|
Loading…
Reference in New Issue
Block a user