extern crate bytes; extern crate env_logger; extern crate futures; extern crate h2; extern crate http; extern crate tokio; use h2::server; use bytes::*; use futures::*; use http::*; use tokio::net::TcpListener; pub fn main() { let _ = env_logger::try_init(); let listener = TcpListener::bind(&"127.0.0.1:5928".parse().unwrap()).unwrap(); println!("listening on {:?}", listener.local_addr()); let server = listener.incoming().for_each(move |socket| { // let socket = io_dump::Dump::to_stdout(socket); let connection = server::handshake(socket) .and_then(|conn| { println!("H2 connection bound"); conn.for_each(|(request, mut respond)| { println!("GOT request: {:?}", request); let response = Response::builder().status(StatusCode::OK).body(()).unwrap(); let mut send = match respond.send_response(response, false) { Ok(send) => send, Err(e) => { println!(" error respond; err={:?}", e); return Ok(()); } }; println!(">>>> sending data"); if let Err(e) = send.send_data(Bytes::from_static(b"hello world"), true) { println!(" -> err={:?}", e); } Ok(()) }) }) .and_then(|_| { println!("~~~~~~~~~~~~~~~~~~~~~~~~~~~ H2 connection CLOSE !!!!!! ~~~~~~~~~~~"); Ok(()) }) .then(|res| { if let Err(e) = res { println!(" -> err={:?}", e); } Ok(()) }); tokio::spawn(Box::new(connection)); Ok(()) }) .map_err(|e| eprintln!("accept error: {}", e)); tokio::run(server); }