#[repr(C)]
pub struct RIoError { /* private fields */ }
Expand description

Ffi safe equivalent to std::io::Error.

Example

Defining an extern function to write a slice into a writer twice.

use abi_stable::{
    erased_types::interfaces::IoWriteInterface,
    rtry, sabi_extern_fn,
    std_types::{RIoError, ROk, RResult},
    traits::IntoReprC,
    DynTrait, RMut,
};

use std::io::Write;

#[sabi_extern_fn]
pub fn write_slice_twice(
    mut write: DynTrait<RMut<'_, ()>, IoWriteInterface>,
    slice: &[u8],
) -> RResult<(), RIoError> {
    rtry!(write.write_all(slice).into_c());
    rtry!(write.write_all(slice).into_c());
    ROk(())
}

Implementations§

source§

impl RIoError

source

pub fn new<E>(kind: ErrorKind, error: E) -> Self
where E: ErrorTrait + Send + Sync + 'static,

Constructs an RIoError from an error and a std::io::ErrorKind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

let err = RIoError::new(ErrorKind::Other, "".parse::<u64>().unwrap_err());
source

pub fn new_<E>(kind: ErrorKind, error: E) -> Self
where E: Into<Box<dyn ErrorTrait + Send + Sync + 'static>>,

Constructs an RIoError from a type convertible into a Box<dyn std::error::Error + Send + Sync + 'static>, and a std::io::ErrorKind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

let str_err = "Timeout receiving the response from server.";

let err = RIoError::new_(ErrorKind::TimedOut, str_err);
source

pub fn from_kind(kind: ErrorKind) -> Self

Constructs an RIoError from a std::io::ErrorKind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

let err = RIoError::from_kind(ErrorKind::AlreadyExists);
source

pub fn with_box( kind: ErrorKind, error: Box<dyn ErrorTrait + Send + Sync + 'static> ) -> Self

Constructs an RIoError from a Box<dyn std::error::Error + Send + Sync + 'static> and a std::io::ErrorKind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

let str_err = "Could not create file \"memes.txt\" because it already exists.";

let err = RIoError::with_box(ErrorKind::AlreadyExists, str_err.into());
source

pub fn with_rboxerror(kind: ErrorKind, error: RBoxError) -> Self

Constructs an RIoError from an RBoxError and a std::io::ErrorKind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

type DynErr = Box<dyn std::error::Error + Send + Sync>;

let str_err: DynErr = "IP address `256.256.256.256` is already in use.".into();

let err = RIoError::with_rboxerror(ErrorKind::AddrInUse, str_err.into());
source

pub fn kind(&self) -> RIoErrorKind

Retrieves the kind of io error.

Example
use abi_stable::std_types::{RIoError, RIoErrorKind};
use std::io::ErrorKind;

let err = RIoError::from_kind(ErrorKind::AlreadyExists);

assert_eq!(err.kind(), RIoErrorKind::AlreadyExists);
source

pub fn get_ref(&self) -> Option<&RBoxError>

Gets the internal error, returning None if this was constructed with RIoError::from_kind.

Example
use abi_stable::std_types::{RBoxError, RIoError, RIoErrorKind};
use std::io::ErrorKind;

{
    let err = RIoError::from_kind(ErrorKind::AlreadyExists);
    assert_eq!(err.get_ref().map(|_| ()), None);
}
{
    let msg = "Cannot access directory at \"/home/Steve/memes/\".";
    let err = RIoError::new_(ErrorKind::PermissionDenied, msg);

    assert!(err.get_ref().is_some());
}
source

pub fn get_mut(&mut self) -> Option<&mut RBoxError>

Gets the internal error, returning None if this was constructed with RIoError::from_kind.

Example
use abi_stable::std_types::{RBoxError, RIoError, RIoErrorKind};
use std::io::ErrorKind;

{
    let mut err = RIoError::from_kind(ErrorKind::AlreadyExists);
    assert_eq!(err.get_mut().map(|_| ()), None);
}
{
    let mut msg = "Cannot access directory at \"/home/Patrick/373.15K takes/\".";
    let mut err = RIoError::new_(ErrorKind::PermissionDenied, msg);
    assert!(err.get_mut().is_some());
}
source

pub fn into_inner(self) -> Option<RBoxError>

Converts this into the internal error, returning None if this was constructed with RIoError::from_kind.

Example
use abi_stable::std_types::RIoError;
use std::io::ErrorKind;

{
    let err = RIoError::from_kind(ErrorKind::AlreadyExists);
    assert_eq!(err.into_inner().map(|_| ()), None);
}
{
    let mut msg = "Cannot access directory at \"/home/wo_boat/blog/\".";
    let err = RIoError::new_(ErrorKind::PermissionDenied, msg);
    assert!(err.into_inner().is_some());
}

Trait Implementations§

source§

impl Debug for RIoError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Display for RIoError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Error for RIoError

1.30.0 · source§

fn source(&self) -> Option<&(dyn Error + 'static)>

The lower-level source of this error, if any. Read more
1.0.0 · source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type based access to context intended for error reports. Read more
source§

impl From<Error> for RIoError

source§

fn from(this: ioError) -> RIoError

Converts to this type from the input type.
source§

impl From<ErrorKind> for RIoError

source§

fn from(kind: ErrorKind) -> Self

Converts to this type from the input type.
source§

impl From<RIoError> for Error

source§

fn from(this: RIoError) -> ioError

Converts to this type from the input type.
source§

impl From<RIoErrorKind> for RIoError

source§

fn from(kind: RIoErrorKind) -> Self

Converts to this type from the input type.
source§

impl GetStaticEquivalent_ for RIoError

§

type StaticEquivalent = _static_RIoError

The 'static equivalent of Self
source§

impl IntoReprRust for RIoError

§

type ReprRust = Error

The #[repr(Rust)] equivalent.
source§

fn into_rust(self) -> Self::ReprRust

Performs the conversion
source§

impl StableAbi for RIoError

§

type IsNonZeroType = False

Whether this type has a single invalid bit-pattern. Read more
source§

const LAYOUT: &'static TypeLayout = _

The layout of the type provided by implementors.
source§

const ABI_CONSTS: AbiConsts = _

const-equivalents of the associated types.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> AlignerFor<1> for T

§

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<1024> for T

§

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<128> for T

§

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<16> for T

§

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<16384> for T

§

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<2> for T

§

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<2048> for T

§

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<256> for T

§

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<32> for T

§

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<32768> for T

§

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<4> for T

§

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<4096> for T

§

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<512> for T

§

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<64> for T

§

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<8> for T

§

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<8192> for T

§

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<S> ROExtAcc for S

source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
source§

impl<S> ROExtOps<Aligned> for S

source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
source§

impl<S> ROExtOps<Unaligned> for S

source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
source§

impl<T> SelfOps for T
where T: ?Sized,

source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
source§

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<This> TransmuteElement for This
where This: ?Sized,

source§

unsafe fn transmute_element<T>( self ) -> <Self as CanTransmuteElement<T>>::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> TypeIdentity for T
where T: ?Sized,

§

type Type = T

This is always Self.
source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.