pub enum Entry<'a, T, A = Global>{
Occupied(OccupiedEntry<'a, T, A>),
Vacant(VacantEntry<'a, T, A>),
}🔬This is a nightly-only experimental API. (
btree_set_entry)Expand description
A view into a single entry in a set, which may either be vacant or occupied.
This enum is constructed from the entry method on BTreeSet.
§Examples
#![feature(btree_set_entry)]
use std::collections::btree_set::BTreeSet;
let mut set = BTreeSet::new();
set.extend(["a", "b", "c"]);
assert_eq!(set.len(), 3);
// Existing value (insert)
let entry = set.entry("a");
let _raw_o = entry.insert();
assert_eq!(set.len(), 3);
// Nonexistent value (insert)
set.entry("d").insert();
// Existing value (or_insert)
set.entry("b").or_insert();
// Nonexistent value (or_insert)
set.entry("e").or_insert();
println!("Our BTreeSet: {:?}", set);
assert!(set.iter().eq(&["a", "b", "c", "d", "e"]));Variants§
Occupied(OccupiedEntry<'a, T, A>)
🔬This is a nightly-only experimental API. (
btree_set_entry)An occupied entry.
§Examples
#![feature(btree_set_entry)]
use std::collections::btree_set::{Entry, BTreeSet};
let mut set = BTreeSet::from(["a", "b"]);
match set.entry("a") {
Entry::Vacant(_) => unreachable!(),
Entry::Occupied(_) => { }
}Vacant(VacantEntry<'a, T, A>)
🔬This is a nightly-only experimental API. (
btree_set_entry)A vacant entry.
§Examples
#![feature(btree_set_entry)]
use std::collections::btree_set::{Entry, BTreeSet};
let mut set = BTreeSet::new();
match set.entry("a") {
Entry::Occupied(_) => unreachable!(),
Entry::Vacant(_) => { }
}Implementations§
Source§impl<'a, T, A> Entry<'a, T, A>
impl<'a, T, A> Entry<'a, T, A>
Sourcepub fn insert(self) -> OccupiedEntry<'a, T, A>
🔬This is a nightly-only experimental API. (btree_set_entry)
pub fn insert(self) -> OccupiedEntry<'a, T, A>
btree_set_entry)Sets the value of the entry, and returns an OccupiedEntry.
§Examples
#![feature(btree_set_entry)]
use std::collections::BTreeSet;
let mut set = BTreeSet::new();
let entry = set.entry("horseyland").insert();
assert_eq!(entry.get(), &"horseyland");Sourcepub fn or_insert(self)
🔬This is a nightly-only experimental API. (btree_set_entry)
pub fn or_insert(self)
btree_set_entry)Ensures a value is in the entry by inserting if it was vacant.
§Examples
#![feature(btree_set_entry)]
use std::collections::BTreeSet;
let mut set = BTreeSet::new();
// nonexistent key
set.entry("poneyland").or_insert();
assert!(set.contains("poneyland"));
// existing key
set.entry("poneyland").or_insert();
assert!(set.contains("poneyland"));
assert_eq!(set.len(), 1);Sourcepub fn get(&self) -> &T
🔬This is a nightly-only experimental API. (btree_set_entry)
pub fn get(&self) -> &T
btree_set_entry)Returns a reference to this entry’s value.
§Examples
#![feature(btree_set_entry)]
use std::collections::BTreeSet;
let mut set = BTreeSet::new();
set.entry("poneyland").or_insert();
// existing key
assert_eq!(set.entry("poneyland").get(), &"poneyland");
// nonexistent key
assert_eq!(set.entry("horseland").get(), &"horseland");Trait Implementations§
Auto Trait Implementations§
impl<'a, T, A> Freeze for Entry<'a, T, A>
impl<'a, T, A> RefUnwindSafe for Entry<'a, T, A>where
A: RefUnwindSafe,
T: RefUnwindSafe,
impl<'a, T, A> Send for Entry<'a, T, A>
impl<'a, T, A> Sync for Entry<'a, T, A>
impl<'a, T, A> Unpin for Entry<'a, T, A>
impl<'a, T, A = Global> !UnwindSafe for Entry<'a, T, A>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T, U> ContextualTryInto<U> for Twhere
U: ContextualTryFrom<T>,
impl<T, U> ContextualTryInto<U> for Twhere
U: ContextualTryFrom<T>,
type Error = <U as ContextualTryFrom<T>>::Error
type Context = <U as ContextualTryFrom<T>>::Context
fn contextual_try_into( self, context: &<U as ContextualTryFrom<T>>::Context, ) -> Result<U, <U as ContextualTryFrom<T>>::Error>
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
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.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
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.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
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> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more