From 9ac0edbac6d6272d4edd7421f96be905d7d701c3 Mon Sep 17 00:00:00 2001 From: kingxsp Date: Wed, 11 Apr 2018 14:39:19 +0800 Subject: [PATCH] update example --- README.md | 2 +- examples/prost-example/Cargo.toml | 5 ++--- examples/prost-example/src/main.rs | 23 ++++++++--------------- 3 files changed, 11 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index 48b8afdae..e5d824d70 100644 --- a/README.md +++ b/README.md @@ -19,7 +19,7 @@ pub struct MyObj { fn index(msg: ProtoBuf) -> Result { println!("model: {:?}", msg); - HttpResponse::Ok().protobuf(msg) // <- send response + HttpResponse::Ok().protobuf(msg.0) // <- send response } ``` diff --git a/examples/prost-example/Cargo.toml b/examples/prost-example/Cargo.toml index 6cd47d969..3f414ea01 100644 --- a/examples/prost-example/Cargo.toml +++ b/examples/prost-example/Cargo.toml @@ -1,16 +1,15 @@ [package] name = "prost-example" -version = "0.1.0" +version = "0.2.0" authors = ["kingxsp "] [dependencies] bytes = "0.4" -futures = "0.1" env_logger = "*" prost = "0.2" prost-derive = "0.2" actix = "0.5" -actix-web = "0.4" +actix-web = "0.5" actix-protobuf = { path="../../" } \ No newline at end of file diff --git a/examples/prost-example/src/main.rs b/examples/prost-example/src/main.rs index 0b2309859..c384094a1 100644 --- a/examples/prost-example/src/main.rs +++ b/examples/prost-example/src/main.rs @@ -1,8 +1,7 @@ +extern crate bytes; extern crate actix; extern crate actix_web; extern crate actix_protobuf; -extern crate bytes; -extern crate futures; extern crate env_logger; extern crate prost; #[macro_use] @@ -10,7 +9,6 @@ extern crate prost_derive; use actix_web::*; use actix_protobuf::*; -use futures::Future; #[derive(Clone, Debug, PartialEq, Message)] pub struct MyObj { @@ -21,26 +19,21 @@ pub struct MyObj { } -fn index(req: HttpRequest) -> Box> { - req.protobuf() - .from_err() // convert all errors into `Error` - .and_then(|val: MyObj| { - println!("model: {:?}", val); - Ok(httpcodes::HTTPOk.build().protobuf(val)?) // <- send response - }) - .responder() +fn index(msg: ProtoBuf) -> Result { + println!("model: {:?}", msg); + HttpResponse::Ok().protobuf(msg.0) // <- send response } fn main() { ::std::env::set_var("RUST_LOG", "actix_web=info"); - let _ = env_logger::init(); + env_logger::init(); let sys = actix::System::new("prost-example"); - let _addr = HttpServer::new(|| { - Application::new() + server::new(|| { + App::new() .middleware(middleware::Logger::default()) - .resource("/", |r| r.method(Method::POST).f(index))}) + .resource("/", |r| r.method(http::Method::POST).with(index))}) .bind("127.0.0.1:8080").unwrap() .shutdown_timeout(1) .start();