pub struct ErasedHandler(/* private fields */);Expand description
Type-erased request handler.
Wraps a boxed closure that has already been monomorphized and type-erased.
Only one impl Handler exists for this type, regardless of how many
handlers are registered — eliminating the per-handler trait-resolution
pressure that causes E0275 at scale.
§Construction
For most users the generic convenience constructors (no_args, with_args,
with_state, with_state_only) are the easiest path. If you hit E0275
with hundreds of handlers, use the erase_handler! / erase_handler_with_args!
macros instead — they generate fully concrete (non-generic) boxing code.
Implementations§
Source§impl ErasedHandler
impl ErasedHandler
Sourcepub fn from_closure(f: Box<HandlerCallFn>) -> Self
pub fn from_closure(f: Box<HandlerCallFn>) -> Self
Create an ErasedHandler from an already-boxed closure.
This is the fully non-generic entry point used by the erase_handler!
family of macros. Because the closure is already boxed, no generic
function is monomorphized at the call site — the compiler only sees
concrete types, keeping trait-resolution pressure near zero.
Prefer the erase_handler! / erase_handler_with_args! macros over
calling this directly; they handle the boxing boilerplate for you.
Sourcepub fn with_args<F, T, Fut, R>(handler: F) -> Selfwhere
F: Fn(T) -> Fut + Send + Sync + 'static,
T: DeserializeOwned + Send + 'static,
Fut: Future<Output = R> + Send + 'static,
R: IntoHandlerResult + 'static,
pub fn with_args<F, T, Fut, R>(handler: F) -> Selfwhere
F: Fn(T) -> Fut + Send + Sync + 'static,
T: DeserializeOwned + Send + 'static,
Fut: Future<Output = R> + Send + 'static,
R: IntoHandlerResult + 'static,
Erase a handler that accepts typed, deserialized arguments.
Sourcepub fn with_state<F, S, T, Fut, R>(handler: F, states: SharedStateMap) -> Self
pub fn with_state<F, S, T, Fut, R>(handler: F, states: SharedStateMap) -> Self
Erase a handler that receives injected state and typed args.
Sourcepub fn with_state_only<F, S, Fut, R>(handler: F, states: SharedStateMap) -> Self
pub fn with_state_only<F, S, Fut, R>(handler: F, states: SharedStateMap) -> Self
Erase a handler that receives only injected state (no args).
Trait Implementations§
Auto Trait Implementations§
impl Freeze for ErasedHandler
impl !RefUnwindSafe for ErasedHandler
impl Send for ErasedHandler
impl Sync for ErasedHandler
impl Unpin for ErasedHandler
impl UnsafeUnpin for ErasedHandler
impl !UnwindSafe for ErasedHandler
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
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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>
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>
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::RequestSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request