mirror of
https://github.com/rwf2/Rocket.git
synced 2025-01-17 23:19:06 +00:00
Reimplement 'routes!' and 'catchers!' as proc-macros.
This commit is contained in:
parent
46afabdfea
commit
8e779610c4
@ -41,4 +41,5 @@ members = [
|
||||
"examples/raw_sqlite",
|
||||
"examples/tls",
|
||||
"examples/fairings",
|
||||
"examples/hello_2018",
|
||||
]
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
extern crate rocket_contrib;
|
||||
|
||||
#[cfg(feature = "templates")]
|
||||
|
@ -435,8 +435,6 @@ macro_rules! register_macros {
|
||||
#[plugin_registrar]
|
||||
pub fn plugin_registrar(reg: &mut Registry) {
|
||||
register_macros!(reg,
|
||||
"routes" => routes,
|
||||
"catchers" => catchers,
|
||||
"uri" => uri,
|
||||
"rocket_internal_uri" => uri_internal
|
||||
);
|
||||
|
@ -1,14 +1,8 @@
|
||||
mod uri;
|
||||
|
||||
use {ROUTE_STRUCT_PREFIX, CATCH_STRUCT_PREFIX};
|
||||
use utils::{sep_by_tok, ParserExt, IdentExt};
|
||||
use utils::IdentExt;
|
||||
|
||||
use syntax::source_map::Span;
|
||||
use syntax::tokenstream::TokenTree;
|
||||
use syntax::ast::{Path, Expr};
|
||||
use syntax::ext::base::{DummyResult, ExtCtxt, MacResult, MacEager};
|
||||
use syntax::parse::token::Token;
|
||||
use syntax::ptr::P;
|
||||
use syntax::ast::Path;
|
||||
|
||||
pub use self::uri::{uri, uri_internal};
|
||||
|
||||
@ -18,55 +12,3 @@ pub fn prefix_path(prefix: &str, path: &mut Path) {
|
||||
let last_seg = &mut path.segments[last];
|
||||
last_seg.ident = last_seg.ident.prepend(prefix);
|
||||
}
|
||||
|
||||
#[inline]
|
||||
pub fn prefix_paths(prefix: &str, paths: &mut Vec<Path>) {
|
||||
for p in paths {
|
||||
prefix_path(prefix, p);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn prefixing_vec_macro<F>(
|
||||
prefix: &str,
|
||||
mut to_expr: F,
|
||||
ecx: &mut ExtCtxt,
|
||||
sp: Span,
|
||||
args: &[TokenTree]) -> Box<MacResult + 'static>
|
||||
where F: FnMut(&ExtCtxt, Path) -> P<Expr>
|
||||
{
|
||||
let mut parser = ecx.new_parser_from_tts(args);
|
||||
match parser.parse_paths() {
|
||||
Ok(mut paths) => {
|
||||
// Prefix each path terminator and build up the P<Expr> for each path.
|
||||
prefix_paths(prefix, &mut paths);
|
||||
let path_exprs: Vec<P<Expr>> = paths.into_iter()
|
||||
.map(|path| to_expr(ecx, path))
|
||||
.collect();
|
||||
|
||||
// Now put them all in one vector and return the thing.
|
||||
let path_list = sep_by_tok(ecx, &path_exprs, Token::Comma);
|
||||
let output = quote_expr!(ecx, vec![$path_list]).into_inner();
|
||||
MacEager::expr(P(output))
|
||||
}
|
||||
Err(mut e) => {
|
||||
e.emit();
|
||||
DummyResult::expr(sp)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[rustfmt_skip]
|
||||
pub fn routes(ecx: &mut ExtCtxt, sp: Span, args: &[TokenTree])
|
||||
-> Box<MacResult + 'static> {
|
||||
prefixing_vec_macro(ROUTE_STRUCT_PREFIX, |ecx, path| {
|
||||
quote_expr!(ecx, ::rocket::Route::from(&$path))
|
||||
}, ecx, sp, args)
|
||||
}
|
||||
|
||||
#[rustfmt_skip]
|
||||
pub fn catchers(ecx: &mut ExtCtxt, sp: Span, args: &[TokenTree])
|
||||
-> Box<MacResult + 'static> {
|
||||
prefixing_vec_macro(CATCH_STRUCT_PREFIX, |ecx, path| {
|
||||
quote_expr!(ecx, ::rocket::Catcher::from(&$path))
|
||||
}, ecx, sp, args)
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
#![allow(dead_code, unused_variables)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/test/<one>/<two>/<three>")]
|
||||
fn get(one: String, two: usize, three: isize) -> &'static str { "hi" }
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
#![allow(dead_code, unused_variables)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/one")]
|
||||
fn one() { }
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/<todo>")]
|
||||
fn todo(todo: String) -> String {
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
#![allow(dead_code, unused_variables)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::{Rocket, State};
|
||||
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
#![allow(dead_code, unused_variables)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::State;
|
||||
|
||||
|
@ -26,4 +26,5 @@ rev = "87ad56ba"
|
||||
|
||||
[dev-dependencies]
|
||||
rocket = { version = "0.4.0-dev", path = "../lib" }
|
||||
rocket_codegen = { version = "0.4.0-dev", path = "../codegen" }
|
||||
compiletest_rs = "0.3.14"
|
||||
|
@ -11,6 +11,7 @@ mod derive;
|
||||
mod attribute;
|
||||
mod http_codegen;
|
||||
mod syn_ext;
|
||||
mod prefixing_vec;
|
||||
|
||||
crate use derive_utils::proc_macro2;
|
||||
|
||||
@ -31,6 +32,22 @@ pub fn derive_responder(input: TokenStream) -> TokenStream {
|
||||
derive::responder::derive_responder(input)
|
||||
}
|
||||
|
||||
const ROUTE_STRUCT_PREFIX: &'static str = "static_rocket_route_info_for_";
|
||||
#[proc_macro]
|
||||
pub fn rocket_routes_internal(input: TokenStream) -> TokenStream {
|
||||
prefixing_vec::prefixing_vec_macro(ROUTE_STRUCT_PREFIX, |path| {
|
||||
quote!(::rocket::Route::from(&#path))
|
||||
}, input)
|
||||
}
|
||||
|
||||
const CATCH_STRUCT_PREFIX: &'static str = "static_rocket_catch_info_for_";
|
||||
#[proc_macro]
|
||||
pub fn rocket_catchers_internal(input: TokenStream) -> TokenStream {
|
||||
prefixing_vec::prefixing_vec_macro(CATCH_STRUCT_PREFIX, |path| {
|
||||
quote!(::rocket::Catcher::from(&#path))
|
||||
}, input)
|
||||
}
|
||||
|
||||
#[proc_macro_attribute]
|
||||
pub fn catch(args: TokenStream, input: TokenStream) -> TokenStream {
|
||||
attribute::catch::catch_attribute(args, input)
|
||||
|
44
core/codegen_next/src/prefixing_vec.rs
Normal file
44
core/codegen_next/src/prefixing_vec.rs
Normal file
@ -0,0 +1,44 @@
|
||||
use proc_macro::TokenStream;
|
||||
use proc_macro2::TokenStream as TokenStream2;
|
||||
|
||||
use syn::{Ident, Path};
|
||||
|
||||
use derive_utils::parser::{Parser, Seperator, Result as PResult};
|
||||
|
||||
#[inline]
|
||||
fn prefix_path(prefix: &str, path: &mut Path) {
|
||||
let mut last_seg = path.segments.last_mut().expect("last path segment");
|
||||
let last_value = last_seg.value_mut();
|
||||
last_value.ident = Ident::new(&format!("{}{}", prefix, last_value.ident), last_value.ident.span());
|
||||
}
|
||||
|
||||
pub fn prefixing_vec_macro_internal<F>(prefix: &str, to_expr: F, args: TokenStream) -> PResult<TokenStream>
|
||||
where F: FnMut(Path) -> TokenStream2
|
||||
{
|
||||
let mut parser = Parser::new(args);
|
||||
let mut paths = parser.parse_sep(Seperator::Comma, |p| {
|
||||
p.parse::<Path>()
|
||||
})?;
|
||||
parser.eof().map_err(|_| {
|
||||
parser.current_span()
|
||||
.error("expected `,` or `::` or end of macro invocation")
|
||||
})?;
|
||||
|
||||
for ref mut p in &mut paths {
|
||||
prefix_path(prefix, p);
|
||||
}
|
||||
let path_exprs: Vec<_> = paths.into_iter().map(to_expr).collect();
|
||||
|
||||
let tokens = quote! { vec![#(#path_exprs),*] };
|
||||
Ok(tokens.into())
|
||||
}
|
||||
|
||||
pub fn prefixing_vec_macro<F>(prefix: &str, to_expr: F, args: TokenStream) -> TokenStream
|
||||
where F: FnMut(Path) -> TokenStream2
|
||||
{
|
||||
prefixing_vec_macro_internal(prefix, to_expr, args)
|
||||
.unwrap_or_else(|diag| {
|
||||
diag.emit();
|
||||
(quote! { vec![] }).into()
|
||||
})
|
||||
}
|
8
core/codegen_next/tests/compile-fail/catchers.rs
Normal file
8
core/codegen_next/tests/compile-fail/catchers.rs
Normal file
@ -0,0 +1,8 @@
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
fn main() {
|
||||
let _ = catchers![a b]; //~ ERROR expected
|
||||
}
|
||||
|
11
core/codegen_next/tests/route.rs
Normal file
11
core/codegen_next/tests/route.rs
Normal file
@ -0,0 +1,11 @@
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/")]
|
||||
fn get() {}
|
||||
|
||||
fn main() {
|
||||
rocket::ignite().mount("/", routes![get]);
|
||||
}
|
8
core/codegen_next/tests/ui-fail/routes.rs
Normal file
8
core/codegen_next/tests/ui-fail/routes.rs
Normal file
@ -0,0 +1,8 @@
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
fn main() {
|
||||
let _ = routes![a b];
|
||||
//~^ ERROR expected
|
||||
}
|
8
core/codegen_next/tests/ui-fail/routes.stderr
Normal file
8
core/codegen_next/tests/ui-fail/routes.stderr
Normal file
@ -0,0 +1,8 @@
|
||||
error: expected `,` or `::` or end of macro invocation
|
||||
--> $DIR/routes.rs:6:23
|
||||
|
|
||||
6 | let _ = routes![a b];
|
||||
| ^
|
||||
|
||||
error: aborting due to previous error
|
||||
|
@ -33,10 +33,10 @@ use yansi::Color::*;
|
||||
/// declared using the `catch` decorator, as follows:
|
||||
///
|
||||
/// ```rust
|
||||
/// #![feature(plugin, decl_macro)]
|
||||
/// #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// #![plugin(rocket_codegen)]
|
||||
///
|
||||
/// extern crate rocket;
|
||||
/// #[macro_use] extern crate rocket;
|
||||
///
|
||||
/// use rocket::{catch, Request};
|
||||
///
|
||||
|
@ -86,9 +86,9 @@ pub type Outcome<'r> = outcome::Outcome<Response<'r>, Status, Data>;
|
||||
/// managed state and a static route, as follows:
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// #
|
||||
/// # #[derive(Copy, Clone)]
|
||||
/// # enum Kind {
|
||||
|
@ -67,10 +67,10 @@
|
||||
//! write Rocket applications. Here's a simple example to get you started:
|
||||
//!
|
||||
//! ```rust
|
||||
//! #![feature(plugin, decl_macro)]
|
||||
//! #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
//! #![plugin(rocket_codegen)]
|
||||
//!
|
||||
//! extern crate rocket;
|
||||
//! #[macro_use] extern crate rocket;
|
||||
//!
|
||||
//! #[get("/")]
|
||||
//! fn hello() -> &'static str {
|
||||
@ -102,6 +102,16 @@
|
||||
#[allow(unused_imports)] #[macro_use] extern crate rocket_codegen_next;
|
||||
#[doc(hidden)] pub use rocket_codegen_next::*;
|
||||
|
||||
#[macro_export]
|
||||
macro_rules! routes {
|
||||
($($input:tt)*) => { $crate::rocket_routes_internal![$($input)*] };
|
||||
}
|
||||
|
||||
#[macro_export]
|
||||
macro_rules! catchers {
|
||||
($($input:tt)*) => { $crate::rocket_catchers_internal![$($input)*] };
|
||||
}
|
||||
|
||||
extern crate rocket_http;
|
||||
#[macro_use] extern crate log;
|
||||
#[macro_use] extern crate pear;
|
||||
|
@ -21,9 +21,9 @@ use http::Status;
|
||||
/// following example does just this:
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// use rocket::State;
|
||||
///
|
||||
/// // In a real application, this would likely be more complex.
|
||||
|
@ -47,10 +47,10 @@ const FLASH_COOKIE_NAME: &str = "_flash";
|
||||
/// message on both the request and response sides.
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// #
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// #
|
||||
/// use rocket::response::{Flash, Redirect};
|
||||
/// use rocket::request::FlashMessage;
|
||||
|
@ -455,9 +455,9 @@ impl Rocket {
|
||||
/// dispatched to the `hi` route.
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// #
|
||||
/// #[get("/world")]
|
||||
/// fn hi() -> &'static str {
|
||||
@ -542,10 +542,10 @@ impl Rocket {
|
||||
/// # Examples
|
||||
///
|
||||
/// ```rust
|
||||
/// #![feature(plugin, decl_macro)]
|
||||
/// #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// #![plugin(rocket_codegen)]
|
||||
///
|
||||
/// extern crate rocket;
|
||||
/// #[macro_use] extern crate rocket;
|
||||
///
|
||||
/// use rocket::{catch, Request};
|
||||
///
|
||||
@ -601,9 +601,9 @@ impl Rocket {
|
||||
/// # Example
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// use rocket::State;
|
||||
///
|
||||
/// struct MyValue(usize);
|
||||
@ -756,9 +756,9 @@ impl Rocket {
|
||||
/// # Example
|
||||
///
|
||||
/// ```rust
|
||||
/// # #![feature(plugin, decl_macro)]
|
||||
/// # #![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
/// # #![plugin(rocket_codegen)]
|
||||
/// # extern crate rocket;
|
||||
/// # #[macro_use] extern crate rocket;
|
||||
/// use rocket::Rocket;
|
||||
/// use rocket::fairing::AdHoc;
|
||||
///
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::response::Redirect;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
const RESPONSE_STRING: &'static str = "This is the body. Hello, world!";
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::request::FlashMessage;
|
||||
use rocket::response::Flash;
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::response::{status, content};
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::Outcome::*;
|
||||
use rocket::{Request, Data};
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::http::Cookies;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[post("/", format = "application/json")]
|
||||
fn specified() -> &'static str {
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::{catch, response::Redirect};
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use std::path::PathBuf;
|
||||
use rocket::Route;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::http::uri::Segments;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
mod common;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
mod common;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
mod common;
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate rocket;
|
||||
extern crate serde_json;
|
||||
#[macro_use] extern crate serde_derive;
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket_contrib;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use std::io::Cursor;
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket_contrib;
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
#[macro_use] extern crate serde_derive;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
10
examples/hello_2018/Cargo.toml
Normal file
10
examples/hello_2018/Cargo.toml
Normal file
@ -0,0 +1,10 @@
|
||||
[package]
|
||||
name = "hello_2018"
|
||||
version = "0.0.0"
|
||||
workspace = "../../"
|
||||
publish = false
|
||||
edition = "2018"
|
||||
|
||||
[dependencies]
|
||||
rocket = { path = "../../core/lib" }
|
||||
rocket_codegen = { path = "../../core/codegen" }
|
16
examples/hello_2018/src/main.rs
Normal file
16
examples/hello_2018/src/main.rs
Normal file
@ -0,0 +1,16 @@
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
use rocket;
|
||||
use rocket::routes;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
#[get("/")]
|
||||
fn hello() -> &'static str {
|
||||
"Hello, Rust 2018!"
|
||||
}
|
||||
|
||||
fn main() {
|
||||
rocket::ignite().mount("/", routes![hello]).launch();
|
||||
}
|
11
examples/hello_2018/src/tests.rs
Normal file
11
examples/hello_2018/src/tests.rs
Normal file
@ -0,0 +1,11 @@
|
||||
use rocket;
|
||||
use rocket::routes;
|
||||
use rocket::local::Client;
|
||||
|
||||
#[test]
|
||||
fn hello_world() {
|
||||
let rocket = rocket::ignite().mount("/", routes![super::hello]);
|
||||
let client = Client::new(rocket).unwrap();
|
||||
let mut response = client.get("/").dispatch();
|
||||
assert_eq!(response.body_string(), Some("Hello, Rust 2018!".into()));
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
#[macro_use] extern crate rocket_contrib;
|
||||
#[macro_use] extern crate serde_derive;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate crossbeam;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
extern crate rocket_contrib;
|
||||
#[macro_use] extern crate serde_derive;
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
extern crate rocket;
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests;
|
||||
|
@ -1,6 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate rocket;
|
||||
extern crate rand;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::http::RawStr;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
extern crate rusqlite;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro, never_type)]
|
||||
#![feature(plugin, decl_macro, never_type, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use rocket::request::{self, Request, FromRequest};
|
||||
use rocket::outcome::Outcome::*;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro, never_type)]
|
||||
#![feature(plugin, decl_macro, never_type, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro, never_type)]
|
||||
#![feature(plugin, decl_macro, never_type, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket_contrib;
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,8 +1,8 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket_contrib;
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
extern crate serde_json;
|
||||
#[macro_use] extern crate serde_derive;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[get("/")]
|
||||
fn hello() -> &'static str {
|
||||
|
@ -1,7 +1,7 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
|
||||
#[cfg(test)] mod tests;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
#![feature(plugin, decl_macro, custom_derive)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use] extern crate rocket;
|
||||
|
@ -1,10 +1,10 @@
|
||||
#![feature(plugin, decl_macro)]
|
||||
#![feature(plugin, decl_macro, proc_macro_non_items)]
|
||||
#![plugin(rocket_codegen)]
|
||||
|
||||
#[macro_use]
|
||||
extern crate lazy_static;
|
||||
extern crate uuid;
|
||||
extern crate rocket;
|
||||
#[macro_use] extern crate rocket;
|
||||
extern crate rocket_contrib;
|
||||
|
||||
use std::collections::HashMap;
|
||||
|
Loading…
Reference in New Issue
Block a user