mirror of
https://github.com/python/cpython.git
synced 2025-09-27 02:39:58 +00:00
Issue #1692335: Move initial args assignment to BaseException.__new__
to help pickling of naive subclasses.
This commit is contained in:
parent
e4c0799d9c
commit
5562d9dc5d
3 changed files with 28 additions and 2 deletions
|
@ -10,6 +10,15 @@ import errno
|
||||||
from test.support import (TESTFN, unlink, run_unittest, captured_output,
|
from test.support import (TESTFN, unlink, run_unittest, captured_output,
|
||||||
gc_collect, cpython_only, no_tracing)
|
gc_collect, cpython_only, no_tracing)
|
||||||
|
|
||||||
|
class NaiveException(Exception):
|
||||||
|
def __init__(self, x):
|
||||||
|
self.x = x
|
||||||
|
|
||||||
|
class SlottedNaiveException(Exception):
|
||||||
|
__slots__ = ('x',)
|
||||||
|
def __init__(self, x):
|
||||||
|
self.x = x
|
||||||
|
|
||||||
# XXX This is not really enough, each *operation* should be tested!
|
# XXX This is not really enough, each *operation* should be tested!
|
||||||
|
|
||||||
class ExceptionTests(unittest.TestCase):
|
class ExceptionTests(unittest.TestCase):
|
||||||
|
@ -296,6 +305,10 @@ class ExceptionTests(unittest.TestCase):
|
||||||
{'args' : ('\u3042', 0, 1, 'ouch'),
|
{'args' : ('\u3042', 0, 1, 'ouch'),
|
||||||
'object' : '\u3042', 'reason' : 'ouch',
|
'object' : '\u3042', 'reason' : 'ouch',
|
||||||
'start' : 0, 'end' : 1}),
|
'start' : 0, 'end' : 1}),
|
||||||
|
(NaiveException, ('foo',),
|
||||||
|
{'args': ('foo',), 'x': 'foo'}),
|
||||||
|
(SlottedNaiveException, ('foo',),
|
||||||
|
{'args': ('foo',), 'x': 'foo'}),
|
||||||
]
|
]
|
||||||
try:
|
try:
|
||||||
# More tests are in test_WindowsError
|
# More tests are in test_WindowsError
|
||||||
|
@ -316,6 +329,7 @@ class ExceptionTests(unittest.TestCase):
|
||||||
raise
|
raise
|
||||||
else:
|
else:
|
||||||
# Verify module name
|
# Verify module name
|
||||||
|
if not type(e).__name__.endswith('NaiveException'):
|
||||||
self.assertEqual(type(e).__module__, 'builtins')
|
self.assertEqual(type(e).__module__, 'builtins')
|
||||||
# Verify no ref leaks in Exc_str()
|
# Verify no ref leaks in Exc_str()
|
||||||
s = str(e)
|
s = str(e)
|
||||||
|
|
|
@ -10,6 +10,9 @@ What's New in Python 3.3.0 Beta 2?
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #1692335: Move initial args assignment to
|
||||||
|
BaseException.__new__ to help pickling of naive subclasses.
|
||||||
|
|
||||||
- Issue #12834: Fix PyBuffer_ToContiguous() for non-contiguous arrays.
|
- Issue #12834: Fix PyBuffer_ToContiguous() for non-contiguous arrays.
|
||||||
|
|
||||||
- Issue #15456: Fix code __sizeof__ after #12399 change.
|
- Issue #15456: Fix code __sizeof__ after #12399 change.
|
||||||
|
|
|
@ -44,6 +44,12 @@ BaseException_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||||
self->traceback = self->cause = self->context = NULL;
|
self->traceback = self->cause = self->context = NULL;
|
||||||
self->suppress_context = 0;
|
self->suppress_context = 0;
|
||||||
|
|
||||||
|
if (args) {
|
||||||
|
self->args = args;
|
||||||
|
Py_INCREF(args);
|
||||||
|
return (PyObject *)self;
|
||||||
|
}
|
||||||
|
|
||||||
self->args = PyTuple_New(0);
|
self->args = PyTuple_New(0);
|
||||||
if (!self->args) {
|
if (!self->args) {
|
||||||
Py_DECREF(self);
|
Py_DECREF(self);
|
||||||
|
@ -56,12 +62,15 @@ BaseException_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
||||||
static int
|
static int
|
||||||
BaseException_init(PyBaseExceptionObject *self, PyObject *args, PyObject *kwds)
|
BaseException_init(PyBaseExceptionObject *self, PyObject *args, PyObject *kwds)
|
||||||
{
|
{
|
||||||
|
PyObject *tmp;
|
||||||
|
|
||||||
if (!_PyArg_NoKeywords(Py_TYPE(self)->tp_name, kwds))
|
if (!_PyArg_NoKeywords(Py_TYPE(self)->tp_name, kwds))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
Py_XDECREF(self->args);
|
tmp = self->args;
|
||||||
self->args = args;
|
self->args = args;
|
||||||
Py_INCREF(self->args);
|
Py_INCREF(self->args);
|
||||||
|
Py_XDECREF(tmp);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue