pub struct CustomRouting<TKey, TMsg, THasher>{ /* private fields */ }Expand description
Factory will dispatch to workers based on a custom hash function.
The factory maintains no queue in this scenario, and jobs are pushed to worker’s queues.
Implementations§
Source§impl<TKey, TMsg, THasher> CustomRouting<TKey, TMsg, THasher>
impl<TKey, TMsg, THasher> CustomRouting<TKey, TMsg, THasher>
Sourcepub fn new(hasher: THasher) -> CustomRouting<TKey, TMsg, THasher>
pub fn new(hasher: THasher) -> CustomRouting<TKey, TMsg, THasher>
Construct a new CustomRouting instance with the supplied hash function
Trait Implementations§
Source§impl<TKey, TMsg, THasher> Debug for CustomRouting<TKey, TMsg, THasher>
impl<TKey, TMsg, THasher> Debug for CustomRouting<TKey, TMsg, THasher>
Source§impl<TKey, TMsg, THasher> Router<TKey, TMsg> for CustomRouting<TKey, TMsg, THasher>
impl<TKey, TMsg, THasher> Router<TKey, TMsg> for CustomRouting<TKey, TMsg, THasher>
Source§fn route_message(
&mut self,
job: Job<TKey, TMsg>,
pool_size: usize,
worker_hint: Option<usize>,
worker_pool: &mut HashMap<usize, WorkerProperties<TKey, TMsg>>,
) -> Result<RouteResult<TKey, TMsg>, Box<dyn Error + Send + Sync>>
fn route_message( &mut self, job: Job<TKey, TMsg>, pool_size: usize, worker_hint: Option<usize>, worker_pool: &mut HashMap<usize, WorkerProperties<TKey, TMsg>>, ) -> Result<RouteResult<TKey, TMsg>, Box<dyn Error + Send + Sync>>
Auto Trait Implementations§
impl<TKey, TMsg, THasher> Freeze for CustomRouting<TKey, TMsg, THasher>where
THasher: Freeze,
impl<TKey, TMsg, THasher> RefUnwindSafe for CustomRouting<TKey, TMsg, THasher>where
THasher: RefUnwindSafe,
impl<TKey, TMsg, THasher> Send for CustomRouting<TKey, TMsg, THasher>
impl<TKey, TMsg, THasher> Sync for CustomRouting<TKey, TMsg, THasher>
impl<TKey, TMsg, THasher> Unpin for CustomRouting<TKey, TMsg, THasher>where
THasher: Unpin,
impl<TKey, TMsg, THasher> UnsafeUnpin for CustomRouting<TKey, TMsg, THasher>where
THasher: UnsafeUnpin,
impl<TKey, TMsg, THasher> UnwindSafe for CustomRouting<TKey, TMsg, THasher>where
THasher: UnwindSafe,
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> 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> Message for T
impl<T> Message for T
Source§fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
Convert a BoxedMessage to this concrete type
Source§fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
Convert this message to a BoxedMessage