Struct PyFileExistsError
pub struct PyFileExistsError(/* private fields */);Available on crate feature
tls only.Expand description
Represents Python’s FileExistsError exception.
§Example: Raising FileExistsError 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::PyFileExistsError;
#[pyfunction]
fn always_throws() -> PyResult<()> {
let message = "I'm FileExistsError, and I was raised from Rust.";
Err(PyFileExistsError::new_err(message))
}Python code:
from my_module import always_throws
try:
always_throws()
except FileExistsError as e:
print(f"Caught an exception: {e}")§Example: Catching FileExistsError in Rust
use pyo3::prelude::*;
use pyo3::exceptions::PyFileExistsError;
use pyo3::ffi::c_str;
Python::attach(|py| {
let result: PyResult<()> = py.run(c_str!("raise FileExistsError"), None, None);
let error_type = match result {
Ok(_) => "Not an error",
Err(error) if error.is_instance_of::<PyFileExistsError>(py) => "FileExistsError",
Err(_) => "Some other error",
};
assert_eq!(error_type, "FileExistsError");
});Implementations§
§impl PyFileExistsError
impl PyFileExistsError
Trait Implementations§
§impl PyTypeInfo for PyFileExistsError
impl PyTypeInfo for PyFileExistsError
§const NAME: &'static str = "PyFileExistsError"
const NAME: &'static str = "PyFileExistsError"
👎Deprecated since 0.28.0:
prefer using ::type_object(py).name() to get the correct runtime value
Class name.
§const MODULE: Option<&'static str>
const MODULE: Option<&'static str>
👎Deprecated since 0.28.0:
prefer using ::type_object(py).module() to get the correct runtime value
Module name, if any.
§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type.impl DerefToPyAny for PyFileExistsError
impl PyLayout<PyFileExistsError> for PyBaseExceptionObject
impl PySizedLayout<PyFileExistsError> for PyBaseExceptionObject
impl ToPyErr for PyFileExistsError
Auto Trait Implementations§
impl !Freeze for PyFileExistsError
impl !RefUnwindSafe for PyFileExistsError
impl !Send for PyFileExistsError
impl !Sync for PyFileExistsError
impl Unpin for PyFileExistsError
impl UnsafeUnpin for PyFileExistsError
impl UnwindSafe for PyFileExistsError
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
👎Deprecated since 0.27.0:
Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Name of self. This is used in error messages, for example.