mirror of
https://github.com/tokio-rs/axum.git
synced 2025-01-11 12:31:25 +01:00
Further compile time improvements (#220)
This improves compiles further when using lots of nested routes. Such as the example posted [here](https://github.com/tokio-rs/axum/issues/200#issuecomment-902541073). It seems rustc is really slow at checking bounds on these kinds of intermediate builder methods. Should probably file an issue about that.
This commit is contained in:
parent
be61b8c611
commit
e8bc3f5082
2 changed files with 15 additions and 19 deletions
|
@ -119,10 +119,7 @@ impl<S> Router<S> {
|
|||
/// # Panics
|
||||
///
|
||||
/// Panics if `description` doesn't start with `/`.
|
||||
pub fn route<T, B>(self, description: &str, svc: T) -> Router<Route<T, S>>
|
||||
where
|
||||
T: Service<Request<B>> + Clone,
|
||||
{
|
||||
pub fn route<T>(self, description: &str, svc: T) -> Router<Route<T, S>> {
|
||||
self.map(|fallback| Route {
|
||||
pattern: PathPattern::new(description),
|
||||
svc,
|
||||
|
@ -207,10 +204,7 @@ impl<S> Router<S> {
|
|||
/// If necessary you can use [`Router::boxed`] to box a group of routes
|
||||
/// making the type easier to name. This is sometimes useful when working with
|
||||
/// `nest`.
|
||||
pub fn nest<T, B>(self, description: &str, svc: T) -> Router<Nested<T, S>>
|
||||
where
|
||||
T: Service<Request<B>> + Clone,
|
||||
{
|
||||
pub fn nest<T>(self, description: &str, svc: T) -> Router<Nested<T, S>> {
|
||||
self.map(|fallback| Nested {
|
||||
pattern: PathPattern::new(description),
|
||||
svc,
|
||||
|
|
|
@ -132,24 +132,26 @@ async fn handler_multiple_methods_last() {
|
|||
|
||||
#[test]
|
||||
fn service_propagates_errors() {
|
||||
let app = Router::new().route::<_, Body>("/echo", service::post(Svc));
|
||||
let app = Router::new().route("/echo", service::post::<_, Body>(Svc));
|
||||
|
||||
check_make_svc::<_, _, _, hyper::Error>(app.into_make_service());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn service_nested_propagates_errors() {
|
||||
let app =
|
||||
Router::new().route::<_, Body>("/echo", Router::new().nest("/foo", service::post(Svc)));
|
||||
let app = Router::new().route(
|
||||
"/echo",
|
||||
Router::new().nest("/foo", service::post::<_, Body>(Svc)),
|
||||
);
|
||||
|
||||
check_make_svc::<_, _, _, hyper::Error>(app.into_make_service());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn service_handle_on_method() {
|
||||
let app = Router::new().route::<_, Body>(
|
||||
let app = Router::new().route(
|
||||
"/echo",
|
||||
service::get(Svc).handle_error(handle_error::<hyper::Error>),
|
||||
service::get::<_, Body>(Svc).handle_error(handle_error::<hyper::Error>),
|
||||
);
|
||||
|
||||
check_make_svc::<_, _, _, Infallible>(app.into_make_service());
|
||||
|
@ -157,9 +159,9 @@ fn service_handle_on_method() {
|
|||
|
||||
#[test]
|
||||
fn service_handle_on_method_multiple() {
|
||||
let app = Router::new().route::<_, Body>(
|
||||
let app = Router::new().route(
|
||||
"/echo",
|
||||
service::get(Svc)
|
||||
service::get::<_, Body>(Svc)
|
||||
.post(Svc)
|
||||
.handle_error(handle_error::<hyper::Error>),
|
||||
);
|
||||
|
@ -170,7 +172,7 @@ fn service_handle_on_method_multiple() {
|
|||
#[test]
|
||||
fn service_handle_on_router() {
|
||||
let app = Router::new()
|
||||
.route::<_, Body>("/echo", service::get(Svc))
|
||||
.route("/echo", service::get::<_, Body>(Svc))
|
||||
.handle_error(handle_error::<hyper::Error>);
|
||||
|
||||
check_make_svc::<_, _, _, Infallible>(app.into_make_service());
|
||||
|
@ -179,7 +181,7 @@ fn service_handle_on_router() {
|
|||
#[test]
|
||||
fn service_handle_on_router_still_impls_routing_dsl() {
|
||||
let app = Router::new()
|
||||
.route::<_, Body>("/echo", service::get(Svc))
|
||||
.route("/echo", service::get::<_, Body>(Svc))
|
||||
.handle_error(handle_error::<hyper::Error>)
|
||||
.route("/", get(unit));
|
||||
|
||||
|
@ -189,7 +191,7 @@ fn service_handle_on_router_still_impls_routing_dsl() {
|
|||
#[test]
|
||||
fn layered() {
|
||||
let app = Router::new()
|
||||
.route::<_, Body>("/echo", get(unit))
|
||||
.route("/echo", get::<_, Body, _>(unit))
|
||||
.layer(timeout())
|
||||
.handle_error(handle_error::<BoxError>);
|
||||
|
||||
|
@ -199,7 +201,7 @@ fn layered() {
|
|||
#[tokio::test] // async because of `.boxed()`
|
||||
async fn layered_boxed() {
|
||||
let app = Router::new()
|
||||
.route::<_, Body>("/echo", get(unit))
|
||||
.route("/echo", get::<_, Body, _>(unit))
|
||||
.layer(timeout())
|
||||
.boxed()
|
||||
.handle_error(handle_error::<BoxError>);
|
||||
|
|
Loading…
Reference in a new issue