From 6c8bd0449abf5fa35991cb043c89e96c5c85ead5 Mon Sep 17 00:00:00 2001 From: Fangdun Tsai Date: Sat, 16 Dec 2023 07:48:08 +0800 Subject: [PATCH] chore(viz): tweak Responder::serve --- viz/src/responder.rs | 47 +++++++++++++++++++++----------------------- 1 file changed, 22 insertions(+), 25 deletions(-) diff --git a/viz/src/responder.rs b/viz/src/responder.rs index fa6fce1d..43959f94 100644 --- a/viz/src/responder.rs +++ b/viz/src/responder.rs @@ -27,31 +27,28 @@ impl Responder { ) -> Result { let method = req.method().clone(); let path = req.uri().path().to_owned(); - let responded = Ok( - match tree.find(&method, &path).or_else(|| { - if method == Method::HEAD { - tree.find(&Method::GET, &path) - } else { - None - } - }) { - Some((handler, route)) => { - req.extensions_mut().insert(addr); - req.extensions_mut().insert(Arc::from(RouteInfo { - id: *route.id, - pattern: route.pattern(), - params: Into::::into(route.params()), - })); - // req.set_state(tree.clone()); - handler - .call(req.map(Some).map(IncomingBody::new)) - .await - .unwrap_or_else(IntoResponse::into_response) - } - None => StatusCode::NOT_FOUND.into_response(), - }, - ); - responded + + let Some((handler, route)) = tree.find(&method, &path).or_else(|| { + if method == Method::HEAD { + tree.find(&Method::GET, &path) + } else { + None + } + }) else { + return Ok(StatusCode::NOT_FOUND.into_response()); + }; + + req.extensions_mut().insert(addr); + req.extensions_mut().insert(Arc::from(RouteInfo { + id: *route.id, + pattern: route.pattern(), + params: Into::::into(route.params()), + })); + // req.set_state(tree.clone()); + Ok(handler + .call(req.map(Some).map(IncomingBody::new)) + .await + .unwrap_or_else(IntoResponse::into_response)) } }