Update examples to use new Tokio (#316)

The old `tokio-core` crate is deprecated in favour of the `tokio` crate,
which also provides the new multithreaded Tokio runtime. Although `h2`
is generic over the runtime, the examples do depend on `tokio`. 

This branch update the example code to use the new `tokio` library
rather than `tokio-core`. It also updates the examples in `RustDoc`.

For the most part, this was pretty trivial --- simply replacing
`handle.spawn(...)` with `tokio::spawn(...)` and `core.run(...)` with
`tokio::run(...)`. There were a couple of cases where error and item
types from spawned futures had to be mapped to `(), ()`. Alternatively,
this could have been avoided by using the single-threaded runtime and
calling `block_on` instead to await the value of those futures, but I
thought it was better to reduce the amount of tokio-specific code in the
examples.

Signed-off-by: Eliza Weisman <eliza@buoyant.io>
This commit is contained in:
Eliza Weisman
2018-09-25 14:33:49 -07:00
committed by GitHub
parent 12e0d26945
commit 00ca534c4a
6 changed files with 38 additions and 57 deletions

View File

@@ -2,7 +2,7 @@ extern crate env_logger;
extern crate futures;
extern crate h2;
extern crate http;
extern crate tokio_core;
extern crate tokio;
use h2::client;
use h2::RecvStream;
@@ -10,8 +10,7 @@ use h2::RecvStream;
use futures::*;
use http::*;
use tokio_core::net::TcpStream;
use tokio_core::reactor;
use tokio::net::TcpStream;
struct Process {
body: RecvStream,
@@ -47,10 +46,7 @@ impl Future for Process {
pub fn main() {
let _ = env_logger::try_init();
let mut core = reactor::Core::new().unwrap();
let handle = core.handle();
let tcp = TcpStream::connect(&"127.0.0.1:5928".parse().unwrap(), &handle);
let tcp = TcpStream::connect(&"127.0.0.1:5928".parse().unwrap());
let tcp = tcp.then(|res| {
let tcp = res.unwrap();
@@ -74,7 +70,7 @@ pub fn main() {
stream.send_trailers(trailers).unwrap();
// Spawn a task to run the conn...
handle.spawn(h2.map_err(|e| println!("GOT ERR={:?}", e)));
tokio::spawn(h2.map_err(|e| println!("GOT ERR={:?}", e)));
response
.and_then(|response| {
@@ -93,5 +89,5 @@ pub fn main() {
})
});
core.run(tcp).unwrap();
tokio::run(tcp);
}