Skip to content

Commit 2d2d557

Browse files
committed
feat(lib): redesign API to use Futures and Tokio
There are many changes involved with this, but let's just talk about user-facing changes. - Creating a `Client` and `Server` now needs a Tokio `Core` event loop to attach to. - `Request` and `Response` both no longer implement the `std::io::{Read,Write}` traits, but instead represent their bodies as a `futures::Stream` of items, where each item is a `Chunk`. - The `Client.request` method now takes a `Request`, instead of being used as a builder, and returns a `Future` that resolves to `Response`. - The `Handler` trait for servers is no more, and instead the Tokio `Service` trait is used. This allows interoperability with generic middleware. BREAKING CHANGE: A big sweeping set of breaking changes.
1 parent e236891 commit 2d2d557

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

43 files changed

+2724
-4982
lines changed

.travis.yml

-5
Original file line numberDiff line numberDiff line change
@@ -2,15 +2,10 @@ language: rust
22
matrix:
33
fast_finish: true
44
include:
5-
- os: osx
6-
rust: stable
7-
env: FEATURES="--no-default-features --features security-framework"
85
- rust: nightly
96
env: FEATURES="--features nightly"
107
- rust: beta
118
- rust: stable
12-
- rust: stable
13-
env: FEATURES="--no-default-features"
149

1510
cache:
1611
apt: true

Cargo.toml

+10-25
Original file line numberDiff line numberDiff line change
@@ -7,49 +7,34 @@ readme = "README.md"
77
documentation = "http://hyperium.github.io/hyper"
88
repository = "https://github.com/hyperium/hyper"
99
license = "MIT"
10-
authors = ["Sean McArthur <sean.monstar@gmail.com>",
11-
"Jonathan Reem <jonathan.reem@gmail.com>"]
10+
authors = ["Sean McArthur <sean.monstar@gmail.com>"]
1211
keywords = ["http", "hyper", "hyperium"]
1312

1413
[dependencies]
14+
futures = "0.1.7"
15+
futures-cpupool = "0.1"
1516
httparse = "1.0"
1617
language-tags = "0.2"
1718
log = "0.3"
1819
mime = "0.2"
19-
rotor = "0.6"
20+
relay = "0.1"
2021
rustc-serialize = "0.3"
21-
spmc = "0.2"
2222
time = "0.1"
23+
tokio-core = "0.1"
24+
tokio-proto = "0.1"
25+
tokio-service = "0.1"
2326
unicase = "1.0"
2427
url = "1.0"
25-
vecio = "0.1"
2628

2729
[dependencies.cookie]
2830
version = "0.3"
2931
default-features = false
3032

31-
[dependencies.openssl]
32-
version = "0.7"
33-
optional = true
34-
35-
[dependencies.openssl-verify]
36-
version = "0.1"
37-
optional = true
38-
39-
[dependencies.security-framework]
40-
version = "0.1.4"
41-
optional = true
42-
43-
[dependencies.serde]
44-
version = "0.8"
45-
optional = true
46-
4733
[dev-dependencies]
48-
env_logger = "0.3"
4934
num_cpus = "1.0"
35+
pretty_env_logger = "0.1"
36+
spmc = "0.2"
5037

5138
[features]
52-
default = ["ssl"]
53-
ssl = ["openssl", "openssl-verify"]
54-
serde-serialization = ["serde", "mime/serde"]
39+
default = []
5540
nightly = []

benches/end_to_end.rs

+61
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
#![feature(test)]
2+
3+
extern crate futures;
4+
extern crate hyper;
5+
extern crate tokio_core;
6+
7+
extern crate test;
8+
9+
use futures::{Future, Stream};
10+
use tokio_core::reactor::Core;
11+
12+
use hyper::header::{ContentLength, ContentType};
13+
use hyper::server::{Service, Request, Response};
14+
15+
16+
#[bench]
17+
fn one_request_at_a_time(b: &mut test::Bencher) {
18+
extern crate pretty_env_logger;
19+
let _ = pretty_env_logger::init();
20+
let mut core = Core::new().unwrap();
21+
let handle = core.handle();
22+
23+
let addr = hyper::Server::http(&"127.0.0.1:0".parse().unwrap(), &handle).unwrap()
24+
.handle(|| Ok(Hello), &handle).unwrap();
25+
26+
let mut client = hyper::Client::new(&handle);
27+
28+
let url: hyper::Url = format!("http://{}/get", addr).parse().unwrap();
29+
30+
b.bytes = 160;
31+
b.iter(move || {
32+
let work = client.get(url.clone()).and_then(|res| {
33+
res.body().for_each(|_chunk| {
34+
Ok(())
35+
})
36+
});
37+
38+
core.run(work).unwrap();
39+
});
40+
}
41+
42+
static PHRASE: &'static [u8] = b"Hello, World!";
43+
44+
#[derive(Clone, Copy)]
45+
struct Hello;
46+
47+
impl Service for Hello {
48+
type Request = Request;
49+
type Response = Response;
50+
type Error = hyper::Error;
51+
type Future = ::futures::Finished<Response, hyper::Error>;
52+
fn call(&mut self, _req: Request) -> Self::Future {
53+
::futures::finished(
54+
Response::new()
55+
.with_header(ContentLength(PHRASE.len() as u64))
56+
.with_header(ContentType::plaintext())
57+
.with_body(PHRASE)
58+
)
59+
}
60+
61+
}

0 commit comments

Comments
 (0)