Skip to main content

AddressBook

Struct AddressBook 

Source
pub struct AddressBook<A: Address> { /* private fields */ }
Expand description

A bounded, deduplicated collection of addresses for a peer.

Backed by an LRU cache: all operations (insert, lookup, promote, evict) are O(1). Most recently seen addresses are promoted automatically. When capacity is exceeded, the least recently seen entry is evicted.

Implementations§

Source§

impl<A: Address> AddressBook<A>

Source

pub fn new(first_addr: A, max_size: usize) -> AddressBook<A>

Source

pub fn seen(&mut self, addr: A) -> bool

Record that we’ve seen this address. Returns true if it was newly added. If already present, promotes it to most recent. If at capacity, evicts the least recently seen entry.

Source

pub fn get(&self, index: usize) -> Option<&A>

Source

pub fn first(&self) -> &A

Returns the most recently seen address.

Source

pub fn iter(&self) -> impl Iterator<Item = &A>

Iterates from most recently seen to least recently seen.

Source

pub fn len(&self) -> usize

Source

pub fn max_size(&self) -> usize

Source

pub fn into_vec(self) -> Vec<A>

Consumes the page and returns addresses in MRU-first order.

Source

pub fn contains(&self, addr: &A) -> bool

Source

pub fn remove(&mut self, addr: &A) -> bool

Source

pub fn is_empty(&self) -> bool

Source

pub fn concat(&mut self, other: &AddressBook<A>) -> usize

Merge addresses from another page into this one. New addresses go in as least recent. Returns number added.

Trait Implementations§

Source§

impl<A: Address> Clone for AddressBook<A>

Source§

fn clone(&self) -> Self

Returns a duplicate 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<A: Address + Debug> Debug for AddressBook<A>

Source§

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

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

impl<A: Address> Display for AddressBook<A>

Source§

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

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

impl<A: Address> Hash for AddressBook<A>

Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<A: Address> PartialEq for AddressBook<A>

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<A: Address> Eq for AddressBook<A>

Auto Trait Implementations§

§

impl<A> Freeze for AddressBook<A>

§

impl<A> RefUnwindSafe for AddressBook<A>
where A: RefUnwindSafe,

§

impl<A> Send for AddressBook<A>
where A: Send,

§

impl<A> Sync for AddressBook<A>
where A: Sync,

§

impl<A> Unpin for AddressBook<A>

§

impl<A> UnsafeUnpin for AddressBook<A>

§

impl<A> UnwindSafe for AddressBook<A>
where A: RefUnwindSafe,

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
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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.