diff --git a/src/server.rs b/src/server.rs index a5e23d29..c61a3f56 100644 --- a/src/server.rs +++ b/src/server.rs @@ -151,7 +151,7 @@ impl Server { where F: Fn() -> N + Clone + Send + 'static, U: net::ToSocketAddrs, - N: NewService + 'static, + N: NewService + 'static, N::Service: 'static, N::Future: 'static, N::Error: fmt::Display, @@ -168,7 +168,7 @@ impl Server { pub fn listen(mut self, lst: net::TcpListener, factory: F) -> Self where F: Fn() -> N + Clone + Send + 'static, - N: NewService + 'static, + N: NewService + 'static, N::Service: 'static, N::Future: 'static, N::Error: fmt::Display, diff --git a/src/server_service.rs b/src/server_service.rs index 0afc99d9..e6292f64 100644 --- a/src/server_service.rs +++ b/src/server_service.rs @@ -1,7 +1,7 @@ use std::cell::Cell; use std::rc::Rc; use std::sync::atomic::{AtomicUsize, Ordering}; -use std::{fmt, io, net}; +use std::{fmt, net}; use futures::task::AtomicTask; use futures::{future, Async, Future, Poll}; @@ -102,7 +102,7 @@ where impl ServerNewService where F: Fn() -> T + Send + Clone + 'static, - T: NewService + 'static, + T: NewService + 'static, T::Service: 'static, T::Future: 'static, T::Error: fmt::Display, @@ -121,7 +121,7 @@ pub trait ServerServiceFactory { impl ServerServiceFactory for ServerNewService where F: Fn() -> T + Send + Clone + 'static, - T: NewService + 'static, + T: NewService + 'static, T::Service: 'static, T::Future: 'static, T::Error: fmt::Display, @@ -136,7 +136,6 @@ where Box::new( (self.inner)() .new_service() - .map_err(|_| ()) .map(move |inner| { let service: BoxedServerService = Box::new(ServerService::new(inner)); service