Merge #3141
3141: Add BaseExceptionGroup for Python >= 3.11 r=adamreichold a=adriangb Not sure if this is totally off base, but it looks like it may be this easy to add support for ExceptionGroup? Co-authored-by: Adrian Garcia Badaracco <1755071+adriangb@users.noreply.github.com>
This commit is contained in:
commit
8ab3f5fc47
1
newsfragments/3141.added.md
Normal file
1
newsfragments/3141.added.md
Normal file
|
@ -0,0 +1 @@
|
|||
Add FFI definition for `BaseExceptionGroup`, which was added in Python 3.11 by [PEP 0654](https://peps.python.org/pep-0654/).
|
|
@ -103,6 +103,8 @@ pub unsafe fn PyUnicodeDecodeError_Create(
|
|||
extern "C" {
|
||||
#[cfg_attr(PyPy, link_name = "PyPyExc_BaseException")]
|
||||
pub static mut PyExc_BaseException: *mut PyObject;
|
||||
#[cfg(Py_3_11)]
|
||||
pub static mut PyExc_BaseExceptionGroup: *mut PyObject;
|
||||
#[cfg_attr(PyPy, link_name = "PyPyExc_Exception")]
|
||||
pub static mut PyExc_Exception: *mut PyObject;
|
||||
#[cfg_attr(PyPy, link_name = "PyPyExc_StopAsyncIteration")]
|
||||
|
|
|
@ -493,7 +493,7 @@ impl_native_exception!(
|
|||
PyExc_UnicodeError,
|
||||
native_doc!("UnicodeError")
|
||||
);
|
||||
// these three errors need arguments, so they're too annoying to write tests for using macros...
|
||||
// these four errors need arguments, so they're too annoying to write tests for using macros...
|
||||
impl_native_exception!(
|
||||
PyUnicodeDecodeError,
|
||||
PyExc_UnicodeDecodeError,
|
||||
|
@ -509,6 +509,12 @@ impl_native_exception!(
|
|||
PyExc_UnicodeTranslateError,
|
||||
native_doc!("UnicodeTranslateError", "")
|
||||
);
|
||||
#[cfg(Py_3_11)]
|
||||
impl_native_exception!(
|
||||
PyBaseExceptionGroup,
|
||||
PyExc_BaseExceptionGroup,
|
||||
native_doc!("BaseExceptionGroup", "")
|
||||
);
|
||||
impl_native_exception!(PyValueError, PyExc_ValueError, native_doc!("ValueError"));
|
||||
impl_native_exception!(
|
||||
PyZeroDivisionError,
|
||||
|
@ -1028,7 +1034,10 @@ mod tests {
|
|||
);
|
||||
});
|
||||
}
|
||||
|
||||
#[cfg(Py_3_11)]
|
||||
test_exception!(PyBaseExceptionGroup, |_| {
|
||||
PyBaseExceptionGroup::new_err(("msg", vec![PyValueError::new_err("err")]))
|
||||
});
|
||||
test_exception!(PyBaseException);
|
||||
test_exception!(PyException);
|
||||
test_exception!(PyStopAsyncIteration);
|
||||
|
|
Loading…
Reference in a new issue