2个版本
0.1.1 | 2019年6月30日 |
---|---|
0.1.0 | 2019年6月30日 |
#2434 in 解析器实现
在rooty_derive中使用
5KB
这是一个Rust库,用于以声明式方式编写Web路由,然后解析和格式化URL。
有关proc宏的说明,请参阅rooty_derive::Routes
的文档。
该特性为解析和格式化添加了一些基本的封装,以防您希望为您的Routes
类型实现不同的Display
和FromStr
。
示例
完整示例
use chrono::NaiveDate;
use rooty::{NotFound, Routes};
use std::str::FromStr;
#[derive(Debug, Routes)]
pub enum MyRoutes {
#[route = "/"]
Home,
#[route = "/about"]
About,
#[route = "/users/{id}"]
User { id: i32 },
#[route = "/posts/{date}"]
Posts { date: NaiveDate },
#[route = "/post/{title}"]
Post { title: String },
}
fn main() {
assert_eq!(MyRoutes::Home.url().to_string(), "/");
assert_eq!(MyRoutes::About.url().to_string(), "/about");
assert_eq!(MyRoutes::User { id: 32 }.url().to_string(), "/users/32");
assert_eq!(
MyRoutes::Posts {
date: NaiveDate::from_str("2018-12-11").unwrap()
}
.url().to_string(),
"/posts/2018-12-11"
);
assert_eq!(
MyRoutes::Post {
title: "my_post_title".into()
}
.url().to_string(),
"/post/my_post_title"
);
println!("{:?}", MyRoutes::parse_url("/post/my_post"));
println!("{:?}", MyRoutes::parse_url("/posts/2012-12-07"));
assert!(MyRoutes::parse_url("/a/made/up/url").is_err());
}
依赖项
~2MB
~46K SLoC