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 · Sourcefn extend<T>(&mut self, iter: T)where
T: IntoIterator<Item = A>,
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§
Sourcefn extend_one(&mut self, item: A)
🔬This is a nightly-only experimental API. (extend_one
)
fn extend_one(&mut self, item: A)
extend_one
)Extends a collection with exactly one element.
Sourcefn extend_reserve(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (extend_one
)
fn extend_reserve(&mut self, additional: usize)
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§
impl Extend<(String, Value)> for geng::prelude::serde_json::Map<String, Value>
impl Extend<(String, Value)> for geng::prelude::toml::map::Map<String, Value>
impl Extend<AsciiChar> for String
impl Extend<char> for String
impl Extend<u8> for Bytes
impl Extend<u8> for bytes::bytes::BytesMut
impl Extend<u8> for bytes::bytes_mut::BytesMut
impl Extend<()> for ()
impl Extend<Extensions> for Extensions
impl Extend<String> for String
impl Extend<OsString> for OsString
impl Extend<Flags> for alsa::poll::Flags
impl Extend<PortCap> for PortCap
impl Extend<PortType> for PortType
impl Extend<Remove> for Remove
impl Extend<Bytes> for bytes::bytes_mut::BytesMut
impl Extend<Api> for Api
impl Extend<ConfigSurfaceTypes> for ConfigSurfaceTypes
impl Extend<DisplayFeatures> for DisplayFeatures
impl Extend<EventMask> for inotify::events::EventMask
impl Extend<EventMask> for inotify::events::EventMask
impl Extend<WatchMask> for inotify::watches::WatchMask
impl Extend<WatchMask> for inotify::watches::WatchMask
impl Extend<EpollCreateFlags> for EpollCreateFlags
impl Extend<EpollFlags> for EpollFlags
impl Extend<EfdFlags> for EfdFlags
impl Extend<Transformations> for Transformations
impl Extend<CreateFlags> for rustix::backend::event::epoll::CreateFlags
impl Extend<CreateFlags> for rustix::backend::event::epoll::CreateFlags
impl Extend<EventFlags> for rustix::backend::event::epoll::EventFlags
impl Extend<EventFlags> for rustix::backend::event::epoll::EventFlags
impl Extend<PollFlags> for rustix::backend::event::poll_fd::PollFlags
impl Extend<PollFlags> for rustix::backend::event::poll_fd::PollFlags
impl Extend<EventfdFlags> for rustix::backend::event::types::EventfdFlags
impl Extend<EventfdFlags> for rustix::backend::event::types::EventfdFlags
impl Extend<CreateFlags> for rustix::backend::fs::inotify::CreateFlags
impl Extend<CreateFlags> for rustix::backend::fs::inotify::CreateFlags
impl Extend<ReadFlags> for rustix::backend::fs::inotify::ReadFlags
impl Extend<ReadFlags> for rustix::backend::fs::inotify::ReadFlags
impl Extend<WatchFlags> for rustix::backend::fs::inotify::WatchFlags
impl Extend<WatchFlags> for rustix::backend::fs::inotify::WatchFlags
impl Extend<Access> for rustix::backend::fs::types::Access
impl Extend<Access> for rustix::backend::fs::types::Access
impl Extend<AtFlags> for rustix::backend::fs::types::AtFlags
impl Extend<AtFlags> for rustix::backend::fs::types::AtFlags
impl Extend<FallocateFlags> for rustix::backend::fs::types::FallocateFlags
impl Extend<FallocateFlags> for rustix::backend::fs::types::FallocateFlags
impl Extend<MemfdFlags> for rustix::backend::fs::types::MemfdFlags
impl Extend<MemfdFlags> for rustix::backend::fs::types::MemfdFlags
impl Extend<Mode> for rustix::backend::fs::types::Mode
impl Extend<Mode> for rustix::backend::fs::types::Mode
impl Extend<OFlags> for rustix::backend::fs::types::OFlags
impl Extend<OFlags> for rustix::backend::fs::types::OFlags
impl Extend<RenameFlags> for rustix::backend::fs::types::RenameFlags
impl Extend<RenameFlags> for rustix::backend::fs::types::RenameFlags
impl Extend<ResolveFlags> for rustix::backend::fs::types::ResolveFlags
impl Extend<ResolveFlags> for rustix::backend::fs::types::ResolveFlags
impl Extend<SealFlags> for rustix::backend::fs::types::SealFlags
impl Extend<SealFlags> for rustix::backend::fs::types::SealFlags
impl Extend<StatVfsMountFlags> for rustix::backend::fs::types::StatVfsMountFlags
impl Extend<StatVfsMountFlags> for rustix::backend::fs::types::StatVfsMountFlags
impl Extend<StatxFlags> for rustix::backend::fs::types::StatxFlags
impl Extend<DupFlags> for rustix::backend::io::types::DupFlags
impl Extend<DupFlags> for rustix::backend::io::types::DupFlags
impl Extend<FdFlags> for rustix::backend::io::types::FdFlags
impl Extend<FdFlags> for rustix::backend::io::types::FdFlags
impl Extend<ReadWriteFlags> for rustix::backend::io::types::ReadWriteFlags
impl Extend<ReadWriteFlags> for rustix::backend::io::types::ReadWriteFlags
impl Extend<MountFlags> for MountFlags
impl Extend<MountPropagationFlags> for MountPropagationFlags
impl Extend<UnmountFlags> for UnmountFlags
impl Extend<RecvFlags> for rustix::backend::net::send_recv::RecvFlags
impl Extend<RecvFlags> for rustix::backend::net::send_recv::RecvFlags
impl Extend<ReturnFlags> for ReturnFlags
impl Extend<SendFlags> for rustix::backend::net::send_recv::SendFlags
impl Extend<SendFlags> for rustix::backend::net::send_recv::SendFlags
impl Extend<PipeFlags> for rustix::backend::pipe::types::PipeFlags
impl Extend<PipeFlags> for rustix::backend::pipe::types::PipeFlags
impl Extend<SpliceFlags> for rustix::backend::pipe::types::SpliceFlags
impl Extend<SpliceFlags> for rustix::backend::pipe::types::SpliceFlags
impl Extend<ShmOFlags> for ShmOFlags
impl Extend<Flags> for rustix::backend::thread::futex::Flags
impl Extend<TimerfdFlags> for TimerfdFlags
impl Extend<TimerfdTimerFlags> for TimerfdTimerFlags
impl Extend<IFlags> for rustix::fs::ioctl::IFlags
impl Extend<IFlags> for rustix::fs::ioctl::IFlags
impl Extend<StatxAttributes> for StatxAttributes
impl Extend<StatxFlags> for rustix::fs::statx::StatxFlags
impl Extend<XattrFlags> for rustix::fs::xattr::XattrFlags
impl Extend<XattrFlags> for rustix::fs::xattr::XattrFlags
impl Extend<SocketFlags> for rustix::net::types::SocketFlags
impl Extend<SocketFlags> for rustix::net::types::SocketFlags
impl Extend<SockaddrXdpFlags> for SockaddrXdpFlags
impl Extend<SocketAddrXdpFlags> for SocketAddrXdpFlags
impl Extend<XdpDescOptions> for rustix::net::types::xdp::XdpDescOptions
impl Extend<XdpDescOptions> for rustix::net::types::xdp::XdpDescOptions
impl Extend<XdpOptionsFlags> for rustix::net::types::xdp::XdpOptionsFlags
impl Extend<XdpOptionsFlags> for rustix::net::types::xdp::XdpOptionsFlags
impl Extend<XdpRingFlags> for rustix::net::types::xdp::XdpRingFlags
impl Extend<XdpRingFlags> for rustix::net::types::xdp::XdpRingFlags
impl Extend<XdpUmemRegFlags> for rustix::net::types::xdp::XdpUmemRegFlags
impl Extend<XdpUmemRegFlags> for rustix::net::types::xdp::XdpUmemRegFlags
impl Extend<MembarrierQuery> for MembarrierQuery
impl Extend<PidfdFlags> for rustix::process::pidfd::PidfdFlags
impl Extend<PidfdFlags> for rustix::process::pidfd::PidfdFlags
impl Extend<PidfdGetfdFlags> for rustix::process::pidfd_getfd::PidfdGetfdFlags
impl Extend<PidfdGetfdFlags> for rustix::process::pidfd_getfd::PidfdGetfdFlags
impl Extend<FloatingPointEmulationControl> for rustix::process::prctl::FloatingPointEmulationControl
impl Extend<FloatingPointEmulationControl> for rustix::process::prctl::FloatingPointEmulationControl
impl Extend<FloatingPointExceptionMode> for rustix::process::prctl::FloatingPointExceptionMode
impl Extend<FloatingPointExceptionMode> for rustix::process::prctl::FloatingPointExceptionMode
impl Extend<SpeculationFeatureControl> for rustix::process::prctl::SpeculationFeatureControl
impl Extend<SpeculationFeatureControl> for rustix::process::prctl::SpeculationFeatureControl
impl Extend<SpeculationFeatureState> for rustix::process::prctl::SpeculationFeatureState
impl Extend<SpeculationFeatureState> for rustix::process::prctl::SpeculationFeatureState
impl Extend<UnalignedAccessControl> for rustix::process::prctl::UnalignedAccessControl
impl Extend<UnalignedAccessControl> for rustix::process::prctl::UnalignedAccessControl
impl Extend<WaitIdOptions> for WaitIdOptions
impl Extend<WaitOptions> for rustix::process::wait::WaitOptions
impl Extend<WaitOptions> for rustix::process::wait::WaitOptions
impl Extend<WaitidOptions> for WaitidOptions
impl Extend<CapabilityFlags> for CapabilityFlags
impl Extend<CapabilitiesSecureBits> for CapabilitiesSecureBits
impl Extend<TaggedAddressMode> for TaggedAddressMode
impl Extend<ThreadNameSpaceType> for ThreadNameSpaceType
impl Extend<Anchor> for smithay_client_toolkit::shell::wlr_layer::Anchor
impl Extend<Channels> for Channels
impl Extend<Table> for ArrayOfTables
impl Extend<DndAction> for DndAction
impl Extend<Mode> for wayland_client::protocol::wl_output::Mode
impl Extend<Capability> for wayland_client::protocol::wl_seat::Capability
impl Extend<Resize> for Resize
impl Extend<Transient> for Transient
impl Extend<WindowManagerCapabilities> for WindowManagerCapabilities
impl Extend<WindowState> for WindowState
impl Extend<Capability> for wayland_protocols_plasma::output_device::v1::generated::client::org_kde_kwin_outputdevice::Capability
impl Extend<Capability> for wayland_protocols_plasma::output_device::v2::generated::client::kde_output_device_v2::Capability
impl Extend<ContentHint> for wayland_protocols_plasma::text_input::v2::generated::client::zwp_text_input_v2::ContentHint
impl Extend<Anchor> for wayland_protocols_wlr::layer_shell::v1::generated::client::zwlr_layer_surface_v1::Anchor
impl Extend<Flags> for wayland_protocols_wlr::screencopy::v1::generated::client::zwlr_screencopy_frame_v1::Flags
impl Extend<Flags> for wayland_protocols::wp::linux_dmabuf::zv1::generated::client::zwp_linux_buffer_params_v1::Flags
impl Extend<TrancheFlags> for TrancheFlags
impl Extend<Kind> for Kind
impl Extend<ContentHint> for wayland_protocols::wp::text_input::zv1::generated::client::zwp_text_input_v1::ContentHint
impl Extend<ContentHint> for wayland_protocols::wp::text_input::zv3::generated::client::zwp_text_input_v3::ContentHint
impl Extend<ConstraintAdjustment> for ConstraintAdjustment
impl Extend<ModifiersState> for ModifiersState
impl Extend<WindowButtons> for WindowButtons
impl Extend<xkb_state_component> for xkb_state_component
impl<'a> Extend<&'a AsciiChar> for String
impl<'a> Extend<&'a char> for String
impl<'a> Extend<&'a str> for String
impl<'a> Extend<&'a u8> for Bytes
impl<'a> Extend<&'a u8> for bytes::bytes::BytesMut
impl<'a> Extend<&'a u8> for bytes::bytes_mut::BytesMut
impl<'a> Extend<&'a OsStr> for OsString
impl<'a> Extend<Cow<'a, str>> for String
impl<'a> Extend<Cow<'a, OsStr>> for OsString
impl<'a, K, V, A> Extend<(&'a K, &'a V)> for BTreeMap<K, V, A>
impl<'a, K, V, S> Extend<(&'a K, &'a V)> for geng::prelude::HashMap<K, V, S>
impl<'a, K, V, S> Extend<(&'a K, &'a V)> for AHashMap<K, V, S>
impl<'a, K, V, S> Extend<(&'a K, &'a V)> for IndexMap<K, V, S>
impl<'a, K, V, S, A> Extend<&'a (K, V)> for hashbrown::map::HashMap<K, V, S, A>
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 hashbrown::map::HashMap<K, V, S, A>
Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.
impl<'a, T, A> Extend<&'a T> for BinaryHeap<T, A>
impl<'a, T, A> Extend<&'a T> for BTreeSet<T, A>
impl<'a, T, A> Extend<&'a T> for LinkedList<T, A>
impl<'a, T, A> Extend<&'a T> for VecDeque<T, A>
impl<'a, T, A> Extend<&'a T> for Vec<T, 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.
impl<'a, T, S> Extend<&'a T> for geng::prelude::HashSet<T, S>
impl<'a, T, S> Extend<&'a T> for AHashSet<T, S>
impl<'a, T, S> Extend<&'a T> for IndexSet<T, S>
impl<'a, T, S, A> Extend<&'a T> for hashbrown::set::HashSet<T, S, A>
impl<'a, V> Extend<(usize, &'a V)> for VecMap<V>where
V: Copy,
impl<'s, T> Extend<T> for SliceVec<'s, T>
impl<'slice, 'fd> Extend<SendAncillaryMessage<'slice, 'fd>> for rustix::net::send_recv::msg::SendAncillaryBuffer<'_, 'slice, 'fd>
impl<'slice, 'fd> Extend<SendAncillaryMessage<'slice, 'fd>> for rustix::net::send_recv::msg::SendAncillaryBuffer<'_, 'slice, 'fd>
impl<A> Extend<<A as Array>::Item> for SmallVec<A>where
A: Array,
impl<A> Extend<<A as Array>::Item> for TinyVec<A>where
A: Array,
impl<A> Extend<<A as Array>::Item> for tinyvec::arrayvec::ArrayVec<A>where
A: Array,
impl<A> Extend<Box<str, A>> for Stringwhere
A: Allocator,
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 impl
s for 1- and 3- through 12-ary tuples were stabilized after 2-tuples, in 1.85.0.
impl<Fut> Extend<Fut> for FuturesOrdered<Fut>where
Fut: Future,
impl<Fut> Extend<Fut> for FuturesUnordered<Fut>
impl<K, V> Extend<(K, V)> for InlineTable
impl<K, V> Extend<(K, V)> for Table
impl<K, V, A> Extend<(K, V)> for BTreeMap<K, V, A>
impl<K, V, S> Extend<(K, V)> for geng::prelude::HashMap<K, V, S>
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 AHashMap<K, V, S>
impl<K, V, S> Extend<(K, V)> for IndexMap<K, V, S>
impl<K, V, S> Extend<(K, V)> for LiteMap<K, V, S>where
K: Ord,
S: StoreBulkMut<K, V>,
impl<K, V, S, A> Extend<(K, V)> for hashbrown::map::HashMap<K, V, S, A>
Inserts all new key-values from the iterator and replaces values with existing keys with new values returned from the iterator.
impl<L, R, A> Extend<A> for Either<L, R>
impl<P> Extend<P> for std::path::PathBuf
impl<P> Extend<P> for async_std::path::pathbuf::PathBuf
impl<St> Extend<St> for SelectAll<St>
impl<T> Extend<(Option<HeaderName>, T)> for HeaderMap<T>
impl<T> Extend<(HeaderName, T)> for HeaderMap<T>
impl<T> Extend<T> for Collection<T>where
T: HasId,
impl<T, A> Extend<T> for BinaryHeap<T, A>
impl<T, A> Extend<T> for BTreeSet<T, A>
impl<T, A> Extend<T> for LinkedList<T, A>where
A: Allocator,
impl<T, A> Extend<T> for VecDeque<T, A>where
A: Allocator,
impl<T, A> Extend<T> for Vec<T, A>where
A: Allocator,
impl<T, S> Extend<T> for geng::prelude::HashSet<T, S>
impl<T, S> Extend<T> for AHashSet<T, S>
impl<T, S> Extend<T> for IndexSet<T, S>
impl<T, S, A> Extend<T> for hashbrown::set::HashSet<T, S, A>
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.