pub trait TrackCompletion<H, V>: Clone {
    type Output;
    // Required method
    fn track_completion(&self, handle: H, value: V) -> Self::Output;
}Expand description
Attaches H-typed completion tracker to V typed values.
Handles (of type H) are intended to be RAII guards that primarily implement Drop and update
load metric state as they are dropped. This trait allows implementors to “forward” the handle
to later parts of the request-handling pipeline, so that the handle is only dropped when the
request has truly completed.
This utility allows load metrics to have a protocol-agnostic means to track streams past their
initial response future. For example, if V represents an HTTP response type, an
implementation could add H-typed handles to each response’s extensions to detect when all the
response’s extensions have been dropped.
A base impl<H, V> TrackCompletion<H, V> for CompleteOnResponse is provided to drop the handle
once the response future is resolved. This is appropriate when a response is discrete and
cannot comprise multiple messages.
In many cases, the Output type is simply V. However, TrackCompletion may alter the type
in order to instrument it appropriately. For example, an HTTP TrackCompletion may modify
the body type: so a TrackCompletion that takes values of type
http::Response<A> may output values of type http::Response<B>.
Required Associated Types§
Required Methods§
Sourcefn track_completion(&self, handle: H, value: V) -> Self::Output
 
fn track_completion(&self, handle: H, value: V) -> Self::Output
Attaches a H-typed handle to a V-typed value.
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.