rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::iter

Trait Extend

1.0.0 · Source
pub trait Extend<A> {
    // Required method
    fn extend<T>(&mut self, iter: T)
       where T: IntoIterator<Item = A>;

    // Provided methods
    fn extend_one(&mut self, item: A) { ... }
    fn extend_reserve(&mut self, additional: usize) { ... }
}
Available on crate feature mtls only.
Expand description

Extend a collection with the contents of an iterator.

Iterators produce a series of values, and collections can also be thought of as a series of values. The Extend trait bridges this gap, allowing you to extend a collection by including the contents of that iterator. When extending a collection with an already existing key, that entry is updated or, in the case of collections that permit multiple entries with equal keys, that entry is inserted.

§Examples

Basic usage:

// You can extend a String with some chars:
let mut message = String::from("The first three letters are: ");

message.extend(&['a', 'b', 'c']);

assert_eq!("abc", &message[29..32]);

Implementing Extend:

// A sample collection, that's just a wrapper over Vec<T>
#[derive(Debug)]
struct MyCollection(Vec<i32>);

// Let's give it some methods so we can create one and add things
// to it.
impl MyCollection {
    fn new() -> MyCollection {
        MyCollection(Vec::new())
    }

    fn add(&mut self, elem: i32) {
        self.0.push(elem);
    }
}

// since MyCollection has a list of i32s, we implement Extend for i32
impl Extend<i32> for MyCollection {

    // This is a bit simpler with the concrete type signature: we can call
    // extend on anything which can be turned into an Iterator which gives
    // us i32s. Because we need i32s to put into MyCollection.
    fn extend<T: IntoIterator<Item=i32>>(&mut self, iter: T) {

        // The implementation is very straightforward: loop through the
        // iterator, and add() each element to ourselves.
        for elem in iter {
            self.add(elem);
        }
    }
}

let mut c = MyCollection::new();

c.add(5);
c.add(6);
c.add(7);

// let's extend our collection with three more numbers
c.extend(vec![1, 2, 3]);

// we've added these elements onto the end
assert_eq!("MyCollection([5, 6, 7, 1, 2, 3])", format!("{c:?}"));

Required Methods§

1.0.0 · Source

fn extend<T>(&mut self, iter: T)
where T: IntoIterator<Item = A>,

Extends a collection with the contents of an iterator.

As this is the only required method for this trait, the trait-level docs contain more details.

§Examples
// You can extend a String with some chars:
let mut message = String::from("abc");

message.extend(['d', 'e', 'f'].iter());

assert_eq!("abcdef", &message);

Provided Methods§

Source

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)

Extends a collection with exactly one element.

Source

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)

Reserves capacity in a collection for the given number of additional elements.

The default implementation does nothing.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl Extend<(String, Value)> for serde_json::map::Map<String, Value>

Source§

impl Extend<(String, Value)> for toml::map::Map<String, Value>

Source§

impl Extend<char> for InlinableString

1.0.0 · Source§

impl Extend<char> for String

Source§

impl Extend<u8> for BytesMut

1.28.0 · Source§

impl Extend<()> for ()

1.4.0 · Source§

impl Extend<String> for String

1.52.0 · Source§

impl Extend<OsString> for OsString

Source§

impl Extend<Bytes> for BytesMut

Source§

impl Extend<CreateFlags> for CreateFlags

Source§

impl Extend<ReadFlags> for ReadFlags

Source§

impl Extend<WatchFlags> for WatchFlags

Source§

impl Extend<Access> for Access

Source§

impl Extend<AtFlags> for AtFlags

Source§

impl Extend<FallocateFlags> for FallocateFlags

Source§

impl Extend<MemfdFlags> for MemfdFlags

Source§

impl Extend<Mode> for Mode

Source§

impl Extend<OFlags> for OFlags

Source§

impl Extend<RenameFlags> for RenameFlags

Source§

impl Extend<ResolveFlags> for ResolveFlags

Source§

impl Extend<SealFlags> for SealFlags

Source§

impl Extend<StatVfsMountFlags> for StatVfsMountFlags

Source§

impl Extend<StatxFlags> for StatxFlags

Source§

impl Extend<DupFlags> for DupFlags

Source§

impl Extend<FdFlags> for FdFlags

Source§

impl Extend<ReadWriteFlags> for ReadWriteFlags

Source§

impl Extend<MountFlags> for MountFlags

Source§

impl Extend<MountPropagationFlags> for MountPropagationFlags

Source§

impl Extend<UnmountFlags> for UnmountFlags

Source§

impl Extend<IFlags> for IFlags

Source§

impl Extend<XattrFlags> for XattrFlags

Source§

impl Extend<TrustAnchor<'static>> for RootCertStore

Source§

impl Extend<Table> for ArrayOfTables

Source§

impl<'a> Extend<&'a char> for InlinableString

1.2.0 · Source§

impl<'a> Extend<&'a char> for String

Source§

impl<'a> Extend<&'a str> for InlinableString

1.0.0 · Source§

impl<'a> Extend<&'a str> for String

Source§

impl<'a> Extend<&'a u8> for BytesMut

Source§

impl<'a> Extend<&'a u8> for PrefixedPayload

1.52.0 · Source§

impl<'a> Extend<&'a OsStr> for OsString

1.19.0 · Source§

impl<'a> Extend<Cow<'a, str>> for String

1.52.0 · Source§

impl<'a> Extend<Cow<'a, OsStr>> for OsString

1.2.0 · Source§

impl<'a, K, V, A> Extend<(&'a K, &'a V)> for BTreeMap<K, V, A>
where K: Ord + Copy, V: Copy, A: Allocator + Clone,

1.4.0 · Source§

impl<'a, K, V, S> Extend<(&'a K, &'a V)> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::collections::HashMap<K, V, S>
where K: Eq + Hash + Copy, V: Copy, S: BuildHasher,

Source§

impl<'a, K, V, S> Extend<(&'a K, &'a V)> for IndexMap<K, V, S>
where K: Hash + Eq + Copy, V: Copy, S: BuildHasher,

Source§

impl<'a, K, V, S, A> Extend<&'a (K, V)> for hashbrown::map::HashMap<K, V, S, A>
where K: Eq + Hash + Copy, V: Copy, S: BuildHasher, A: Allocator,

Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.

Source§

impl<'a, K, V, S, A> Extend<(&'a K, &'a V)> for hashbrown::map::HashMap<K, V, S, A>
where K: Eq + Hash + Copy, V: Copy, S: BuildHasher, A: Allocator,

Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.

Source§

impl<'a, T> Extend<&'a Range<T>> for IntervalSet<T>
where T: 'a + IntervalBound,

Source§

impl<'a, T> Extend<&'a RangeInclusive<T>> for IntervalSet<T>
where T: 'a + IntervalBound,

Source§

impl<'a, T> Extend<&'a Interval<T>> for IntervalSet<T>
where T: 'a + IntervalBound,

1.2.0 · Source§

impl<'a, T, A> Extend<&'a T> for BinaryHeap<T, A>
where T: 'a + Ord + Copy, A: Allocator,

1.2.0 · Source§

impl<'a, T, A> Extend<&'a T> for BTreeSet<T, A>
where T: 'a + Ord + Copy, A: Allocator + Clone,

1.2.0 · Source§

impl<'a, T, A> Extend<&'a T> for LinkedList<T, A>
where T: 'a + Copy, A: Allocator,

1.2.0 · Source§

impl<'a, T, A> Extend<&'a T> for VecDeque<T, A>
where T: 'a + Copy, A: Allocator,

1.2.0 · Source§

impl<'a, T, A> Extend<&'a T> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::vec::Vec<T, A>
where T: Copy + 'a, A: Allocator,

Extend implementation that copies elements out of references before pushing them onto the Vec.

This implementation is specialized for slice iterators, where it uses copy_from_slice to append the entire slice at once.

Source§

impl<'a, T, A> Extend<&'a T> for allocator_api2::stable::vec::Vec<T, A>
where T: Copy + 'a, A: Allocator + 'a,

Extend implementation that copies elements out of references before pushing them onto the Vec.

This implementation is specialized for slice iterators, where it uses copy_from_slice to append the entire slice at once.

1.4.0 · Source§

impl<'a, T, S> Extend<&'a T> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::collections::HashSet<T, S>
where T: 'a + Eq + Hash + Copy, S: BuildHasher,

Source§

impl<'a, T, S> Extend<&'a T> for IndexSet<T, S>
where T: Hash + Eq + Copy + 'a, S: BuildHasher,

Source§

impl<'a, T, S, A> Extend<&'a T> for hashbrown::set::HashSet<T, S, A>
where T: 'a + Eq + Hash + Copy, S: BuildHasher, A: Allocator,

Source§

impl<'s, T> Extend<T> for SliceVec<'s, T>

Source§

impl<A> Extend<<A as Array>::Item> for SmallVec<A>
where A: Array,

Source§

impl<A> Extend<<A as Array>::Item> for TinyVec<A>
where A: Array,

Source§

impl<A> Extend<<A as Array>::Item> for ArrayVec<A>
where A: Array,

1.45.0 · Source§

impl<A> Extend<Box<str, A>> for String
where A: Allocator,

Source§

impl<A> Extend<Box<str, A>> for String
where A: Allocator,

1.56.0 · Source§

impl<A, B, ExtendA, ExtendB> Extend<(A, B)> for (ExtendA, ExtendB)
where ExtendA: Extend<A>, ExtendB: Extend<B>,

Source§

impl<Fut> Extend<Fut> for FuturesOrdered<Fut>
where Fut: Future,

Source§

impl<Fut> Extend<Fut> for FuturesUnordered<Fut>

Source§

impl<K, V> Extend<(K, V)> for StreamMap<K, V>

Source§

impl<K, V> Extend<(K, V)> for InlineTable
where K: Into<Key>, V: Into<Value>,

Source§

impl<K, V> Extend<(K, V)> for Table
where K: Into<Key>, V: Into<Item>,

1.0.0 · Source§

impl<K, V, A> Extend<(K, V)> for BTreeMap<K, V, A>
where K: Ord, A: Allocator + Clone,

1.0.0 · Source§

impl<K, V, S> Extend<(K, V)> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::collections::HashMap<K, V, S>
where K: Eq + Hash, S: BuildHasher,

Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.

Source§

impl<K, V, S> Extend<(K, V)> for IndexMap<K, V, S>
where K: Hash + Eq, S: BuildHasher,

Source§

impl<K, V, S, A> Extend<(K, V)> for hashbrown::map::HashMap<K, V, S, A>
where K: Eq + Hash, S: BuildHasher, A: Allocator,

Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.

Source§

impl<L, R, A> Extend<A> for Either<L, R>
where L: Extend<A>, R: Extend<A>,

1.0.0 · Source§

impl<P> Extend<P> for PathBuf
where P: AsRef<Path>,

Source§

impl<St> Extend<St> for SelectAll<St>
where St: Stream + Unpin,

Source§

impl<T> Extend<(Option<HeaderName>, T)> for HeaderMap<T>

Source§

impl<T> Extend<(HeaderName, T)> for HeaderMap<T>

Source§

impl<T> Extend<Range<T>> for IntervalSet<T>
where T: IntervalBound,

Source§

impl<T> Extend<RangeInclusive<T>> for IntervalSet<T>
where T: IntervalBound,

Source§

impl<T> Extend<Interval<T>> for IntervalSet<T>
where T: IntervalBound,

1.0.0 · Source§

impl<T, A> Extend<T> for BinaryHeap<T, A>
where T: Ord, A: Allocator,

1.0.0 · Source§

impl<T, A> Extend<T> for BTreeSet<T, A>
where T: Ord, A: Allocator + Clone,

1.0.0 · Source§

impl<T, A> Extend<T> for LinkedList<T, A>
where A: Allocator,

1.0.0 · Source§

impl<T, A> Extend<T> for VecDeque<T, A>
where A: Allocator,

1.0.0 · Source§

impl<T, A> Extend<T> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::vec::Vec<T, A>
where A: Allocator,

Source§

impl<T, A> Extend<T> for allocator_api2::stable::vec::Vec<T, A>
where A: Allocator,

Source§

impl<T, L> Extend<(T, L)> for Targets
where T: Into<String>, L: Into<LevelFilter>,

1.0.0 · Source§

impl<T, S> Extend<T> for rocket::mtls::x509::der_parser::asn1_rs::nom::lib::std::collections::HashSet<T, S>
where T: Eq + Hash, S: BuildHasher,

Source§

impl<T, S> Extend<T> for IndexSet<T, S>
where T: Hash + Eq, S: BuildHasher,

Source§

impl<T, S, A> Extend<T> for hashbrown::set::HashSet<T, S, A>
where T: Eq + Hash, S: BuildHasher, A: Allocator,

Source§

impl<V> Extend<V> for Array
where V: Into<Value>,