Struct ListByRelayIds

Source
pub struct ListByRelayIds<H: HasRelayIds>{ /* private fields */ }
Expand description

A list of objects that can be accessed by relay identity.

Multiple objects in the list can have a given relay identity.

§Invariants

Every object in the list must have at least one recognized relay identity; if it does not, it cannot be inserted.

This list may panic or give incorrect results if the values can change their keys through interior mutability.

§General information

A list of elements of type H whose members can be accessed by multiple keys.

The keys are:

  • rsa (RsaIdentity) (Option)
  • ed25519 (Ed25519Identity) (Option)

Each element has a value for each required key, and up to one value for each optional key. There can be many elements for a given key value.

§Requirements

Key types must have consistent Hash and Eq implementations, as they will be used as keys in a HashMap.

If all keys are optional, then every element inserted must have at least one non-None key.

An element must not change its keys over time through interior mutability.

If any of these rules is violated, the consequences are unspecified, and could include panics or wrong answers (but not memory-unsafety).

Implementations§

Source§

impl<H: HasRelayIds> ListByRelayIds<H>

Source

pub fn new() -> Self

Construct a new ListByRelayIds.

Source

pub fn with_capacity(n: usize) -> Self

Construct a new ListByRelayIds with a given capacity.

Source

pub fn by_rsa<BorrowAsKey_>( &self, key: &BorrowAsKey_, ) -> ListByRelayIdsIter<'_, H>
where RsaIdentity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Return an iterator of the elements whose rsa is key.

The iteration order is arbitrary.

Source

pub fn contains_rsa<BorrowAsKey_>(&mut self, key: &BorrowAsKey_) -> bool
where RsaIdentity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Return true if this list contains an element whose rsa is key.

Source

pub fn remove_by_rsa<BorrowAsKey_>( &mut self, key: &BorrowAsKey_, filter: impl FnMut(&H) -> bool, ) -> Vec<H>
where RsaIdentity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Remove and return the elements whose rsa is key and where filter returns true.

Source

pub fn by_ed25519<BorrowAsKey_>( &self, key: &BorrowAsKey_, ) -> ListByRelayIdsIter<'_, H>
where Ed25519Identity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Return an iterator of the elements whose ed25519 is key.

The iteration order is arbitrary.

Source

pub fn contains_ed25519<BorrowAsKey_>(&mut self, key: &BorrowAsKey_) -> bool
where Ed25519Identity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Return true if this list contains an element whose ed25519 is key.

Source

pub fn remove_by_ed25519<BorrowAsKey_>( &mut self, key: &BorrowAsKey_, filter: impl FnMut(&H) -> bool, ) -> Vec<H>
where Ed25519Identity: Borrow<BorrowAsKey_>, BorrowAsKey_: Hash + Eq + ?Sized,

Remove and return the elements whose ed25519 is key and where filter returns true.

Source

pub fn values(&self) -> impl Iterator<Item = &H> + '_

Return an iterator over the elements in this container.

Source

pub fn into_values(self) -> impl Iterator<Item = H>

Consume this container and return an iterator of its values.

Source

pub fn try_insert(&mut self, value: H) -> Result<(), Error>

Try to insert value.

Return Error::NoKeys if all the keys are optional, and value has no keys at all.

Source

pub fn insert(&mut self, value: H)

See try_insert. Panicks on errors.

Source

pub fn len(&self) -> usize

Return the number of elements in this container.

Source

pub fn is_empty(&self) -> bool

Return true if there are no elements in this container.

Source

pub fn capacity(&self) -> usize

Return the number of elements for which this container has allocated storage.

Source

pub fn retain<F>(&mut self, pred: F)
where F: FnMut(&H) -> bool,

Remove every element that does not satisfy the predicate pred.

Source

pub fn empty_iterator(&self) -> ListByRelayIdsIter<'_, H>

👎Deprecated

An empty iterator.

NOTE: This function is weird and will be removed in the future. We can fix this once we support a minimum rust version of 1.79.

Source§

impl<H: HasRelayIds> ListByRelayIds<H>

Source

pub fn by_id<'a, T>(&self, key: T) -> ListByRelayIdsIter<'_, H>
where T: Into<RelayIdRef<'a>>,

Return an iterator of the values in this list that have the key key.

Source

pub fn by_all_ids<'a>( &'a self, key: &'a impl HasRelayIds, ) -> impl Iterator<Item = &'a H> + 'a

Return the values in this list that have all the relay IDs that key does.

Returns an empty iterator if key has no relay IDs.

Source

pub fn all_overlapping<T>(&self, key: &T) -> Vec<&H>
where T: HasRelayIds,

Return a reference to every element in this set that shares any ID with key.

No element is returned more than once. Equality is compared using ByAddress.

Source

pub fn all_subset<T>(&self, key: &T) -> Vec<&H>
where T: HasRelayIds,

Return a reference to every element in this list whose relay IDs are a subset of the relay IDs that key has.

No element is returned more than once. Equality is compared using ByAddress.

Source

pub fn remove_by_id<'a, T>( &mut self, key: T, filter: impl FnMut(&H) -> bool, ) -> Vec<H>
where T: Into<RelayIdRef<'a>>,

Return the values in this list that have the key key and where filter returns true.

Source

pub fn remove_exact<T>(&mut self, key: &T) -> Vec<H>
where T: HasRelayIds,

Remove and return the values in this list that have exactly the same relay IDs that key does.

Source

pub fn remove_by_all_ids<T>(&mut self, key: &T) -> Vec<H>
where T: HasRelayIds,

Remove and return the values in this list that have all the same relay IDs that key does.

If key has no relay IDs, then no values are removed.

Trait Implementations§

Source§

impl<H: Clone + HasRelayIds> Clone for ListByRelayIds<H>

Source§

fn clone(&self) -> ListByRelayIds<H>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<H: Debug + HasRelayIds> Debug for ListByRelayIds<H>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<H: HasRelayIds> Default for ListByRelayIds<H>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<H: HasRelayIds> FromIterator<H> for ListByRelayIds<H>

Source§

fn from_iter<IntoIter_>(iter: IntoIter_) -> Self
where IntoIter_: IntoIterator<Item = H>,

Creates a value from an iterator. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T