refactor(lib): convert to futures 0.2.0-beta (#1470)
This commit is contained in:
@@ -8,7 +8,7 @@ extern crate pretty_env_logger;
|
||||
use std::env;
|
||||
use std::io::{self, Write};
|
||||
|
||||
use futures::{Future, Stream};
|
||||
use futures::{FutureExt, StreamExt};
|
||||
use futures::future::lazy;
|
||||
|
||||
use hyper::{Body, Client, Request};
|
||||
@@ -30,7 +30,7 @@ fn main() {
|
||||
return;
|
||||
}
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let client = Client::default();
|
||||
|
||||
let mut req = Request::new(Body::empty());
|
||||
@@ -43,10 +43,13 @@ fn main() {
|
||||
res.into_parts().1.into_stream().for_each(|chunk| {
|
||||
io::stdout().write_all(&chunk).map_err(From::from)
|
||||
})
|
||||
}).map(|_| {
|
||||
println!("\n\nDone.");
|
||||
}).map_err(|err| {
|
||||
eprintln!("Error {}", err);
|
||||
}).then(|result| {
|
||||
if let Some(err) = result.err() {
|
||||
eprintln!("Error {}", err);
|
||||
} else {
|
||||
println!("\n\nDone.");
|
||||
}
|
||||
Ok(())
|
||||
})
|
||||
}));
|
||||
}
|
||||
|
||||
@@ -4,7 +4,7 @@ extern crate futures;
|
||||
extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
|
||||
use futures::Future;
|
||||
use futures::FutureExt;
|
||||
use futures::future::lazy;
|
||||
|
||||
use hyper::{Body, Response};
|
||||
@@ -20,13 +20,13 @@ fn main() {
|
||||
Ok(Response::new(Body::from(PHRASE)))
|
||||
}));
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let server = Http::new()
|
||||
.sleep_on_errors(true)
|
||||
.bind(&addr, new_service)
|
||||
.unwrap();
|
||||
|
||||
println!("Listening on http://{} with 1 thread.", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| eprintln!("Server error {}", err))
|
||||
println!("Listening on http://{}", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| panic!("Server error {}", err))
|
||||
}));
|
||||
}
|
||||
|
||||
@@ -4,8 +4,9 @@ extern crate futures;
|
||||
extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
|
||||
use futures::{Future, Stream};
|
||||
use futures::{FutureExt, StreamExt};
|
||||
use futures::future::{FutureResult, lazy};
|
||||
use futures::executor::spawn;
|
||||
|
||||
use hyper::{Body, Method, Request, Response, StatusCode};
|
||||
use hyper::server::{Http, Service};
|
||||
@@ -43,22 +44,20 @@ fn main() {
|
||||
let addr1 = "127.0.0.1:1337".parse().unwrap();
|
||||
let addr2 = "127.0.0.1:1338".parse().unwrap();
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let srv1 = Http::new().serve_addr(&addr1, || Ok(Srv(INDEX1))).unwrap();
|
||||
let srv2 = Http::new().serve_addr(&addr2, || Ok(Srv(INDEX2))).unwrap();
|
||||
|
||||
println!("Listening on http://{}", srv1.incoming_ref().local_addr());
|
||||
println!("Listening on http://{}", srv2.incoming_ref().local_addr());
|
||||
|
||||
tokio::spawn(srv1.for_each(move |conn| {
|
||||
tokio::spawn(conn.map(|_| ()).map_err(|err| println!("srv1 error: {:?}", err)));
|
||||
Ok(())
|
||||
}).map_err(|_| ()));
|
||||
spawn(srv1.map_err(|err| panic!("srv1 error: {:?}", err)).for_each(move |conn| {
|
||||
spawn(conn.map(|_| ()).map_err(|err| panic!("srv1 error: {:?}", err)))
|
||||
}).map(|_| ()));
|
||||
|
||||
tokio::spawn(srv2.for_each(move |conn| {
|
||||
tokio::spawn(conn.map(|_| ()).map_err(|err| println!("srv2 error: {:?}", err)));
|
||||
Ok(())
|
||||
}).map_err(|_| ()));
|
||||
spawn(srv2.map_err(|err| panic!("srv2 error: {:?}", err)).for_each(move |conn| {
|
||||
spawn(conn.map(|_| ()).map_err(|err| panic!("srv2 error: {:?}", err)))
|
||||
}).map(|_| ()));
|
||||
|
||||
Ok(())
|
||||
}));
|
||||
|
||||
@@ -5,7 +5,7 @@ extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
extern crate url;
|
||||
|
||||
use futures::{Future, Stream};
|
||||
use futures::{Future, FutureExt, StreamExt};
|
||||
use futures::future::lazy;
|
||||
|
||||
use hyper::{Body, Method, Request, Response, StatusCode};
|
||||
@@ -32,7 +32,7 @@ impl Service for ParamExample {
|
||||
Box::new(futures::future::ok(Response::new(INDEX.into())))
|
||||
},
|
||||
(&Method::POST, "/post") => {
|
||||
Box::new(req.into_parts().1.into_stream().concat2().map(|b| {
|
||||
Box::new(req.into_parts().1.into_stream().concat().map(|b| {
|
||||
// Parse the request body. form_urlencoded::parse
|
||||
// always succeeds, but in general parsing may
|
||||
// fail (for example, an invalid post of json), so
|
||||
@@ -98,9 +98,11 @@ fn main() {
|
||||
pretty_env_logger::init();
|
||||
let addr = "127.0.0.1:1337".parse().unwrap();
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let server = Http::new().bind(&addr, || Ok(ParamExample)).unwrap();
|
||||
println!("Listening on http://{} with 1 thread.", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| eprintln!("Server error {}", err))
|
||||
println!("Listening on http://{}", server.local_addr().unwrap());
|
||||
server.run().recover(|err| {
|
||||
eprintln!("Server error {}", err)
|
||||
})
|
||||
}));
|
||||
}
|
||||
|
||||
@@ -4,9 +4,9 @@ extern crate hyper;
|
||||
extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
|
||||
use futures::{Future/*, Sink*/};
|
||||
use futures::{Future, FutureExt};
|
||||
use futures::future::lazy;
|
||||
use futures::sync::oneshot;
|
||||
use futures::channel::oneshot;
|
||||
|
||||
use hyper::{Body, /*Chunk,*/ Method, Request, Response, StatusCode};
|
||||
use hyper::error::Error;
|
||||
@@ -141,9 +141,9 @@ fn main() {
|
||||
pretty_env_logger::init();
|
||||
let addr = "127.0.0.1:1337".parse().unwrap();
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let server = Http::new().bind(&addr, || Ok(ResponseExamples)).unwrap();
|
||||
println!("Listening on http://{} with 1 thread.", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| eprintln!("Server error {}", err))
|
||||
println!("Listening on http://{}", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| panic!("Server error {}", err))
|
||||
}));
|
||||
}
|
||||
|
||||
@@ -4,7 +4,7 @@ extern crate hyper;
|
||||
extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
|
||||
use futures::Future;
|
||||
use futures::FutureExt;
|
||||
use futures::future::{FutureResult, lazy};
|
||||
|
||||
use hyper::{Body, Method, Request, Response, StatusCode};
|
||||
@@ -43,9 +43,11 @@ fn main() {
|
||||
pretty_env_logger::init();
|
||||
let addr = "127.0.0.1:1337".parse().unwrap();
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let server = Http::new().bind(&addr, || Ok(Echo)).unwrap();
|
||||
println!("Listening on http://{} with 1 thread.", server.local_addr().unwrap());
|
||||
server.run().map_err(|err| eprintln!("Server error {}", err))
|
||||
println!("Listening on http://{}", server.local_addr().unwrap());
|
||||
server.run().recover(|err| {
|
||||
eprintln!("Server error {}", err)
|
||||
})
|
||||
}));
|
||||
}
|
||||
|
||||
@@ -4,14 +4,15 @@ extern crate hyper;
|
||||
extern crate pretty_env_logger;
|
||||
extern crate tokio;
|
||||
|
||||
use futures::{Future, Stream};
|
||||
use futures::{Future, FutureExt, StreamExt};
|
||||
use futures::executor::spawn;
|
||||
use futures::future::lazy;
|
||||
use tokio::reactor::Handle;
|
||||
|
||||
use hyper::{Body, Chunk, Client, Method, Request, Response, StatusCode};
|
||||
use hyper::server::{Http, Service};
|
||||
|
||||
#[allow(unused)]
|
||||
#[allow(unused, deprecated)]
|
||||
use std::ascii::AsciiExt;
|
||||
|
||||
static NOTFOUND: &[u8] = b"Not Found";
|
||||
@@ -78,13 +79,15 @@ fn main() {
|
||||
pretty_env_logger::init();
|
||||
let addr = "127.0.0.1:1337".parse().unwrap();
|
||||
|
||||
tokio::run(lazy(move || {
|
||||
tokio::runtime::run2(lazy(move |_| {
|
||||
let handle = Handle::current();
|
||||
let serve = Http::new().serve_addr(&addr, move || Ok(ResponseExamples(handle.clone()))).unwrap();
|
||||
println!("Listening on http://{} with 1 thread.", serve.incoming_ref().local_addr());
|
||||
println!("Listening on http://{}", serve.incoming_ref().local_addr());
|
||||
|
||||
serve.map_err(|_| ()).for_each(move |conn| {
|
||||
tokio::spawn(conn.map(|_| ()).map_err(|err| println!("serve error: {:?}", err)))
|
||||
})
|
||||
serve.map_err(|err| panic!("server error {:?}", err)).for_each(move |conn| {
|
||||
spawn(conn.recover(|err| {
|
||||
println!("connection error: {:?}", err);
|
||||
}))
|
||||
}).map(|_| ())
|
||||
}));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user