Struct soroban_sdk::Vec

source ·
pub struct Vec<T> { /* private fields */ }
Expand description

Vec is a sequential and indexable growable collection type.

Values are stored in the environment and are available to contract through the functions defined on Vec. Values stored in the Vec are transmitted to the environment as RawVals, and when retrieved from the Vec are transmitted back and converted from RawVal back into their type.

The values in a Vec are not guaranteed to be of type T and conversion will fail if they are not. Most functions on Vec return a Result due to this.

To store u8s and binary data, use Bytes/BytesN instead.

Vec values can be stored as Storage, or in other types like Vec, Map, etc.

Examples

use soroban_sdk::{vec, Env};

let env = Env::default();
let vec = vec![&env, 0, 1, 2, 3];
assert_eq!(vec.len(), 4);

Implementation Details

The following information is implementation details that has no consistency guarantee.

Values are stored in the environment backed by a RRB-vector using im_rc::Vector. Most operations are O(log n). Push/pop are O(1) amortised, and O(log n) in the worst case.

Implementations§

source§

impl<T> Vec<T>

source

pub fn env(&self) -> &Env

source

pub fn as_raw(&self) -> &RawVal

source

pub fn to_raw(&self) -> RawVal

source

pub fn as_object(&self) -> &VecObject

source

pub fn to_object(&self) -> VecObject

source§

impl<T> Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source

pub fn new(env: &Env) -> Vec<T>

source

pub fn from_array<const N: usize>(env: &Env, items: [T; N]) -> Vec<T>

source

pub fn from_slice(env: &Env, items: &[T]) -> Vec<T>where T: Clone,

source

pub fn get(&self, i: u32) -> Option<Result<T, T::Error>>

source

pub fn get_unchecked(&self, i: u32) -> Result<T, T::Error>where T::Error: Debug,

source

pub fn set(&mut self, i: u32, v: T)

source

pub fn remove(&mut self, i: u32) -> Option<()>

source

pub fn remove_unchecked(&mut self, i: u32)

source

pub fn is_empty(&self) -> bool

source

pub fn len(&self) -> u32

source

pub fn push_front(&mut self, x: T)

source

pub fn pop_front(&mut self) -> Option<Result<T, T::Error>>

source

pub fn pop_front_unchecked(&mut self) -> Result<T, T::Error>

source

pub fn push_back(&mut self, x: T)

source

pub fn pop_back(&mut self) -> Option<Result<T, T::Error>>

source

pub fn pop_back_unchecked(&mut self) -> Result<T, T::Error>

source

pub fn push(&mut self, x: T)

👎Deprecated: use [Vec::push_back]
source

pub fn pop(&mut self) -> Option<Result<T, T::Error>>

👎Deprecated: use [Vec::pop_back]
source

pub fn pop_unchecked(&mut self) -> Result<T, T::Error>

👎Deprecated: use [Vec::push_back_unchecked]
source

pub fn first(&self) -> Option<Result<T, T::Error>>

source

pub fn first_unchecked(&self) -> Result<T, T::Error>

source

pub fn last(&self) -> Option<Result<T, T::Error>>

source

pub fn last_unchecked(&self) -> Result<T, T::Error>

source

pub fn insert(&mut self, i: u32, x: T)

source

pub fn append(&mut self, other: &Vec<T>)

source

pub fn extend_from_array<const N: usize>(&mut self, items: [T; N])

source

pub fn extend_from_slice(&mut self, items: &[T])where T: Clone,

source

pub fn slice(&self, r: impl RangeBounds<u32>) -> Self

source

pub fn iter(&self) -> VecIter<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal> + Clone,

source

pub fn iter_unchecked(&self) -> UncheckedIter<VecIter<T>, T, T::Error> where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal> + Clone, T::Error: Debug,

source

pub fn into_iter_unchecked(self) -> UncheckedIter<VecIter<T>, T, T::Error> where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal> + Clone, T::Error: Debug,

source§

impl<T> Vec<T>where T: IntoVal<Env, RawVal>,

source

pub fn contains(&self, item: impl Borrow<T>) -> bool

Returns true if the Vec contains the item.

source

pub fn first_index_of(&self, item: impl Borrow<T>) -> Option<u32>

Returns the index of the first occurrence of the item.

If the item cannot be found None is returned.

source

pub fn last_index_of(&self, item: impl Borrow<T>) -> Option<u32>

Returns the index of the last occurrence of the item.

If the item cannot be found None is returned.

Returns the index of an occurrence of the item in an already sorted Vec, or the index of where the item can be inserted to keep the Vec sorted.

If the item is found, Result::Ok is returned containing the index of the item.

If the item is not found, Result::Err is returned containing the index of where the item could be inserted to retain the sorted ordering.

source§

impl<T> Vec<Vec<T>>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal> + Clone,

source

pub fn concat(&self) -> Vec<T>

Trait Implementations§

source§

impl<T: Clone> Clone for Vec<T>

source§

fn clone(&self) -> Vec<T>

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<T> Debug for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal> + Debug + Clone, T::Error: Debug,

source§

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

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

impl<T> From<Vec<T>> for RawValwhere T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source§

fn from(v: Vec<T>) -> Self

Converts to this type from the input type.
source§

impl<T> From<Vec<T>> for VecObjectwhere T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source§

fn from(v: Vec<T>) -> Self

Converts to this type from the input type.
source§

impl<T> IntoIterator for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

§

type Item = Result<T, <T as TryFromVal<Env, RawVal>>::Error>

The type of the elements being iterated over.
§

type IntoIter = VecIter<T>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
source§

impl<T> Ord for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source§

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

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

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

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

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

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

fn clamp(self, min: Self, max: Self) -> Selfwhere Self: Sized + PartialOrd<Self>,

Restrict a value to a certain interval. Read more
source§

impl<T> PartialEq<Vec<T>> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source§

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

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

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

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

impl<T> PartialOrd<Vec<T>> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

source§

fn partial_cmp(&self, other: &Self) -> 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

This method 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

This method 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

This method 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

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

impl<T> TryFrom<&Vec<T>> for ScVal

§

type Error = ConversionError

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

fn try_from(v: &Vec<T>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<T> TryFrom<&Vec<T>> for ScVec

§

type Error = ConversionError

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

fn try_from(v: &Vec<T>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<T> TryFrom<Vec<T>> for ScVal

§

type Error = ConversionError

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

fn try_from(v: Vec<T>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<T> TryFrom<Vec<T>> for ScVec

§

type Error = ConversionError

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

fn try_from(v: Vec<T>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<T> TryFromVal<Env, &Vec<RawVal>> for Vec<T>

§

type Error = Infallible

source§

fn try_from_val(env: &Env, v: &&Vec<RawVal>) -> Result<Self, Self::Error>

source§

impl TryFromVal<Env, ()> for Vec<RawVal>

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, _v: &()) -> Result<Self, Self::Error>

source§

impl<T0> TryFromVal<Env, (T0,)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>,

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, v: &(T0,)) -> Result<Self, Self::Error>

source§

impl<T0, T1> TryFromVal<Env, (T0, T1)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>,

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, v: &(T0, T1)) -> Result<Self, Self::Error>

source§

impl<T0, T1, T2> TryFromVal<Env, (T0, T1, T2)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3> TryFromVal<Env, (T0, T1, T2, T3)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4> TryFromVal<Env, (T0, T1, T2, T3, T4)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5> TryFromVal<Env, (T0, T1, T2, T3, T4, T5)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7, T8)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>, T8: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>, T8: IntoVal<Env, RawVal>, T9: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>, T8: IntoVal<Env, RawVal>, T9: IntoVal<Env, RawVal>, T10: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>, T8: IntoVal<Env, RawVal>, T9: IntoVal<Env, RawVal>, T10: IntoVal<Env, RawVal>, T11: IntoVal<Env, RawVal>,

source§

impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> TryFromVal<Env, (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)> for Vec<RawVal>where T0: IntoVal<Env, RawVal>, T1: IntoVal<Env, RawVal>, T2: IntoVal<Env, RawVal>, T3: IntoVal<Env, RawVal>, T4: IntoVal<Env, RawVal>, T5: IntoVal<Env, RawVal>, T6: IntoVal<Env, RawVal>, T7: IntoVal<Env, RawVal>, T8: IntoVal<Env, RawVal>, T9: IntoVal<Env, RawVal>, T10: IntoVal<Env, RawVal>, T11: IntoVal<Env, RawVal>, T12: IntoVal<Env, RawVal>,

source§

impl<T> TryFromVal<Env, RawVal> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, val: &RawVal) -> Result<Self, Self::Error>

source§

impl<T> TryFromVal<Env, ScVal> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, val: &ScVal) -> Result<Self, Self::Error>

source§

impl<T> TryFromVal<Env, ScVec> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

§

type Error = ConversionError

source§

fn try_from_val(env: &Env, val: &ScVec) -> Result<Self, Self::Error>

source§

impl<T> TryFromVal<Env, Vec<T>> for RawVal

§

type Error = ConversionError

source§

fn try_from_val(_env: &Env, v: &Vec<T>) -> Result<Self, Self::Error>

source§

impl<T> TryFromVal<Env, Vec<T>> for Vec<RawVal>

§

type Error = Infallible

source§

fn try_from_val(env: &Env, v: &Vec<T>) -> Result<Self, Self::Error>

source§

impl<T> TryFromVal<Env, VecObject> for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

§

type Error = Infallible

source§

fn try_from_val(env: &Env, obj: &VecObject) -> Result<Self, Self::Error>

source§

impl<T> Eq for Vec<T>where T: IntoVal<Env, RawVal> + TryFromVal<Env, RawVal>,

Auto Trait Implementations§

§

impl<T> !RefUnwindSafe for Vec<T>

§

impl<T> !Send for Vec<T>

§

impl<T> !Sync for Vec<T>

§

impl<T> Unpin for Vec<T>where T: Unpin,

§

impl<T> !UnwindSafe for Vec<T>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<T, C> Compare<&T> for Cwhere C: Compare<T>,

§

type Error = <C as Compare<T>>::Error

§

fn compare(&self, a: &&T, b: &&T) -> Result<Ordering, <C as Compare<&T>>::Error>

§

impl<T, U, E, C> Compare<(T, U)> for Cwhere C: Compare<T, Error = E, Error = E> + Compare<U>,

§

type Error = E

§

fn compare( &self, a: &(T, U), b: &(T, U) ) -> Result<Ordering, <C as Compare<(T, U)>>::Error>

§

impl<T, U, V, E, C> Compare<(T, U, V)> for Cwhere C: Compare<T, Error = E, Error = E, Error = E> + Compare<U> + Compare<V>,

§

type Error = E

§

fn compare( &self, a: &(T, U, V), b: &(T, U, V) ) -> Result<Ordering, <C as Compare<(T, U, V)>>::Error>

§

impl<T, C> Compare<Box<T, Global>> for Cwhere C: Compare<T>,

§

type Error = <C as Compare<T>>::Error

§

fn compare( &self, a: &Box<T, Global>, b: &Box<T, Global> ) -> Result<Ordering, <C as Compare<Box<T, Global>>>::Error>

§

impl<T, C> Compare<Option<T>> for Cwhere C: Compare<T>,

§

type Error = <C as Compare<T>>::Error

§

fn compare( &self, a: &Option<T>, b: &Option<T> ) -> Result<Ordering, <C as Compare<Option<T>>>::Error>

§

impl<T, C> Compare<Rc<T>> for Cwhere C: Compare<T>,

§

type Error = <C as Compare<T>>::Error

§

fn compare( &self, a: &Rc<T>, b: &Rc<T> ) -> Result<Ordering, <C as Compare<Rc<T>>>::Error>

§

impl<T, C> Compare<Vec<T, Global>> for Cwhere C: Compare<T>,

§

type Error = <C as Compare<T>>::Error

§

fn compare( &self, a: &Vec<T, Global>, b: &Vec<T, Global> ) -> Result<Ordering, <C as Compare<Vec<T, Global>>>::Error>

§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<E, T, U> FromVal<E, T> for Uwhere E: Env, U: TryFromVal<E, T>,

source§

fn from_val(e: &E, v: &T) -> U

source§

impl<T> FromXdr for Twhere T: TryFromVal<Env, RawVal>,

§

type Error = <T as TryFromVal<Env, RawVal>>::Error

source§

fn from_xdr(env: &Env, b: &Bytes) -> Result<T, <T as FromXdr>::Error>

source§

impl<T, U> Into<U> for Twhere 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<E, T, U> IntoVal<E, T> for Uwhere E: Env, T: FromVal<E, U>,

source§

fn into_val(&self, e: &E) -> T

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

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> ToXdr for Twhere T: IntoVal<Env, RawVal>,

source§

fn to_xdr(self, env: &Env) -> Bytes

source§

impl<T, U> TryFrom<U> for Twhere 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 Twhere 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.
§

impl<E, T, U> TryIntoVal<E, T> for Uwhere E: Env, T: TryFromVal<E, U>,

§

type Error = <T as TryFromVal<E, U>>::Error

§

fn try_into_val(&self, env: &E) -> Result<T, <U as TryIntoVal<E, T>>::Error>

§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V