Struct tower::buffer::Buffer [−][src]
Adds a buffer in front of an inner service.
See crate level documentation for more details.
Implementations
impl<T, Request> Buffer<T, Request> where
T: Service<Request>,
<T as Service<Request>>::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
[src]
T: Service<Request>,
<T as Service<Request>>::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
pub fn new(service: T, bound: usize) -> Buffer<T, Request> where
T: Send + 'static,
Request: Send + 'static,
<T as Service<Request>>::Future: Send,
<T as Service<Request>>::Error: Send,
<T as Service<Request>>::Error: Sync,
[src]
T: Send + 'static,
Request: Send + 'static,
<T as Service<Request>>::Future: Send,
<T as Service<Request>>::Error: Send,
<T as Service<Request>>::Error: Sync,
Creates a new Buffer
wrapping service
.
bound
gives the maximal number of requests that can be queued for the service before
backpressure is applied to callers.
The default Tokio executor is used to run the given service, which means that this method must be called while on the Tokio runtime.
pub fn pair(
service: T,
bound: usize
) -> (Buffer<T, Request>, Worker<T, Request>) where
T: Send + 'static,
Request: Send + 'static,
<T as Service<Request>>::Error: Send,
<T as Service<Request>>::Error: Sync,
[src]
service: T,
bound: usize
) -> (Buffer<T, Request>, Worker<T, Request>) where
T: Send + 'static,
Request: Send + 'static,
<T as Service<Request>>::Error: Send,
<T as Service<Request>>::Error: Sync,
Creates a new Buffer
wrapping service
but returns the background worker.
This is useful if you do not want to spawn directly onto the tokio
runtime
but instead want to use your own executor. This will return the Buffer
and
the background Worker
that you can then spawn.
Trait Implementations
impl<T, Request> Clone for Buffer<T, Request> where
T: Service<Request>,
[src]
T: Service<Request>,
impl<T, Request> Debug for Buffer<T, Request> where
T: Debug + Service<Request>,
Request: Debug,
<T as Service<Request>>::Future: Debug,
[src]
T: Debug + Service<Request>,
Request: Debug,
<T as Service<Request>>::Future: Debug,
impl<T, Request> Service<Request> for Buffer<T, Request> where
T: Service<Request>,
<T as Service<Request>>::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
[src]
T: Service<Request>,
<T as Service<Request>>::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
type Response = <T as Service<Request>>::Response
Responses given by the service.
type Error = Box<dyn Error + 'static + Send + Sync, Global>
Errors produced by the service.
type Future = ResponseFuture<<T as Service<Request>>::Future>
The future response value.
pub fn poll_ready(
&mut self,
cx: &mut Context<'_>
) -> Poll<Result<(), <Buffer<T, Request> as Service<Request>>::Error>>
[src]
&mut self,
cx: &mut Context<'_>
) -> Poll<Result<(), <Buffer<T, Request> as Service<Request>>::Error>>
pub fn call(
&mut self,
request: Request
) -> <Buffer<T, Request> as Service<Request>>::Future
[src]
&mut self,
request: Request
) -> <Buffer<T, Request> as Service<Request>>::Future
Auto Trait Implementations
impl<T, Request> !RefUnwindSafe for Buffer<T, Request>
impl<T, Request> Send for Buffer<T, Request> where
Request: Send,
<T as Service<Request>>::Future: Send,
Request: Send,
<T as Service<Request>>::Future: Send,
impl<T, Request> Sync for Buffer<T, Request> where
Request: Send,
<T as Service<Request>>::Future: Send,
Request: Send,
<T as Service<Request>>::Future: Send,
impl<T, Request> Unpin for Buffer<T, Request>
impl<T, Request> !UnwindSafe for Buffer<T, Request>
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, Request> ServiceExt<Request> for T where
T: Service<Request> + ?Sized,
[src]
T: Service<Request> + ?Sized,
pub fn ready(&mut self) -> Ready<'_, Self, Request>ⓘ
[src]
pub fn ready_and(&mut self) -> ReadyAnd<'_, Self, Request>
[src]
pub fn ready_oneshot(self) -> ReadyOneshot<Self, Request>
[src]
pub fn oneshot(self, req: Request) -> Oneshot<Self, Request>ⓘ
[src]
pub fn call_all<S>(self, reqs: S) -> CallAll<Self, S> where
S: Stream<Item = Request>,
Self::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
[src]
S: Stream<Item = Request>,
Self::Error: Into<Box<dyn Error + 'static + Send + Sync, Global>>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,