Skip to main content

MsgIndex

Struct MsgIndex 

Source
pub struct MsgIndex { /* private fields */ }
Expand description

Owning index of Msg values keyed on MsgId.

The C engine stores struct msg * pointers; the Rust port owns the value directly so dropping the index releases every contained message. Lookups return references; transferring ownership out of the index requires MsgIndex::remove.

§Thread safety

MsgIndex mirrors the reference engine’s outstanding_msgs_dict, which is per-connection and accessed only from the connection’s owning event-loop thread. The Rust port preserves that single-threaded contract: MsgIndex is Send (it can be moved to another task or thread, e.g. when a connection migrates) but is intentionally not exposed through any synchronisation primitive. The wrapped std::collections::HashMap inside DictMap is not Sync, so two tasks cannot share a &MsgIndex and call its mutating methods concurrently. Stages 9 and beyond keep the index private to the per-connection FSM; if a future caller ever needs cross-thread shared access, that caller is responsible for wrapping it in a Mutex (or equivalent), not the type itself.

Implementations§

Source§

impl MsgIndex

Source

pub fn new() -> Self

Build an empty index.

§Examples
use dynomite::msg::MsgIndex;
let idx = MsgIndex::new();
assert!(idx.is_empty());
Source

pub fn insert(&mut self, msg: Msg) -> Option<Msg>

Insert msg under its own id. The previous value, if any, is returned to the caller.

§Examples
use dynomite::msg::{Msg, MsgIndex, MsgType};

let mut idx = MsgIndex::new();
let m = Msg::new(7, MsgType::ReqRedisGet, true);
assert!(idx.insert(m).is_none());
assert!(idx.contains_key(7));
Source

pub fn remove(&mut self, id: MsgId) -> Option<Msg>

Remove the message stored under id and transfer ownership to the caller.

§Examples
use dynomite::msg::{Msg, MsgIndex, MsgType};

let mut idx = MsgIndex::new();
idx.insert(Msg::new(7, MsgType::ReqRedisGet, true));
assert!(idx.remove(7).is_some());
assert!(idx.remove(7).is_none());
Source

pub fn get(&self, id: MsgId) -> Option<&Msg>

Borrow the message stored under id, if any.

§Examples
use dynomite::msg::{Msg, MsgIndex, MsgType};

let mut idx = MsgIndex::new();
idx.insert(Msg::new(7, MsgType::ReqRedisGet, true));
assert_eq!(idx.get(7).unwrap().id(), 7);
Source

pub fn get_mut(&mut self, id: MsgId) -> Option<&mut Msg>

Mutably borrow the message stored under id.

§Examples
use dynomite::msg::{Msg, MsgIndex, MsgType};

let mut idx = MsgIndex::new();
idx.insert(Msg::new(7, MsgType::ReqRedisGet, true));
idx.get_mut(7).unwrap().set_done(true);
Source

pub fn contains_key(&self, id: MsgId) -> bool

True when an entry exists for id.

§Examples
use dynomite::msg::MsgIndex;
assert!(!MsgIndex::new().contains_key(0));
Source

pub fn len(&self) -> usize

Number of indexed messages.

§Examples
use dynomite::msg::MsgIndex;
assert_eq!(MsgIndex::new().len(), 0);
Source

pub fn is_empty(&self) -> bool

True when the index has no entries.

§Examples
use dynomite::msg::MsgIndex;
assert!(MsgIndex::new().is_empty());

Trait Implementations§

Source§

impl Debug for MsgIndex

Source§

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

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

impl Default for MsgIndex

Source§

fn default() -> Self

Returns the “default value” for a type. 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
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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FutureExt for T

Source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
Source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
Source§

impl<T> Instrument for T

Source§

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

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

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> Same for T

Source§

type Output = T

Should always be Self
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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,