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) { ... }
}
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 geng::prelude::serde_json::Map<String, Value>

Source§

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

Source§

impl Extend<AsciiChar> for String

1.0.0 · Source§

impl Extend<char> for String

Source§

impl Extend<u8> for Bytes

Source§

impl Extend<u8> for bytes::bytes::BytesMut

Source§

impl Extend<u8> for bytes::bytes_mut::BytesMut

1.28.0 · Source§

impl Extend<()> for ()

Source§

impl Extend<Extensions> for Extensions

1.4.0 · Source§

impl Extend<String> for String

1.52.0 · Source§

impl Extend<OsString> for OsString

Source§

impl Extend<Flags> for alsa::poll::Flags

Source§

impl Extend<PortCap> for PortCap

Source§

impl Extend<PortType> for PortType

Source§

impl Extend<Remove> for Remove

Source§

impl Extend<Bytes> for bytes::bytes_mut::BytesMut

Source§

impl Extend<Api> for Api

Source§

impl Extend<ConfigSurfaceTypes> for ConfigSurfaceTypes

Source§

impl Extend<DisplayFeatures> for DisplayFeatures

Source§

impl Extend<EventMask> for inotify::events::EventMask

Source§

impl Extend<EventMask> for inotify::events::EventMask

Source§

impl Extend<WatchMask> for inotify::watches::WatchMask

Source§

impl Extend<WatchMask> for inotify::watches::WatchMask

Source§

impl Extend<EpollCreateFlags> for EpollCreateFlags

Source§

impl Extend<EpollFlags> for EpollFlags

Source§

impl Extend<EfdFlags> for EfdFlags

Source§

impl Extend<Transformations> for Transformations

Source§

impl Extend<CreateFlags> for rustix::backend::event::epoll::CreateFlags

Source§

impl Extend<CreateFlags> for rustix::backend::event::epoll::CreateFlags

Source§

impl Extend<EventFlags> for rustix::backend::event::epoll::EventFlags

Source§

impl Extend<EventFlags> for rustix::backend::event::epoll::EventFlags

Source§

impl Extend<PollFlags> for rustix::backend::event::poll_fd::PollFlags

Source§

impl Extend<PollFlags> for rustix::backend::event::poll_fd::PollFlags

Source§

impl Extend<EventfdFlags> for rustix::backend::event::types::EventfdFlags

Source§

impl Extend<EventfdFlags> for rustix::backend::event::types::EventfdFlags

Source§

impl Extend<CreateFlags> for rustix::backend::fs::inotify::CreateFlags

Source§

impl Extend<CreateFlags> for rustix::backend::fs::inotify::CreateFlags

Source§

impl Extend<ReadFlags> for rustix::backend::fs::inotify::ReadFlags

Source§

impl Extend<ReadFlags> for rustix::backend::fs::inotify::ReadFlags

Source§

impl Extend<WatchFlags> for rustix::backend::fs::inotify::WatchFlags

Source§

impl Extend<WatchFlags> for rustix::backend::fs::inotify::WatchFlags

Source§

impl Extend<Access> for rustix::backend::fs::types::Access

Source§

impl Extend<Access> for rustix::backend::fs::types::Access

Source§

impl Extend<AtFlags> for rustix::backend::fs::types::AtFlags

Source§

impl Extend<AtFlags> for rustix::backend::fs::types::AtFlags

Source§

impl Extend<FallocateFlags> for rustix::backend::fs::types::FallocateFlags

Source§

impl Extend<FallocateFlags> for rustix::backend::fs::types::FallocateFlags

Source§

impl Extend<MemfdFlags> for rustix::backend::fs::types::MemfdFlags

Source§

impl Extend<MemfdFlags> for rustix::backend::fs::types::MemfdFlags

Source§

impl Extend<Mode> for rustix::backend::fs::types::Mode

Source§

impl Extend<Mode> for rustix::backend::fs::types::Mode

Source§

impl Extend<OFlags> for rustix::backend::fs::types::OFlags

Source§

impl Extend<OFlags> for rustix::backend::fs::types::OFlags

Source§

impl Extend<RenameFlags> for rustix::backend::fs::types::RenameFlags

Source§

impl Extend<RenameFlags> for rustix::backend::fs::types::RenameFlags

Source§

impl Extend<ResolveFlags> for rustix::backend::fs::types::ResolveFlags

Source§

impl Extend<ResolveFlags> for rustix::backend::fs::types::ResolveFlags

Source§

impl Extend<SealFlags> for rustix::backend::fs::types::SealFlags

Source§

impl Extend<SealFlags> for rustix::backend::fs::types::SealFlags

Source§

impl Extend<StatVfsMountFlags> for rustix::backend::fs::types::StatVfsMountFlags

Source§

impl Extend<StatVfsMountFlags> for rustix::backend::fs::types::StatVfsMountFlags

Source§

impl Extend<StatxFlags> for rustix::backend::fs::types::StatxFlags

Source§

impl Extend<DupFlags> for rustix::backend::io::types::DupFlags

Source§

impl Extend<DupFlags> for rustix::backend::io::types::DupFlags

Source§

impl Extend<FdFlags> for rustix::backend::io::types::FdFlags

Source§

impl Extend<FdFlags> for rustix::backend::io::types::FdFlags

Source§

impl Extend<ReadWriteFlags> for rustix::backend::io::types::ReadWriteFlags

Source§

impl Extend<ReadWriteFlags> for rustix::backend::io::types::ReadWriteFlags

Source§

impl Extend<MountFlags> for MountFlags

Source§

impl Extend<MountPropagationFlags> for MountPropagationFlags

Source§

impl Extend<UnmountFlags> for UnmountFlags

Source§

impl Extend<RecvFlags> for rustix::backend::net::send_recv::RecvFlags

Source§

impl Extend<RecvFlags> for rustix::backend::net::send_recv::RecvFlags

Source§

impl Extend<ReturnFlags> for ReturnFlags

Source§

impl Extend<SendFlags> for rustix::backend::net::send_recv::SendFlags

Source§

impl Extend<SendFlags> for rustix::backend::net::send_recv::SendFlags

Source§

impl Extend<PipeFlags> for rustix::backend::pipe::types::PipeFlags

Source§

impl Extend<PipeFlags> for rustix::backend::pipe::types::PipeFlags

Source§

impl Extend<SpliceFlags> for rustix::backend::pipe::types::SpliceFlags

Source§

impl Extend<SpliceFlags> for rustix::backend::pipe::types::SpliceFlags

Source§

impl Extend<ShmOFlags> for ShmOFlags

Source§

impl Extend<Flags> for rustix::backend::thread::futex::Flags

Source§

impl Extend<TimerfdFlags> for TimerfdFlags

Source§

impl Extend<TimerfdTimerFlags> for TimerfdTimerFlags

Source§

impl Extend<IFlags> for rustix::fs::ioctl::IFlags

Source§

impl Extend<IFlags> for rustix::fs::ioctl::IFlags

Source§

impl Extend<StatxAttributes> for StatxAttributes

Source§

impl Extend<StatxFlags> for rustix::fs::statx::StatxFlags

Source§

impl Extend<XattrFlags> for rustix::fs::xattr::XattrFlags

Source§

impl Extend<XattrFlags> for rustix::fs::xattr::XattrFlags

Source§

impl Extend<SocketFlags> for rustix::net::types::SocketFlags

Source§

impl Extend<SocketFlags> for rustix::net::types::SocketFlags

Source§

impl Extend<SockaddrXdpFlags> for SockaddrXdpFlags

Source§

impl Extend<SocketAddrXdpFlags> for SocketAddrXdpFlags

Source§

impl Extend<XdpDescOptions> for rustix::net::types::xdp::XdpDescOptions

Source§

impl Extend<XdpDescOptions> for rustix::net::types::xdp::XdpDescOptions

Source§

impl Extend<XdpOptionsFlags> for rustix::net::types::xdp::XdpOptionsFlags

Source§

impl Extend<XdpOptionsFlags> for rustix::net::types::xdp::XdpOptionsFlags

Source§

impl Extend<XdpRingFlags> for rustix::net::types::xdp::XdpRingFlags

Source§

impl Extend<XdpRingFlags> for rustix::net::types::xdp::XdpRingFlags

Source§

impl Extend<XdpUmemRegFlags> for rustix::net::types::xdp::XdpUmemRegFlags

Source§

impl Extend<XdpUmemRegFlags> for rustix::net::types::xdp::XdpUmemRegFlags

Source§

impl Extend<MembarrierQuery> for MembarrierQuery

Source§

impl Extend<PidfdFlags> for rustix::process::pidfd::PidfdFlags

Source§

impl Extend<PidfdFlags> for rustix::process::pidfd::PidfdFlags

Source§

impl Extend<PidfdGetfdFlags> for rustix::process::pidfd_getfd::PidfdGetfdFlags

Source§

impl Extend<PidfdGetfdFlags> for rustix::process::pidfd_getfd::PidfdGetfdFlags

Source§

impl Extend<FloatingPointEmulationControl> for rustix::process::prctl::FloatingPointEmulationControl

Source§

impl Extend<FloatingPointEmulationControl> for rustix::process::prctl::FloatingPointEmulationControl

Source§

impl Extend<FloatingPointExceptionMode> for rustix::process::prctl::FloatingPointExceptionMode

Source§

impl Extend<FloatingPointExceptionMode> for rustix::process::prctl::FloatingPointExceptionMode

Source§

impl Extend<SpeculationFeatureControl> for rustix::process::prctl::SpeculationFeatureControl

Source§

impl Extend<SpeculationFeatureControl> for rustix::process::prctl::SpeculationFeatureControl

Source§

impl Extend<SpeculationFeatureState> for rustix::process::prctl::SpeculationFeatureState

Source§

impl Extend<SpeculationFeatureState> for rustix::process::prctl::SpeculationFeatureState

Source§

impl Extend<UnalignedAccessControl> for rustix::process::prctl::UnalignedAccessControl

Source§

impl Extend<UnalignedAccessControl> for rustix::process::prctl::UnalignedAccessControl

Source§

impl Extend<WaitIdOptions> for WaitIdOptions

Source§

impl Extend<WaitOptions> for rustix::process::wait::WaitOptions

Source§

impl Extend<WaitOptions> for rustix::process::wait::WaitOptions

Source§

impl Extend<WaitidOptions> for WaitidOptions

Source§

impl Extend<CapabilityFlags> for CapabilityFlags

Source§

impl Extend<CapabilitiesSecureBits> for CapabilitiesSecureBits

Source§

impl Extend<TaggedAddressMode> for TaggedAddressMode

Source§

impl Extend<ThreadNameSpaceType> for ThreadNameSpaceType

Source§

impl Extend<UnshareFlags> for UnshareFlags

Source§

impl Extend<Anchor> for smithay_client_toolkit::shell::wlr_layer::Anchor

Source§

impl Extend<Channels> for Channels

Source§

impl Extend<Table> for ArrayOfTables

Source§

impl Extend<DndAction> for DndAction

Source§

impl Extend<Mode> for wayland_client::protocol::wl_output::Mode

Source§

impl Extend<Capability> for wayland_client::protocol::wl_seat::Capability

Source§

impl Extend<Resize> for Resize

Source§

impl Extend<Transient> for Transient

Source§

impl Extend<WindowManagerCapabilities> for WindowManagerCapabilities

Source§

impl Extend<WindowState> for WindowState

Source§

impl Extend<Capability> for wayland_protocols_plasma::output_device::v1::generated::client::org_kde_kwin_outputdevice::Capability

Source§

impl Extend<Capability> for wayland_protocols_plasma::output_device::v2::generated::client::kde_output_device_v2::Capability

Source§

impl Extend<ContentHint> for wayland_protocols_plasma::text_input::v2::generated::client::zwp_text_input_v2::ContentHint

Source§

impl Extend<Anchor> for wayland_protocols_wlr::layer_shell::v1::generated::client::zwlr_layer_surface_v1::Anchor

Source§

impl Extend<Flags> for wayland_protocols_wlr::screencopy::v1::generated::client::zwlr_screencopy_frame_v1::Flags

Source§

impl Extend<Flags> for wayland_protocols::wp::linux_dmabuf::zv1::generated::client::zwp_linux_buffer_params_v1::Flags

Source§

impl Extend<TrancheFlags> for TrancheFlags

Source§

impl Extend<Kind> for Kind

Source§

impl Extend<ContentHint> for wayland_protocols::wp::text_input::zv1::generated::client::zwp_text_input_v1::ContentHint

Source§

impl Extend<ContentHint> for wayland_protocols::wp::text_input::zv3::generated::client::zwp_text_input_v3::ContentHint

Source§

impl Extend<ConstraintAdjustment> for ConstraintAdjustment

Source§

impl Extend<ModifiersState> for ModifiersState

Source§

impl Extend<WindowButtons> for WindowButtons

Source§

impl Extend<xkb_state_component> for xkb_state_component

Source§

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

1.2.0 · Source§

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

1.0.0 · Source§

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

Source§

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

Source§

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

Source§

impl<'a> Extend<&'a u8> for bytes::bytes_mut::BytesMut

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 geng::prelude::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 AHashMap<K, V, S>
where K: Eq + Hash + Copy + 'a, V: Copy + 'a, 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.

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 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.4.0 · Source§

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

Source§

impl<'a, T, S> Extend<&'a T> for AHashSet<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<'a, V> Extend<(usize, &'a V)> for VecMap<V>
where V: Copy,

Source§

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

Source§

impl<'slice, 'fd> Extend<SendAncillaryMessage<'slice, 'fd>> for rustix::net::send_recv::msg::SendAncillaryBuffer<'_, 'slice, 'fd>

Source§

impl<'slice, 'fd> Extend<SendAncillaryMessage<'slice, 'fd>> for rustix::net::send_recv::msg::SendAncillaryBuffer<'_, 'slice, 'fd>

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 tinyvec::arrayvec::ArrayVec<A>
where A: Array,

1.45.0 · Source§

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

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.

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 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 geng::prelude::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 AHashMap<K, V, S>
where K: Eq + Hash, S: BuildHasher,

Source§

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

Source§

impl<K, V, S> Extend<(K, V)> for LiteMap<K, V, S>
where K: Ord, S: StoreBulkMut<K, V>,

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 std::path::PathBuf
where P: AsRef<Path>,

Source§

impl<P> Extend<P> for async_std::path::pathbuf::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<T> for Collection<T>
where T: HasId,

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

1.0.0 · Source§

impl<T, S> Extend<T> for geng::prelude::HashSet<T, S>
where T: Eq + Hash, S: BuildHasher,

Source§

impl<T, S> Extend<T> for AHashSet<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<T, const CAP: usize> Extend<T> for arrayvec::arrayvec::ArrayVec<T, CAP>

Extend the ArrayVec with an iterator.

Panics if extending the vector exceeds its capacity.

Source§

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

Source§

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