pub struct MultiValue2<T0, T1>(pub (T0, T1));
Tuple Fields§
§0: (T0, T1)
Implementations§
Source§impl<T0, T1> MultiValue2<T0, T1>
impl<T0, T1> MultiValue2<T0, T1>
pub fn into_tuple(self) -> (T0, T1)
Trait Implementations§
Source§impl<T0, T1> Clone for MultiValue2<T0, T1>
impl<T0, T1> Clone for MultiValue2<T0, T1>
Source§fn clone(&self) -> MultiValue2<T0, T1>
fn clone(&self) -> MultiValue2<T0, T1>
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<T0, T1> Debug for MultiValue2<T0, T1>
impl<T0, T1> Debug for MultiValue2<T0, T1>
Source§impl<T0, T1> From<(T0, T1)> for MultiValue2<T0, T1>
impl<T0, T1> From<(T0, T1)> for MultiValue2<T0, T1>
Source§fn from(tuple: (T0, T1)) -> MultiValue2<T0, T1>
fn from(tuple: (T0, T1)) -> MultiValue2<T0, T1>
Converts to this type from the input type.
Source§impl<T1, T2> ManagedVecItem for MultiValue2<T1, T2>
impl<T1, T2> ManagedVecItem for MultiValue2<T1, T2>
Source§const SKIPS_RESERIALIZATION: bool
const SKIPS_RESERIALIZATION: bool
If true, then the encoding of the item is identical to the payload,
and no further conversion is necessary
(the underlying buffer can be used as-is during serialization).
False for all managed types, but true for basic types (like
u32
).Source§type PAYLOAD = <(T1, (T2, ())) as ManagedVecItemNestedTuple>::PAYLOAD
type PAYLOAD = <(T1, (T2, ())) as ManagedVecItemNestedTuple>::PAYLOAD
Type managing the underlying binary representation in a ManagedVec..
Source§type Ref<'a> = ManagedVecRef<'a, MultiValue2<T1, T2>>
type Ref<'a> = ManagedVecRef<'a, MultiValue2<T1, T2>>
Reference representation of the ManagedVec item. Read more
Source§fn read_from_payload(payload: &Self::PAYLOAD) -> Self
fn read_from_payload(payload: &Self::PAYLOAD) -> Self
Parses given bytes as a an owned object.
Source§unsafe fn borrow_from_payload<'a>(payload: &Self::PAYLOAD) -> Self::Ref<'a>
unsafe fn borrow_from_payload<'a>(payload: &Self::PAYLOAD) -> Self::Ref<'a>
Parses given bytes as a representation of the object, either owned, or a reference. Read more
Source§fn save_to_payload(self, payload: &mut Self::PAYLOAD)
fn save_to_payload(self, payload: &mut Self::PAYLOAD)
Converts the object into bytes. Read more
fn payload_size() -> usize
Source§impl<T0, T1> PartialEq for MultiValue2<T0, T1>
impl<T0, T1> PartialEq for MultiValue2<T0, T1>
Source§impl<T0, T1> TopDecodeMulti for MultiValue2<T0, T1>where
T0: TopDecodeMulti,
T1: TopDecodeMulti,
impl<T0, T1> TopDecodeMulti for MultiValue2<T0, T1>where
T0: TopDecodeMulti,
T1: TopDecodeMulti,
fn multi_decode_or_handle_err<I, H>(
input: &mut I,
h: H,
) -> Result<MultiValue2<T0, T1>, <H as DecodeErrorHandler>::HandledErr>where
I: TopDecodeMultiInput,
H: DecodeErrorHandler,
Source§const IS_SINGLE_VALUE: bool = false
const IS_SINGLE_VALUE: bool = false
Used to optimize single value loading of endpoint arguments.
fn multi_decode<I>(input: &mut I) -> Result<Self, DecodeError>where
I: TopDecodeMultiInput,
Source§impl<T0, T1> TopDecodeMultiLength for MultiValue2<T0, T1>
impl<T0, T1> TopDecodeMultiLength for MultiValue2<T0, T1>
Source§impl<T0, T1> TopEncodeMulti for MultiValue2<T0, T1>where
T0: TopEncodeMulti,
T1: TopEncodeMulti,
impl<T0, T1> TopEncodeMulti for MultiValue2<T0, T1>where
T0: TopEncodeMulti,
T1: TopEncodeMulti,
Source§fn multi_encode_or_handle_err<O, H>(
&self,
output: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeMultiOutput,
H: EncodeErrorHandler,
fn multi_encode_or_handle_err<O, H>(
&self,
output: &mut O,
h: H,
) -> Result<(), <H as EncodeErrorHandler>::HandledErr>where
O: TopEncodeMultiOutput,
H: EncodeErrorHandler,
Version of
top_encode
that can handle errors as soon as they occur.
For instance in can exit immediately and make sure that if it returns, it is a success.
By not deferring error handling, this can lead to somewhat smaller bytecode.Source§fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
O: TopEncodeMultiOutput,
fn multi_encode<O>(&self, output: &mut O) -> Result<(), EncodeError>where
O: TopEncodeMultiOutput,
Attempt to serialize the value to ouput.
Source§impl<T0, T1> TypeAbi for MultiValue2<T0, T1>
impl<T0, T1> TypeAbi for MultiValue2<T0, T1>
type Unmanaged = MultiValue2<<T0 as TypeAbi>::Unmanaged, <T1 as TypeAbi>::Unmanaged>
fn type_name() -> TypeName
fn type_name_rust() -> TypeName
Source§fn provide_type_descriptions<TDC: TypeDescriptionContainer>(
accumulator: &mut TDC,
)
fn provide_type_descriptions<TDC: TypeDescriptionContainer>( accumulator: &mut TDC, )
A type can provide more than its own name.
For instance, a struct can also provide the descriptions of the type of its fields.
TypeAbi doesn’t care for the exact accumulator type,
which is abstracted by the TypeDescriptionContainer trait.
fn type_names() -> TypeNames
impl<T0, T1> StructuralPartialEq for MultiValue2<T0, T1>
impl<T0, U0, T1, U1> TypeAbiFrom<MultiValue2<U0, U1>> for MultiValue2<T0, T1>where
T0: TypeAbiFrom<U0>,
T1: TypeAbiFrom<U1>,
Auto Trait Implementations§
impl<T0, T1> Freeze for MultiValue2<T0, T1>
impl<T0, T1> RefUnwindSafe for MultiValue2<T0, T1>where
T0: RefUnwindSafe,
T1: RefUnwindSafe,
impl<T0, T1> Send for MultiValue2<T0, T1>
impl<T0, T1> Sync for MultiValue2<T0, T1>
impl<T0, T1> Unpin for MultiValue2<T0, T1>
impl<T0, T1> UnwindSafe for MultiValue2<T0, T1>where
T0: UnwindSafe,
T1: UnwindSafe,
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