Struct mozjs::jsapi::mozilla::Result

source ·
#[repr(C)]
pub struct Result { pub mImpl: SelectResultImpl, }
Expand description

Result<V, E> represents the outcome of an operation that can either succeed or fail. It contains either a success value of type V or an error value of type E.

All Result methods are const, so results are basically immutable. This is just like Variant<V, E> but with a slightly different API, and the following cases are optimized so Result can be stored more efficiently:

  • If both the success and error types do not use their least significant bit, are trivially copyable and destructible, Result<V, E> is guaranteed to be as large as the larger type. This is determined via the HasFreeLSB trait. By default, empty classes (in particular Ok) and aligned pointer types are assumed to have a free LSB, but you can specialize this trait for other types. If the success type is empty, the representation is guaranteed to be all zero bits on success. Do not change this representation! There is JIT code that depends on it. (Implementation note: The lowest bit is used as a tag bit: 0 to indicate the Result’s bits are a success value, 1 to indicate the Result’s bits (with the 1 masked out) encode an error value)

  • Else, if the error type can’t have a all-zero bits representation and is not larger than a pointer, a CompactPair is used to represent this rather than a Variant. This has shown to be better optimizable, and the template code is much simpler than that of Variant, so it should also compile faster. Whether an error type can’t be all-zero bits, is determined via the UnusedZero trait. MFBT doesn’t declare any public type UnusedZero, but nsresult is declared UnusedZero in XPCOM.

The purpose of Result is to reduce the screwups caused by using false or nullptr to indicate errors. What screwups? See https://bugzilla.mozilla.org/show_bug.cgi?id=912928 for a partial list.

Result<const V, E> or Result<V, const E> are not meaningful. The success or error values in a Result instance are non-modifiable in-place anyway. This guarantee must also be maintained when evolving Result. They can be unwrap()ped, but this loses const qualification. However, Result<const V, E> or Result<V, const E> may be misleading and prevent movability. Just use Result<V, E>. (Result<const V*, E> may make sense though, just Result<const V* const, E> is not possible.)

Fields§

§mImpl: SelectResultImpl

Trait Implementations§

source§

impl Clone for Result

source§

fn clone(&self) -> Result

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Result

source§

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

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

impl PartialEq for Result

source§

fn eq(&self, other: &Result) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Copy for Result

source§

impl StructuralPartialEq for Result

Auto Trait Implementations§

§

impl Freeze for Result

§

impl RefUnwindSafe for Result

§

impl Send for Result

§

impl Sync for Result

§

impl Unpin for Result

§

impl UnwindSafe for Result

Blanket Implementations§

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> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> Filterable for T

source§

fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>

Creates a filterable data provider with the given name for debugging. 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<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

source§

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>,

source§

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> ErasedDestructor for T
where T: 'static,

source§

impl<T> MaybeSendSync for T