mirror of
https://github.com/tokio-rs/axum.git
synced 2024-12-02 04:56:53 +01:00
d5de3bc7e3
* Improve `debug_handler` to use the correct span for specific bounds This results in better localised error messages, as they now point directly to the corresponding argument instead of to the macro itself. * Improve some error messages behind a `nightly-error-messages` feature flag This uses the nightly only `rustc_on_unimplemented` attribute to improve some error messages when users try to use invalid handler functions. This should be seen as prove of concept, not as full solution for all potential error cases. The underlying feature is currently marked as permanently unstable, but I'm working on getting this specific attribute (or an attribute with different name, similar functionality) ready to work on a stable compiler. * Apply suggestions from code review Co-authored-by: Jonas Platte <jplatte+git@posteo.de> * Enable the `nightly-error-messages` feature unconditionally for nightly compilers * Use a nightly compiler to run the axum-marcos compile fail tests * update to newer nightly * Run axum-macros tests on nightly * tweak compile error hints a bit * more tweaks * update test Co-authored-by: Jonas Platte <jplatte+git@posteo.de> Co-authored-by: David Pedersen <david.pdrsn@gmail.com>
22 lines
1.3 KiB
Text
22 lines
1.3 KiB
Text
error: #[derive(FromRequest)] only supports generics when used with #[from_request(via)]
|
|
--> tests/from_request/fail/generic_without_via_rejection.rs:6:18
|
|
|
|
|
6 | struct Extractor<T>(T);
|
|
| ^
|
|
|
|
error[E0277]: the trait bound `fn(Extractor<()>) -> impl Future<Output = ()> {foo}: Handler<_, _, _>` is not satisfied
|
|
--> tests/from_request/fail/generic_without_via_rejection.rs:11:46
|
|
|
|
|
11 | Router::<(), Body>::new().route("/", get(foo));
|
|
| --- ^^^ the trait `Handler<_, _, _>` is not implemented for fn item `fn(Extractor<()>) -> impl Future<Output = ()> {foo}`
|
|
| |
|
|
| required by a bound introduced by this call
|
|
|
|
|
= note: Consider using `#[axum::debug_handler]` to improve the error message
|
|
= help: the trait `Handler<T, S, B2>` is implemented for `Layered<L, H, T, S, B, B2>`
|
|
note: required by a bound in `axum::routing::get`
|
|
--> $WORKSPACE/axum/src/routing/method_routing.rs
|
|
|
|
|
| top_level_handler_fn!(get, GET);
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `axum::routing::get`
|
|
= note: this error originates in the macro `top_level_handler_fn` (in Nightly builds, run with -Z macro-backtrace for more info)
|