Eliza Weisman 1e126aa752 Unbox server handshake future (#52)
Server-side version of #42. I've rewritten `server::Handshake` as a hand-rolled `Future` rather than as a `Box<Future>`. In addition to removing a `Box`, this also means that the `'static` lifetime bounds on the type parameters `T` and `B` can be removed.

The type of the server handshake future is somewhat more complex than the client-side handshake future. Note also that I've had to re-export `proto::streams::Prioritized` as `pub(crate)` from `proto`, as it appears in the type of the handshake future.

I've ran the tests against this branch and everything passes. Since no new functionality was added, I haven't added any additional tests.

This also fixes #158 - I had accidentally committed a Darwin h2spec executable and that's what was breaking CI.
2017-10-19 12:21:13 -07:00
2017-05-31 14:44:58 -07:00
2017-10-19 12:21:13 -07:00
2017-10-18 11:00:56 -07:00
2017-03-09 20:02:47 -08:00
2017-10-18 11:00:56 -07:00
2017-10-07 12:34:46 -07:00
2017-08-16 22:23:45 -07:00
2017-08-16 22:23:45 -07:00
2017-10-09 11:21:05 -07:00

H2

A Tokio aware, HTTP/2.0 client & server implementation for Rust.

Build Status Codecov

This library is not production ready. Do not try to use it in a production environment or you will regret it! This crate is still under active development and there has not yet been any focus on documentation (because you shouldn't be using it yet!).

More information about this crate can be found in the crate documentation

Features

  • Client and server HTTP/2.0 implementation.
  • Implements the full HTTP/2.0 specification.
  • Passes h2spec.
  • Focus on performance and correctness.
  • Built on Tokio.

Non goals

This crate is intended to only be an implementation of the HTTP/2.0 specification. It does not handle:

  • Managing TCP connections
  • HTTP 1.0 upgrade
  • TLS
  • Any feature not described by the HTTP/2.0 specification.

The intent is that this crate will eventually be used by hyper, which will provide all of these features.

Usage

To use h2, first add this to your Cargo.toml:

[dependencies]
h2 = { git = 'https://github.com/carllerche/h2' } # soon to be on crates.io!

Next, add this to your crate:

extern crate h2;

use h2::server::Server;

fn main() {
    // ...
}

License

h2 is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.

See LICENSE-APACHE, and LICENSE-MIT for details.

Description
No description provided
Readme 4.5 MiB
Languages
Rust 99.2%
Python 0.7%