Trait IteratorExtend

1.0.0 ยท Source
pub trait IteratorExtend<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) { ... }
}
Expand description

๐Ÿ”„ core Extend a collection with the contents of an iterator.

Re-exported from core::iter:: Extendโ†’IteratorExtend.


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<AsciiChar> for devela::all::String

1.0.0 ยท Sourceยง

impl Extend<char> for devela::all::String

ยง

impl Extend<u8> for BytesMut

1.28.0 ยท Sourceยง

impl Extend<()> for ()

ยง

impl Extend<KeyEventState> for KeyEventState

ยง

impl Extend<KeyModifiers> for KeyModifiers

ยง

impl Extend<KeyboardEnhancementFlags> for KeyboardEnhancementFlags

ยง

impl Extend<FileAccess> for FileAccess

ยง

impl Extend<Root> for Root

ยง

impl Extend<FileChooserType> for FileChooserType

ยง

impl Extend<FileDialogOptions> for FileDialogOptions

ยง

impl Extend<LineStyle> for LineStyle

ยง

impl Extend<Align> for Align

ยง

impl Extend<CallbackTrigger> for CallbackTrigger

ยง

impl Extend<Damage> for Damage

ยง

impl Extend<Mode> for devela::_dep::fltk::enums::Mode

ยง

impl Extend<Shortcut> for Shortcut

ยง

impl Extend<GridAlign> for GridAlign

ยง

impl Extend<AnimGifImageFlags> for AnimGifImageFlags

ยง

impl Extend<MenuFlag> for MenuFlag

ยง

impl Extend<Attrib> for Attrib

ยง

impl Extend<CharFlags> for CharFlags

ยง

impl Extend<OutFlags> for OutFlags

ยง

impl Extend<CreateFlags> for devela::_dep::rustix::event::epoll::CreateFlags

ยง

impl Extend<EventfdFlags> for EventfdFlags

ยง

impl Extend<PollFlags> for PollFlags

ยง

impl Extend<CreateFlags> for devela::_dep::rustix::fs::inotify::CreateFlags

ยง

impl Extend<ReadFlags> for ReadFlags

ยง

impl Extend<WatchFlags> for WatchFlags

ยง

impl Extend<Access> for Access

ยง

impl Extend<AtFlags> for AtFlags

ยง

impl Extend<FallocateFlags> for FallocateFlags

ยง

impl Extend<FdFlags> for FdFlags

ยง

impl Extend<IFlags> for IFlags

ยง

impl Extend<MemfdFlags> for MemfdFlags

ยง

impl Extend<Mode> for devela::_dep::rustix::fs::Mode

ยง

impl Extend<MountFlags> for MountFlags

ยง

impl Extend<MountPropagationFlags> for MountPropagationFlags

ยง

impl Extend<OFlags> for OFlags

ยง

impl Extend<RenameFlags> for RenameFlags

ยง

impl Extend<ResolveFlags> for ResolveFlags

ยง

impl Extend<SealFlags> for SealFlags

ยง

impl Extend<StatVfsMountFlags> for StatVfsMountFlags

ยง

impl Extend<StatxFlags> for StatxFlags

ยง

impl Extend<UnmountFlags> for UnmountFlags

ยง

impl Extend<XattrFlags> for XattrFlags

ยง

impl Extend<DupFlags> for DupFlags

ยง

impl Extend<ReadWriteFlags> for ReadWriteFlags

ยง

impl Extend<EventFlags> for EventFlags

ยง

impl Extend<IoringAcceptFlags> for IoringAcceptFlags

ยง

impl Extend<IoringAsyncCancelFlags> for IoringAsyncCancelFlags

ยง

impl Extend<IoringCqFlags> for IoringCqFlags

ยง

impl Extend<IoringCqeFlags> for IoringCqeFlags

ยง

impl Extend<IoringEnterFlags> for IoringEnterFlags

ยง

impl Extend<IoringFeatureFlags> for IoringFeatureFlags

ยง

impl Extend<IoringFsyncFlags> for IoringFsyncFlags

ยง

impl Extend<IoringMsgringFlags> for IoringMsgringFlags

ยง

impl Extend<IoringOpFlags> for IoringOpFlags

ยง

impl Extend<IoringPollFlags> for IoringPollFlags

ยง

impl Extend<IoringRecvFlags> for IoringRecvFlags

ยง

impl Extend<IoringRegisterFlags> for IoringRegisterFlags

ยง

impl Extend<IoringRsrcFlags> for IoringRsrcFlags

ยง

impl Extend<IoringSendFlags> for IoringSendFlags

ยง

impl Extend<IoringSetupFlags> for IoringSetupFlags

ยง

impl Extend<IoringSqFlags> for IoringSqFlags

ยง

impl Extend<IoringSqeFlags> for IoringSqeFlags

ยง

impl Extend<IoringTimeoutFlags> for IoringTimeoutFlags

ยง

impl Extend<RecvFlags> for RecvFlags

ยง

impl Extend<RecvmsgOutFlags> for RecvmsgOutFlags

ยง

impl Extend<SendFlags> for SendFlags

ยง

impl Extend<SocketFlags> for SocketFlags

ยง

impl Extend<SpliceFlags> for devela::_dep::rustix::io_uring::SpliceFlags

ยง

impl Extend<MapFlags> for MapFlags

ยง

impl Extend<MlockAllFlags> for MlockAllFlags

ยง

impl Extend<MlockFlags> for MlockFlags

ยง

impl Extend<MprotectFlags> for MprotectFlags

ยง

impl Extend<MremapFlags> for MremapFlags

ยง

impl Extend<MsyncFlags> for MsyncFlags

ยง

impl Extend<ProtFlags> for ProtFlags

ยง

impl Extend<UserfaultfdFlags> for UserfaultfdFlags

ยง

impl Extend<FsMountFlags> for FsMountFlags

ยง

impl Extend<FsOpenFlags> for FsOpenFlags

ยง

impl Extend<FsPickFlags> for FsPickFlags

ยง

impl Extend<MountAttrFlags> for MountAttrFlags

ยง

impl Extend<MoveMountFlags> for MoveMountFlags

ยง

impl Extend<OpenTreeFlags> for OpenTreeFlags

ยง

impl Extend<SockaddrXdpFlags> for SockaddrXdpFlags

ยง

impl Extend<XdpDescOptions> for XdpDescOptions

ยง

impl Extend<XdpOptionsFlags> for XdpOptionsFlags

ยง

impl Extend<XdpRingFlags> for XdpRingFlags

ยง

impl Extend<XdpUmemRegFlags> for XdpUmemRegFlags

ยง

impl Extend<PipeFlags> for PipeFlags

ยง

impl Extend<SpliceFlags> for devela::_dep::rustix::pipe::SpliceFlags

ยง

impl Extend<FloatingPointEmulationControl> for FloatingPointEmulationControl

ยง

impl Extend<FloatingPointExceptionMode> for FloatingPointExceptionMode

ยง

impl Extend<MembarrierQuery> for MembarrierQuery

ยง

impl Extend<PidfdFlags> for PidfdFlags

ยง

impl Extend<PidfdGetfdFlags> for PidfdGetfdFlags

ยง

impl Extend<SpeculationFeatureControl> for SpeculationFeatureControl

ยง

impl Extend<SpeculationFeatureState> for SpeculationFeatureState

ยง

impl Extend<UnalignedAccessControl> for UnalignedAccessControl

ยง

impl Extend<WaitOptions> for WaitOptions

ยง

impl Extend<WaitidOptions> for WaitidOptions

ยง

impl Extend<OpenptFlags> for OpenptFlags

ยง

impl Extend<GetRandomFlags> for GetRandomFlags

ยง

impl Extend<ShmOFlags> for ShmOFlags

ยง

impl Extend<ControlModes> for ControlModes

ยง

impl Extend<InputModes> for InputModes

ยง

impl Extend<LocalModes> for LocalModes

ยง

impl Extend<OutputModes> for OutputModes

ยง

impl Extend<CapabilitiesSecureBits> for CapabilitiesSecureBits

ยง

impl Extend<CapabilityFlags> for CapabilityFlags

ยง

impl Extend<Flags> for devela::_dep::rustix::thread::FutexFlags

ยง

impl Extend<TaggedAddressMode> for TaggedAddressMode

ยง

impl Extend<ThreadNameSpaceType> for ThreadNameSpaceType

ยง

impl Extend<UnshareFlags> for UnshareFlags

ยง

impl Extend<TimerfdFlags> for TimerfdFlags

ยง

impl Extend<TimerfdTimerFlags> for TimerfdTimerFlags

ยง

impl Extend<InitFlag> for devela::_dep::sdl2::image::InitFlag

ยง

impl Extend<Mod> for devela::_dep::sdl2::keyboard::Mod

ยง

impl Extend<MessageBoxButtonFlag> for devela::_dep::sdl2::messagebox::MessageBoxButtonFlag

ยง

impl Extend<MessageBoxFlag> for devela::_dep::sdl2::messagebox::MessageBoxFlag

ยง

impl Extend<InitFlag> for devela::_dep::sdl2::mixer::InitFlag

ยง

impl Extend<FontStyle> for FontStyle

ยง

impl Extend<GlobFlags> for GlobFlags

ยง

impl Extend<Mod> for devela::_dep::sdl3::keyboard::Mod

ยง

impl Extend<MessageBoxButtonFlag> for devela::_dep::sdl3::messagebox::MessageBoxButtonFlag

ยง

impl Extend<MessageBoxFlag> for devela::_dep::sdl3::messagebox::MessageBoxFlag

ยง

impl Extend<Channels> for Channels

ยง

impl Extend<Table> for ArrayOfTables

1.52.0 ยท Sourceยง

impl Extend<OsString> for OsString

1.4.0 ยท Sourceยง

impl Extend<String> for devela::all::String

ยง

impl Extend<Bytes> for BytesMut

ยง

impl Extend<EfdFlags> for EfdFlags

ยง

impl Extend<EpollCreateFlags> for EpollCreateFlags

ยง

impl Extend<EpollFlags> for EpollFlags

ยง

impl Extend<EventMask> for EventMask

ยง

impl Extend<Flags> for Flags

ยง

impl Extend<PortCap> for PortCap

ยง

impl Extend<PortType> for PortType

ยง

impl Extend<Remove> for Remove

ยง

impl Extend<Transformations> for Transformations

ยง

impl Extend<WatchMask> for WatchMask

Sourceยง

impl<'a> Extend<&'a AsciiChar> for devela::all::String

1.2.0 ยท Sourceยง

impl<'a> Extend<&'a char> for devela::all::String

1.0.0 ยท Sourceยง

impl<'a> Extend<&'a str> for devela::all::String

ยง

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

1.52.0 ยท Sourceยง

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

1.19.0 ยท Sourceยง

impl<'a> Extend<Cow<'a, str>> for devela::all::String

1.52.0 ยท Sourceยง

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

ยง

impl<'a, 'bump> Extend<&'a char> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'a, 'bump> Extend<&'a str> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'a, 'bump> Extend<Cow<'a, str>> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'a, 'bump, T> Extend<&'a T> for devela::_dep::bumpalo::collections::Vec<'bump, T>
where T: 'a + Copy,

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.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 devela::_dep::_std::collections::HashMap<K, V, S>
where K: Eq + Hash + Copy, V: Copy, S: BuildHasher,

ยง

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

ยง

impl<'a, K, V, S, A> Extend<&'a (K, V)> for devela::all::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.

ยง

impl<'a, K, V, S, A> Extend<(&'a K, &'a V)> for devela::all::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.

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 BinaryHeap<T, A>
where T: 'a + Ord + Copy, A: Allocator,

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 devela::all::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.

1.2.0 ยท Sourceยง

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

1.4.0 ยท Sourceยง

impl<'a, T, S> Extend<&'a T> for devela::_dep::_std::collections::HashSet<T, S>
where T: 'a + Eq + Hash + Copy, S: BuildHasher,

ยง

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

ยง

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

ยง

impl<'a, V> Extend<(usize, &'a V)> for VecMap<V>
where V: Copy,

ยง

impl<'bump> Extend<char> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'bump> Extend<String<'bump>> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'bump> Extend<String> for devela::_dep::bumpalo::collections::String<'bump>

ยง

impl<'bump, T> Extend<T> for devela::_dep::bumpalo::collections::Vec<'bump, T>
where T: 'bump,

ยง

impl<'slice, 'fd> Extend<SendAncillaryMessage<'slice, 'fd>> for SendAncillaryBuffer<'_, 'slice, 'fd>

ยง

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

1.45.0 ยท Sourceยง

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

Sourceยง

impl<A> Extend<A> for devela::_dep::js_sys::Array
where A: AsRef<JsValue>,

1.56.0 ยท Sourceยง

impl<A, EA> Extend<(Aโ‚, Aโ‚‚, โ€ฆ, Aโ‚™)> for (EAโ‚, EAโ‚‚, โ€ฆ, EAโ‚™)
where EA: Extend<A>,

This trait is implemented for tuples up to twelve items long. The impls for 1- and 3- through 12-ary tuples were stabilized after 2-tuples, in 1.85.0.

ยง

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

ยง

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 devela::_dep::_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.

ยง

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

ยง

impl<K, V, S, A> Extend<(K, V)> for devela::all::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>,

ยง

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

ยง

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

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 BinaryHeap<T, A>
where T: Ord, A: Allocator,

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 devela::all::Vec<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, S> Extend<T> for devela::_dep::_std::collections::HashSet<T, S>
where T: Eq + Hash, S: BuildHasher,

ยง

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

ยง

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

Sourceยง

impl<T, const CAP: usize> Extend<T> for ArrayVec<T, CAP>

Extend the ArrayVec with an iterator.

Panics if extending the vector exceeds its capacity.

ยง

impl<V> Extend<(usize, V)> for VecMap<V>

ยง

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