pub struct AdjacencyEntry {
pub edges: SmallVec<[AdjacencyEdge; 4]>,
}Expand description
Sorted adjacency list for one node.
Fields§
§edges: SmallVec<[AdjacencyEdge; 4]>Edges sorted by (label, neighbor, edge_id).
Implementations§
Source§impl AdjacencyEntry
impl AdjacencyEntry
Sourcepub fn iter(&self) -> impl Iterator<Item = &AdjacencyEdge>
pub fn iter(&self) -> impl Iterator<Item = &AdjacencyEdge>
Iterate adjacent edges in sorted order.
Sourcepub fn iter_label<'a>(
&'a self,
label: &DbString,
) -> impl Iterator<Item = &'a AdjacencyEdge>
pub fn iter_label<'a>( &'a self, label: &DbString, ) -> impl Iterator<Item = &'a AdjacencyEdge>
Iterate adjacent edges with exactly label.
Entries are sorted by (label, neighbor, edge_id), so this uses a
bounded label range rather than scanning unrelated edge labels.
Sourcepub fn add(&mut self, edge: AdjacencyEdge)
pub fn add(&mut self, edge: AdjacencyEdge)
Insert edge while maintaining sorted order.
Sourcepub fn remove(&mut self, edge_id: EdgeId) -> Option<AdjacencyEdge>
pub fn remove(&mut self, edge_id: EdgeId) -> Option<AdjacencyEdge>
Remove the edge with edge_id, returning it when present.
Trait Implementations§
Source§impl Clone for AdjacencyEntry
impl Clone for AdjacencyEntry
Source§fn clone(&self) -> AdjacencyEntry
fn clone(&self) -> AdjacencyEntry
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for AdjacencyEntry
impl Debug for AdjacencyEntry
Source§impl Default for AdjacencyEntry
impl Default for AdjacencyEntry
impl Eq for AdjacencyEntry
Source§impl Hash for AdjacencyEntry
impl Hash for AdjacencyEntry
Source§impl PartialEq for AdjacencyEntry
impl PartialEq for AdjacencyEntry
Source§fn eq(&self, other: &AdjacencyEntry) -> bool
fn eq(&self, other: &AdjacencyEntry) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for AdjacencyEntry
Auto Trait Implementations§
impl Freeze for AdjacencyEntry
impl RefUnwindSafe for AdjacencyEntry
impl Send for AdjacencyEntry
impl Sync for AdjacencyEntry
impl Unpin for AdjacencyEntry
impl UnsafeUnpin for AdjacencyEntry
impl UnwindSafe for AdjacencyEntry
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.