pub struct PyIOError(/* private fields */);
Expand description
Represents Python’s IOError
exception.
§Example: Raising IOError from Rust
This exception can be sent to Python code by converting it into a
PyErr
, where Python code can then catch it.
use pyo3::prelude::*;
use pyo3::exceptions::PyIOError;
#[pyfunction]
fn always_throws() -> PyResult<()> {
let message = "I'm IOError, and I was raised from Rust.";
Err(PyIOError::new_err(message))
}
Python code:
from my_module import always_throws
try:
always_throws()
except IOError as e:
print(f"Caught an exception: {e}")
§Example: Catching IOError in Rust
use pyo3::prelude::*;
use pyo3::exceptions::PyIOError;
Python::with_gil(|py| {
let result: PyResult<()> = py.run_bound("raise IOError", None, None);
let error_type = match result {
Ok(_) => "Not an error",
Err(error) if error.is_instance_of::<PyIOError>(py) => "IOError",
Err(_) => "Some other error",
};
assert_eq!(error_type, "IOError");
});
Implementations§
Trait Implementations§
Source§impl AsPyPointer for PyIOError
impl AsPyPointer for PyIOError
Source§impl PyTypeInfo for PyIOError
impl PyTypeInfo for PyIOError
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
Source§fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
fn type_object_bound(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
impl DerefToPyAny for PyIOError
impl PyLayout<PyIOError> for PyBaseExceptionObject
impl PySizedLayout<PyIOError> for PyBaseExceptionObject
impl ToPyErr for PyIOError
Auto Trait Implementations§
impl !Freeze for PyIOError
impl !RefUnwindSafe for PyIOError
impl !Send for PyIOError
impl !Sync for PyIOError
impl Unpin for PyIOError
impl UnwindSafe for PyIOError
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more