From 21fb5f4d22bf33a8750e8b0da1d8905fd864eadb Mon Sep 17 00:00:00 2001 From: Alexander Jackson Date: Thu, 22 Jun 2023 22:51:52 +0100 Subject: [PATCH] Allow unreachable code in `#[debug_handler]` (#2014) Co-authored-by: David Pedersen --- axum-macros/src/debug_handler.rs | 8 ++++++++ .../tests/debug_handler/pass/deny_unreachable_code.rs | 8 ++++++++ 2 files changed, 16 insertions(+) create mode 100644 axum-macros/tests/debug_handler/pass/deny_unreachable_code.rs diff --git a/axum-macros/src/debug_handler.rs b/axum-macros/src/debug_handler.rs index 9b42a1af90..dcd292b1e1 100644 --- a/axum-macros/src/debug_handler.rs +++ b/axum-macros/src/debug_handler.rs @@ -276,6 +276,7 @@ fn check_inputs_impls_from_request( quote_spanned! {span=> #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] fn #check_fn #check_fn_generics() where @@ -285,6 +286,7 @@ fn check_inputs_impls_from_request( // we have to call the function to actually trigger a compile error // since the function is generic, just defining it is not enough #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] fn #call_check_fn() { @@ -429,6 +431,7 @@ fn check_output_impls_into_response(item_fn: &ItemFn) -> TokenStream { let make = if item_fn.sig.asyncness.is_some() { quote_spanned! {span=> #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] async fn #make_value_name() -> #ty { #declare_inputs @@ -438,6 +441,7 @@ fn check_output_impls_into_response(item_fn: &ItemFn) -> TokenStream { } else { quote_spanned! {span=> #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] fn #make_value_name() -> #ty { #declare_inputs @@ -453,6 +457,7 @@ fn check_output_impls_into_response(item_fn: &ItemFn) -> TokenStream { #make #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] async fn #name() { let value = #receiver #make_value_name().await; @@ -465,6 +470,7 @@ fn check_output_impls_into_response(item_fn: &ItemFn) -> TokenStream { } else { quote_spanned! {span=> #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] async fn #name() { #make @@ -515,6 +521,7 @@ fn check_future_send(item_fn: &ItemFn) -> TokenStream { if let Some(receiver) = self_receiver(item_fn) { quote! { #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] fn #name() { let future = #receiver #handler_name(#(#args),*); @@ -524,6 +531,7 @@ fn check_future_send(item_fn: &ItemFn) -> TokenStream { } else { quote! { #[allow(warnings)] + #[allow(unreachable_code)] #[doc(hidden)] fn #name() { #item_fn diff --git a/axum-macros/tests/debug_handler/pass/deny_unreachable_code.rs b/axum-macros/tests/debug_handler/pass/deny_unreachable_code.rs new file mode 100644 index 0000000000..1ccbc6e01e --- /dev/null +++ b/axum-macros/tests/debug_handler/pass/deny_unreachable_code.rs @@ -0,0 +1,8 @@ +#![deny(unreachable_code)] + +use axum::extract::Path; + +#[axum_macros::debug_handler] +async fn handler(Path(_): Path) {} + +fn main() {}