mirror of
https://github.com/tokio-rs/axum.git
synced 2025-01-01 08:56:15 +01:00
Annotate panicking functions with #[track_caller]
(#1248)
This commit is contained in:
parent
50a4be999d
commit
6cd356690d
3 changed files with 17 additions and 1 deletions
|
@ -42,8 +42,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
relaxed so the response type must implement `IntoResponse` rather than being a
|
relaxed so the response type must implement `IntoResponse` rather than being a
|
||||||
literal `Response`
|
literal `Response`
|
||||||
- **change:** axum's MSRV is now 1.60 ([#1239])
|
- **change:** axum's MSRV is now 1.60 ([#1239])
|
||||||
|
- **fixed:** Annotate panicking functions with `#[track_caller]` so the error
|
||||||
|
message points to where the user added the invalid router, rather than
|
||||||
|
somewhere internally in axum ([#1248])
|
||||||
|
|
||||||
[#1171]: https://github.com/tokio-rs/axum/pull/1171
|
|
||||||
[#1077]: https://github.com/tokio-rs/axum/pull/1077
|
[#1077]: https://github.com/tokio-rs/axum/pull/1077
|
||||||
[#1086]: https://github.com/tokio-rs/axum/pull/1086
|
[#1086]: https://github.com/tokio-rs/axum/pull/1086
|
||||||
[#1088]: https://github.com/tokio-rs/axum/pull/1088
|
[#1088]: https://github.com/tokio-rs/axum/pull/1088
|
||||||
|
@ -52,7 +54,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
[#1130]: https://github.com/tokio-rs/axum/pull/1130
|
[#1130]: https://github.com/tokio-rs/axum/pull/1130
|
||||||
[#1135]: https://github.com/tokio-rs/axum/pull/1135
|
[#1135]: https://github.com/tokio-rs/axum/pull/1135
|
||||||
[#1152]: https://github.com/tokio-rs/axum/pull/1152
|
[#1152]: https://github.com/tokio-rs/axum/pull/1152
|
||||||
|
[#1171]: https://github.com/tokio-rs/axum/pull/1171
|
||||||
[#1239]: https://github.com/tokio-rs/axum/pull/1239
|
[#1239]: https://github.com/tokio-rs/axum/pull/1239
|
||||||
|
[#1248]: https://github.com/tokio-rs/axum/pull/1248
|
||||||
[#924]: https://github.com/tokio-rs/axum/pull/924
|
[#924]: https://github.com/tokio-rs/axum/pull/924
|
||||||
|
|
||||||
# 0.5.10 (28. June, 2022)
|
# 0.5.10 (28. June, 2022)
|
||||||
|
|
|
@ -205,6 +205,7 @@ macro_rules! chained_service_fn {
|
||||||
$name:ident, $method:ident
|
$name:ident, $method:ident
|
||||||
) => {
|
) => {
|
||||||
$(#[$m])+
|
$(#[$m])+
|
||||||
|
#[track_caller]
|
||||||
pub fn $name<S>(self, svc: S) -> Self
|
pub fn $name<S>(self, svc: S) -> Self
|
||||||
where
|
where
|
||||||
S: Service<Request<ReqBody>, Error = E>
|
S: Service<Request<ReqBody>, Error = E>
|
||||||
|
@ -268,6 +269,7 @@ macro_rules! chained_handler_fn {
|
||||||
$name:ident, $method:ident
|
$name:ident, $method:ident
|
||||||
) => {
|
) => {
|
||||||
$(#[$m])+
|
$(#[$m])+
|
||||||
|
#[track_caller]
|
||||||
pub fn $name<H, T>(self, handler: H) -> Self
|
pub fn $name<H, T>(self, handler: H) -> Self
|
||||||
where
|
where
|
||||||
H: Handler<T, B>,
|
H: Handler<T, B>,
|
||||||
|
@ -577,6 +579,7 @@ where
|
||||||
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
|
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
|
||||||
/// # };
|
/// # };
|
||||||
/// ```
|
/// ```
|
||||||
|
#[track_caller]
|
||||||
pub fn on<H, T>(self, filter: MethodFilter, handler: H) -> Self
|
pub fn on<H, T>(self, filter: MethodFilter, handler: H) -> Self
|
||||||
where
|
where
|
||||||
H: Handler<T, B>,
|
H: Handler<T, B>,
|
||||||
|
@ -689,6 +692,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
|
||||||
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
|
/// # axum::Server::bind(&"".parse().unwrap()).serve(app.into_make_service()).await.unwrap();
|
||||||
/// # };
|
/// # };
|
||||||
/// ```
|
/// ```
|
||||||
|
#[track_caller]
|
||||||
pub fn on_service<S>(self, filter: MethodFilter, svc: S) -> Self
|
pub fn on_service<S>(self, filter: MethodFilter, svc: S) -> Self
|
||||||
where
|
where
|
||||||
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,
|
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,
|
||||||
|
@ -783,8 +787,10 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[doc = include_str!("../docs/method_routing/merge.md")]
|
#[doc = include_str!("../docs/method_routing/merge.md")]
|
||||||
|
#[track_caller]
|
||||||
pub fn merge(mut self, other: MethodRouter<ReqBody, E>) -> Self {
|
pub fn merge(mut self, other: MethodRouter<ReqBody, E>) -> Self {
|
||||||
// written using inner functions to generate less IR
|
// written using inner functions to generate less IR
|
||||||
|
#[track_caller]
|
||||||
fn merge_inner<T>(name: &str, first: Option<T>, second: Option<T>) -> Option<T> {
|
fn merge_inner<T>(name: &str, first: Option<T>, second: Option<T>) -> Option<T> {
|
||||||
match (first, second) {
|
match (first, second) {
|
||||||
(Some(_), Some(_)) => panic!(
|
(Some(_), Some(_)) => panic!(
|
||||||
|
@ -796,6 +802,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn merge_fallback<B, E>(
|
fn merge_fallback<B, E>(
|
||||||
fallback: Fallback<B, E>,
|
fallback: Fallback<B, E>,
|
||||||
fallback_other: Fallback<B, E>,
|
fallback_other: Fallback<B, E>,
|
||||||
|
@ -843,6 +850,7 @@ impl<ReqBody, E> MethodRouter<ReqBody, E> {
|
||||||
self.layer(HandleErrorLayer::new(f))
|
self.layer(HandleErrorLayer::new(f))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn on_service_boxed_response_body<S>(mut self, filter: MethodFilter, svc: S) -> Self
|
fn on_service_boxed_response_body<S>(mut self, filter: MethodFilter, svc: S) -> Self
|
||||||
where
|
where
|
||||||
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,
|
S: Service<Request<ReqBody>, Error = E> + Clone + Send + 'static,
|
||||||
|
|
|
@ -114,6 +114,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
#[doc = include_str!("../docs/routing/route.md")]
|
#[doc = include_str!("../docs/routing/route.md")]
|
||||||
|
#[track_caller]
|
||||||
pub fn route<T>(mut self, path: &str, service: T) -> Self
|
pub fn route<T>(mut self, path: &str, service: T) -> Self
|
||||||
where
|
where
|
||||||
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
|
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
|
||||||
|
@ -167,6 +168,7 @@ where
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn set_node(&mut self, path: &str, id: RouteId) {
|
fn set_node(&mut self, path: &str, id: RouteId) {
|
||||||
let mut node =
|
let mut node =
|
||||||
Arc::try_unwrap(Arc::clone(&self.node)).unwrap_or_else(|node| (*node).clone());
|
Arc::try_unwrap(Arc::clone(&self.node)).unwrap_or_else(|node| (*node).clone());
|
||||||
|
@ -177,6 +179,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
#[doc = include_str!("../docs/routing/nest.md")]
|
#[doc = include_str!("../docs/routing/nest.md")]
|
||||||
|
#[track_caller]
|
||||||
pub fn nest<T>(mut self, mut path: &str, svc: T) -> Self
|
pub fn nest<T>(mut self, mut path: &str, svc: T) -> Self
|
||||||
where
|
where
|
||||||
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
|
T: Service<Request<B>, Error = Infallible> + Clone + Send + 'static,
|
||||||
|
@ -216,6 +219,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
#[doc = include_str!("../docs/routing/merge.md")]
|
#[doc = include_str!("../docs/routing/merge.md")]
|
||||||
|
#[track_caller]
|
||||||
pub fn merge<R>(mut self, other: R) -> Self
|
pub fn merge<R>(mut self, other: R) -> Self
|
||||||
where
|
where
|
||||||
R: Into<Router<B>>,
|
R: Into<Router<B>>,
|
||||||
|
|
Loading…
Reference in a new issue