Struct fidl::encoding::Ambiguous1
source · pub struct Ambiguous1;
Expand description
A fake FIDL type that can encode from and decode into any Rust type.
This exists solely to prevent the compiler from inferring T: TypeMarker
,
allowing us to add new generic impls without source breakage. It also
improves error messages when no suitable T: TypeMarker
exists, preventing
spurious guesses about what you should do (e.g. implement HandleBased
).
Trait Implementations§
source§impl<D: ResourceDialect> Decode<Ambiguous1, D> for AmbiguousNever
impl<D: ResourceDialect> Decode<Ambiguous1, D> for AmbiguousNever
source§impl ResourceTypeMarker for Ambiguous1
impl ResourceTypeMarker for Ambiguous1
§type Borrowed<'a> = AmbiguousNever
type Borrowed<'a> = AmbiguousNever
The Rust type to use for encoding. This is a particular
Encode<Self>
type cheaply obtainable from &mut Self::Owned
. There are three cases: Read moresource§fn take_or_borrow(value: &mut <Self as TypeMarker>::Owned) -> Self::Borrowed<'_>where
Self: TypeMarker,
fn take_or_borrow(value: &mut <Self as TypeMarker>::Owned) -> Self::Borrowed<'_>where
Self: TypeMarker,
Cheaply converts from
&mut Self::Owned
to Self::Borrowed
. For
HandleBased
types this is “take” (it returns an owned handle and
replaces value
with Handle::invalid
), and for all other types it is
“borrow” (just converts from one reference to another).source§impl TypeMarker for Ambiguous1
impl TypeMarker for Ambiguous1
§type Owned = AmbiguousNever
type Owned = AmbiguousNever
The owned Rust type which this FIDL type decodes into.
source§fn inline_align(_context: Context) -> usize
fn inline_align(_context: Context) -> usize
Returns the minimum required alignment of the inline portion of the
encoded object. It must be a (nonzero) power of two.
source§fn inline_size(_context: Context) -> usize
fn inline_size(_context: Context) -> usize
Returns the size of the inline portion of the encoded object, including
padding for alignment. Must be a multiple of
inline_align
.source§fn encode_is_copy() -> bool
fn encode_is_copy() -> bool
Returns true if the memory layout of
Self::Owned
matches the FIDL wire
format and encoding requires no validation. When true, we can optimize
encoding arrays and vectors of Self::Owned
to a single memcpy. Read moresource§fn decode_is_copy() -> bool
fn decode_is_copy() -> bool
Returns true if the memory layout of
Self::Owned
matches the FIDL wire
format and decoding requires no validation. When true, we can optimize
decoding arrays and vectors of Self::Owned
to a single memcpy.source§impl ValueTypeMarker for Ambiguous1
impl ValueTypeMarker for Ambiguous1
§type Borrowed<'a> = AmbiguousNever
type Borrowed<'a> = AmbiguousNever
The Rust type to use for encoding. This is a particular
Encode<Self>
type cheaply obtainable from &Self::Owned
. There are three cases: Read moreAuto Trait Implementations§
impl Freeze for Ambiguous1
impl RefUnwindSafe for Ambiguous1
impl Send for Ambiguous1
impl Sync for Ambiguous1
impl Unpin for Ambiguous1
impl UnwindSafe for Ambiguous1
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