referrerpolicy=no-referrer-when-downgrade
xcm_simulator

Type Alias InteriorLocation

pub type InteriorLocation = Junctions;
Expand description

A relative location which is constrained to be an interior location of the context.

See also Location.

Aliased Type§

enum InteriorLocation {
    Here,
    X1(Arc<[Junction; 1]>),
    X2(Arc<[Junction; 2]>),
    X3(Arc<[Junction; 3]>),
    X4(Arc<[Junction; 4]>),
    X5(Arc<[Junction; 5]>),
    X6(Arc<[Junction; 6]>),
    X7(Arc<[Junction; 7]>),
    X8(Arc<[Junction; 8]>),
}

Variants§

§

Here

The interpreting consensus system.

§

X1(Arc<[Junction; 1]>)

A relative path comprising 1 junction.

§

X2(Arc<[Junction; 2]>)

A relative path comprising 2 junctions.

§

X3(Arc<[Junction; 3]>)

A relative path comprising 3 junctions.

§

X4(Arc<[Junction; 4]>)

A relative path comprising 4 junctions.

§

X5(Arc<[Junction; 5]>)

A relative path comprising 5 junctions.

§

X6(Arc<[Junction; 6]>)

A relative path comprising 6 junctions.

§

X7(Arc<[Junction; 7]>)

A relative path comprising 7 junctions.

§

X8(Arc<[Junction; 8]>)

A relative path comprising 8 junctions.

Implementations

§

impl Junctions

pub const fn into_location(self) -> Location

Convert self into a Location containing 0 parents.

Similar to Into::into, except that this method can be used in a const evaluation context.

pub const fn into_exterior(self, n: u8) -> Location

Convert self into a Location containing n parents.

Similar to Self::into_location, with the added ability to specify the number of parent junctions.

pub fn as_slice(&self) -> &[Junction]

Casts self into a slice containing Junctions.

pub fn as_slice_mut(&mut self) -> &mut [Junction]

Casts self into a mutable slice containing Junctions.

pub fn remove_network_id(&mut self)

Remove the NetworkId value in any Junctions.

pub fn invert_target(&self, target: &Location) -> Result<Location, ()>

Treating self as the universal context, return the location of the local consensus system from the point of view of the given target.

pub fn for_each_mut(&mut self, x: impl FnMut(&mut Junction))

Execute a function f on every junction. We use this since we cannot implement a mutable Iterator without unsafe code.

pub fn global_consensus(&self) -> Result<NetworkId, ()>

Extract the network ID treating this value as a universal location.

This will return an Err if the first item is not a GlobalConsensus, which would indicate that this value is not a universal location.

pub fn split_global(self) -> Result<(NetworkId, Junctions), ()>

Extract the network ID and the interior consensus location, treating this value as a universal location.

This will return an Err if the first item is not a GlobalConsensus, which would indicate that this value is not a universal location.

pub fn within_global(self, relative: Location) -> Result<Junctions, ()>

Treat self as a universal location and the context of relative, returning the universal location of relative.

This will return an error if relative has as many (or more) parents than there are junctions in self, implying that relative refers into a different global consensus.

pub fn relative_to(self, viewer: &Junctions) -> Location

Consumes self and returns how viewer would address it locally.

pub fn first(&self) -> Option<&Junction>

Returns first junction, or None if the location is empty.

pub fn last(&self) -> Option<&Junction>

Returns last junction, or None if the location is empty.

pub fn split_first(self) -> (Junctions, Option<Junction>)

Splits off the first junction, returning the remaining suffix (first item in tuple) and the first element (second item in tuple) or None if it was empty.

pub fn split_last(self) -> (Junctions, Option<Junction>)

Splits off the last junction, returning the remaining prefix (first item in tuple) and the last element (second item in tuple) or None if it was empty.

pub fn take_first(&mut self) -> Option<Junction>

Removes the first element from self, returning it (or None if it was empty).

pub fn take_last(&mut self) -> Option<Junction>

Removes the last element from self, returning it (or None if it was empty).

pub fn push(&mut self, new: impl Into<Junction>) -> Result<(), Junction>

Mutates self to be appended with new or returns an Err with new if would overflow.

pub fn push_front(&mut self, new: impl Into<Junction>) -> Result<(), Junction>

Mutates self to be prepended with new or returns an Err with new if would overflow.

pub fn pushed_with( self, new: impl Into<Junction>, ) -> Result<Junctions, (Junctions, Junction)>

Consumes self and returns a Junctions suffixed with new, or an Err with the original value of self and new in case of overflow.

pub fn pushed_front_with( self, new: impl Into<Junction>, ) -> Result<Junctions, (Junctions, Junction)>

Consumes self and returns a Junctions prefixed with new, or an Err with the original value of self and new in case of overflow.

pub fn append_with( &mut self, suffix: impl Into<Junctions>, ) -> Result<(), Junctions>

Mutate self so that it is suffixed with suffix.

Does not modify self and returns Err with suffix in case of overflow.

§Example
let mut m = Junctions::from([Parachain(21)]);
assert_eq!(m.append_with([PalletInstance(3)]), Ok(()));
assert_eq!(m, [Parachain(21), PalletInstance(3)]);

pub fn len(&self) -> usize

Returns the number of junctions in self.

pub fn at(&self, i: usize) -> Option<&Junction>

Returns the junction at index i, or None if the location doesn’t contain that many elements.

pub fn at_mut(&mut self, i: usize) -> Option<&mut Junction>

Returns a mutable reference to the junction at index i, or None if the location doesn’t contain that many elements.

pub fn iter(&self) -> JunctionsRefIterator<'_>

Returns a reference iterator over the junctions.

pub fn match_and_split(&self, prefix: &Junctions) -> Option<&Junction>

Ensures that self begins with prefix and that it has a single Junction item following. If so, returns a reference to this Junction item.

§Example
let mut m = Junctions::from([Parachain(2), PalletInstance(3), OnlyChild]);
assert_eq!(m.match_and_split(&[Parachain(2), PalletInstance(3)].into()), Some(&OnlyChild));
assert_eq!(m.match_and_split(&[Parachain(2)].into()), None);

pub fn starts_with(&self, prefix: &Junctions) -> bool

Trait Implementations

§

impl Clone for Junctions

§

fn clone(&self) -> Junctions

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
§

impl Debug for Junctions

§

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

Formats the value using the given formatter. Read more
§

impl Decode for Junctions

§

fn decode<__CodecInputEdqy>( __codec_input_edqy: &mut __CodecInputEdqy, ) -> Result<Junctions, Error>
where __CodecInputEdqy: Input,

Attempt to deserialise the value from input.
§

fn decode_into<I>( input: &mut I, dst: &mut MaybeUninit<Self>, ) -> Result<DecodeFinished, Error>
where I: Input,

Attempt to deserialize the value from input into a pre-allocated piece of memory. Read more
§

fn skip<I>(input: &mut I) -> Result<(), Error>
where I: Input,

Attempt to skip the encoded value from input. Read more
§

fn encoded_fixed_size() -> Option<usize>

Returns the fixed encoded size of the type. Read more
§

impl<'de> Deserialize<'de> for Junctions

§

fn deserialize<__D>( __deserializer: __D, ) -> Result<Junctions, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
§

impl Encode for Junctions

§

fn size_hint(&self) -> usize

If possible give a hint of expected size of the encoding. Read more
§

fn encode_to<__CodecOutputEdqy>( &self, __codec_dest_edqy: &mut __CodecOutputEdqy, )
where __CodecOutputEdqy: Output + ?Sized,

Convert self to a slice and append it to the destination.
§

fn encode(&self) -> Vec<u8>

Convert self to an owned vector.
§

fn using_encoded<R, F>(&self, f: F) -> R
where F: FnOnce(&[u8]) -> R,

Convert self to a slice and then invoke the given closure with it.
§

fn encoded_size(&self) -> usize

Calculates the encoded size. Read more
§

impl From<[Junction; 0]> for Junctions

§

fn from(_: [Junction; 0]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 1]> for Junctions

§

fn from(junctions: [Junction; 1]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 2]> for Junctions

§

fn from(junctions: [Junction; 2]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 3]> for Junctions

§

fn from(junctions: [Junction; 3]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 4]> for Junctions

§

fn from(junctions: [Junction; 4]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 5]> for Junctions

§

fn from(junctions: [Junction; 5]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 6]> for Junctions

§

fn from(junctions: [Junction; 6]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 7]> for Junctions

§

fn from(junctions: [Junction; 7]) -> Junctions

Converts to this type from the input type.
§

impl From<[Junction; 8]> for Junctions

§

fn from(junctions: [Junction; 8]) -> Junctions

Converts to this type from the input type.
§

impl From<()> for Junctions

§

fn from(_: ()) -> Junctions

Converts to this type from the input type.
§

impl<J0> From<(J0,)> for Junctions
where J0: Into<Junction>,

§

fn from(_: (J0,)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1> From<(J0, J1)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>,

§

fn from(_: (J0, J1)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2> From<(J0, J1, J2)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>,

§

fn from(_: (J0, J1, J2)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2, J3> From<(J0, J1, J2, J3)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>, J3: Into<Junction>,

§

fn from(_: (J0, J1, J2, J3)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2, J3, J4> From<(J0, J1, J2, J3, J4)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>, J3: Into<Junction>, J4: Into<Junction>,

§

fn from(_: (J0, J1, J2, J3, J4)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2, J3, J4, J5> From<(J0, J1, J2, J3, J4, J5)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>, J3: Into<Junction>, J4: Into<Junction>, J5: Into<Junction>,

§

fn from(_: (J0, J1, J2, J3, J4, J5)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2, J3, J4, J5, J6> From<(J0, J1, J2, J3, J4, J5, J6)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>, J3: Into<Junction>, J4: Into<Junction>, J5: Into<Junction>, J6: Into<Junction>,

§

fn from(_: (J0, J1, J2, J3, J4, J5, J6)) -> Junctions

Converts to this type from the input type.
§

impl<J0, J1, J2, J3, J4, J5, J6, J7> From<(J0, J1, J2, J3, J4, J5, J6, J7)> for Junctions
where J0: Into<Junction>, J1: Into<Junction>, J2: Into<Junction>, J3: Into<Junction>, J4: Into<Junction>, J5: Into<Junction>, J6: Into<Junction>, J7: Into<Junction>,

§

fn from(_: (J0, J1, J2, J3, J4, J5, J6, J7)) -> Junctions

Converts to this type from the input type.
§

impl<T> From<T> for Junctions
where T: Into<Junction>,

§

fn from(x: T) -> Junctions

Converts to this type from the input type.
§

impl IntoIterator for Junctions

§

type Item = Junction

The type of the elements being iterated over.
§

type IntoIter = JunctionsIterator

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <Junctions as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl MaxEncodedLen for Junctions

§

fn max_encoded_len() -> usize

Upper bound, in bytes, of the maximum encoded size of this item.
§

impl Ord for Junctions

§

fn cmp(&self, other: &Junctions) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
§

impl PartialEq<[Junction; 1]> for Junctions

§

fn eq(&self, rhs: &[Junction; 1]) -> 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.
§

impl PartialEq<[Junction; 2]> for Junctions

§

fn eq(&self, rhs: &[Junction; 2]) -> 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.
§

impl PartialEq<[Junction; 3]> for Junctions

§

fn eq(&self, rhs: &[Junction; 3]) -> 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.
§

impl PartialEq<[Junction; 4]> for Junctions

§

fn eq(&self, rhs: &[Junction; 4]) -> 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.
§

impl PartialEq<[Junction; 5]> for Junctions

§

fn eq(&self, rhs: &[Junction; 5]) -> 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.
§

impl PartialEq<[Junction; 6]> for Junctions

§

fn eq(&self, rhs: &[Junction; 6]) -> 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.
§

impl PartialEq<[Junction; 7]> for Junctions

§

fn eq(&self, rhs: &[Junction; 7]) -> 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.
§

impl PartialEq<[Junction; 8]> for Junctions

§

fn eq(&self, rhs: &[Junction; 8]) -> 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.
§

impl PartialEq for Junctions

§

fn eq(&self, other: &Junctions) -> 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.
§

impl PartialOrd for Junctions

§

fn partial_cmp(&self, other: &Junctions) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

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

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

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

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

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

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

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

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
§

impl Serialize for Junctions

§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
§

impl TryFrom<Junctions> for Junctions

§

type Error = ()

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

fn try_from(old: Junctions) -> Result<Junctions, ()>

Performs the conversion.
§

impl TryFrom<Location> for Junctions

§

type Error = Location

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

fn try_from(x: Location) -> Result<Junctions, Location>

Performs the conversion.
§

impl TryFrom<VersionedInteriorLocation> for Junctions

§

type Error = ()

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

fn try_from(x: VersionedInteriorLocation) -> Result<Junctions, ()>

Performs the conversion.
§

impl TypeInfo for Junctions

§

type Identity = Junctions

The type identifying for which type info is provided. Read more
§

fn type_info() -> Type

Returns the static type identifier for Self.
§

impl DecodeWithMemTracking for Junctions

§

impl EncodeLike for Junctions

§

impl Eq for Junctions

§

impl StructuralPartialEq for Junctions