Remove boxed futures in server, use async fn.

This commit is contained in:
Sergio Benitez 2021-03-10 16:31:32 -08:00
parent 88cb6ec4d1
commit 191b93498e

View File

@ -3,7 +3,7 @@ use std::sync::Arc;
use std::panic::AssertUnwindSafe;
use futures::stream::StreamExt;
use futures::future::{Future, FutureExt, BoxFuture};
use futures::future::FutureExt;
use tokio::sync::oneshot;
use yansi::Paint;
@ -221,37 +221,30 @@ impl Rocket {
response
}
/// Route the request and process the outcome to eventually get a response.
fn route_and_process<'s, 'r: 's>(
async fn route_and_process<'s, 'r: 's>(
&'s self,
request: &'r Request<'s>,
data: Data
) -> impl Future<Output = Response<'r>> + Send + 's {
async move {
) -> Response<'r> {
let mut response = match self.route(request, data).await {
Outcome::Success(response) => response,
Outcome::Forward(data) => {
// There was no matching route. Autohandle `HEAD` requests.
if request.method() == Method::Head {
Outcome::Forward(data) if request.method() == Method::Head => {
info_!("Autohandling {} request.", Paint::default("HEAD").bold());
// Dispatch the request again with Method `GET`.
request._set_method(Method::Get);
// Return early so we don't set cookies twice.
let try_next: BoxFuture<'_, _> =
Box::pin(self.route_and_process(request, data));
return try_next.await;
} else {
// No match was found and it can't be autohandled. 404.
self.handle_error(Status::NotFound, request).await
match self.route(request, data).await {
Outcome::Success(response) => response,
Outcome::Failure(status) => self.handle_error(status, request).await,
Outcome::Forward(_) => self.handle_error(Status::NotFound, request).await,
}
}
Outcome::Forward(_) => self.handle_error(Status::NotFound, request).await,
Outcome::Failure(status) => self.handle_error(status, request).await,
};
// Set the cookies. Note that error responses will only include
// cookies set by the error handler. See `handle_error` for more.
// Set the cookies. Note that error responses will only include cookies
// set by the error handler. See `handle_error` for more.
let delta_jar = request.cookies().take_delta_jar();
for cookie in delta_jar.delta() {
response.adjoin_header(cookie);
@ -259,7 +252,6 @@ impl Rocket {
response
}
}
/// Tries to find a `Responder` for a given `request`. It does this by
/// routing the request and calling the handler for each matching route
@ -267,12 +259,11 @@ impl Rocket {
/// additional routes to try (forward). The corresponding outcome for each
/// condition is returned.
#[inline]
fn route<'s, 'r: 's>(
async fn route<'s, 'r: 's>(
&'s self,
request: &'r Request<'s>,
mut data: Data,
) -> impl Future<Output = handler::Outcome<'r>> + 's {
async move {
) -> handler::Outcome<'r> {
// Go through the list of matching routes until we fail or succeed.
let matches = self.router.route(request);
for route in matches {
@ -298,7 +289,6 @@ impl Rocket {
error_!("No matching routes for {}.", request);
Outcome::Forward(data)
}
}
/// Invokes the handler with `req` for catcher with status `status`.
///