1
0
mirror of https://github.com/fafhrd91/actix-net synced 2025-01-18 23:21:50 +01:00

fix IntoService

This commit is contained in:
Nikolay Kim 2019-03-08 20:50:29 -08:00
parent 0f064c43e9
commit 49867b5e9d

View File

@ -1,7 +1,7 @@
use std::marker::PhantomData; use std::marker::PhantomData;
use futures::future::{ok, FutureResult}; use futures::future::{ok, Future, FutureResult};
use futures::{Async, IntoFuture, Poll}; use futures::{try_ready, Async, IntoFuture, Poll};
use crate::{IntoConfigurableNewService, IntoNewService, IntoService, NewService, Service}; use crate::{IntoConfigurableNewService, IntoNewService, IntoService, NewService, Service};
@ -216,7 +216,8 @@ where
pub struct FnNewServiceConfig<F, C, R, S, E, Req> pub struct FnNewServiceConfig<F, C, R, S, E, Req>
where where
F: Fn(&C) -> R, F: Fn(&C) -> R,
R: IntoFuture<Item = S, Error = E>, R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>, S: Service<Req>,
{ {
f: F, f: F,
@ -226,7 +227,8 @@ where
impl<F, C, R, S, E, Req> FnNewServiceConfig<F, C, R, S, E, Req> impl<F, C, R, S, E, Req> FnNewServiceConfig<F, C, R, S, E, Req>
where where
F: Fn(&C) -> R, F: Fn(&C) -> R,
R: IntoFuture<Item = S, Error = E>, R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>, S: Service<Req>,
{ {
pub fn new(f: F) -> Self { pub fn new(f: F) -> Self {
@ -237,7 +239,8 @@ where
impl<F, C, R, S, E, Req> NewService<Req, C> for FnNewServiceConfig<F, C, R, S, E, Req> impl<F, C, R, S, E, Req> NewService<Req, C> for FnNewServiceConfig<F, C, R, S, E, Req>
where where
F: Fn(&C) -> R, F: Fn(&C) -> R,
R: IntoFuture<Item = S, Error = E>, R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>, S: Service<Req>,
{ {
type Response = S::Response; type Response = S::Response;
@ -245,17 +248,45 @@ where
type Service = S; type Service = S;
type InitError = E; type InitError = E;
type Future = R::Future; type Future = FnNewServiceConfigFut<R, S, E, Req>;
fn new_service(&self, cfg: &C) -> Self::Future { fn new_service(&self, cfg: &C) -> Self::Future {
(self.f)(cfg).into_future() FnNewServiceConfigFut {
fut: (self.f)(cfg).into_future(),
_t: PhantomData,
}
}
}
pub struct FnNewServiceConfigFut<R, S, E, Req>
where
R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>,
{
fut: R::Future,
_t: PhantomData<(S, Req)>,
}
impl<R, S, E, Req> Future for FnNewServiceConfigFut<R, S, E, Req>
where
R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>,
{
type Item = S;
type Error = R::Error;
fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
Ok(Async::Ready(try_ready!(self.fut.poll()).into_service()))
} }
} }
impl<F, C, R, S, E, Req> Clone for FnNewServiceConfig<F, C, R, S, E, Req> impl<F, C, R, S, E, Req> Clone for FnNewServiceConfig<F, C, R, S, E, Req>
where where
F: Fn(&C) -> R + Clone, F: Fn(&C) -> R + Clone,
R: IntoFuture<Item = S, Error = E>, R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>, S: Service<Req>,
{ {
fn clone(&self) -> Self { fn clone(&self) -> Self {
@ -267,7 +298,8 @@ impl<F, C, R, S, E, Req>
IntoConfigurableNewService<FnNewServiceConfig<F, C, R, S, E, Req>, Req, C> for F IntoConfigurableNewService<FnNewServiceConfig<F, C, R, S, E, Req>, Req, C> for F
where where
F: Fn(&C) -> R, F: Fn(&C) -> R,
R: IntoFuture<Item = S, Error = E>, R: IntoFuture<Error = E>,
R::Item: IntoService<S, Req>,
S: Service<Req>, S: Service<Req>,
{ {
fn into_new_service(self) -> FnNewServiceConfig<F, C, R, S, E, Req> { fn into_new_service(self) -> FnNewServiceConfig<F, C, R, S, E, Req> {