diff --git a/src/body/incoming.rs b/src/body/incoming.rs index 72af126c20..628911d792 100644 --- a/src/body/incoming.rs +++ b/src/body/incoming.rs @@ -7,6 +7,11 @@ use std::task::{Context, Poll}; use bytes::Bytes; #[cfg(all(feature = "http1", any(feature = "client", feature = "server")))] use futures_channel::{mpsc, oneshot}; +#[cfg(all( + any(feature = "http1", feature = "http2"), + any(feature = "client", feature = "server") +))] +use futures_util::ready; #[cfg(all(feature = "http1", any(feature = "client", feature = "server")))] use futures_util::{stream::FusedStream, Stream}; // for mpsc::Receiver #[cfg(all(feature = "http1", any(feature = "client", feature = "server")))] diff --git a/src/client/conn/http1.rs b/src/client/conn/http1.rs index 4d1fed3a31..b85f5d4b9e 100644 --- a/src/client/conn/http1.rs +++ b/src/client/conn/http1.rs @@ -8,6 +8,7 @@ use std::task::{Context, Poll}; use crate::rt::{Read, Write}; use bytes::Bytes; +use futures_util::ready; use http::{Request, Response}; use httparse::ParserConfig; diff --git a/src/client/conn/http2.rs b/src/client/conn/http2.rs index 4153ec044e..32c3a36b9f 100644 --- a/src/client/conn/http2.rs +++ b/src/client/conn/http2.rs @@ -10,6 +10,7 @@ use std::task::{Context, Poll}; use std::time::Duration; use crate::rt::{Read, Write}; +use futures_util::ready; use http::{Request, Response}; use super::super::dispatch; diff --git a/src/common/mod.rs b/src/common/mod.rs index 57b66e1f9f..e52835ddd4 100644 --- a/src/common/mod.rs +++ b/src/common/mod.rs @@ -1,16 +1,3 @@ -#[cfg(all( - any(feature = "client", feature = "server"), - any(feature = "http1", feature = "http2") -))] -macro_rules! ready { - ($e:expr) => { - match $e { - std::task::Poll::Ready(v) => v, - std::task::Poll::Pending => return std::task::Poll::Pending, - } - }; -} - #[cfg(all(any(feature = "client", feature = "server"), feature = "http1"))] pub(crate) mod buf; #[cfg(all(feature = "server", any(feature = "http1", feature = "http2")))] diff --git a/src/lib.rs b/src/lib.rs index 372adeeeba..23087a0efe 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -106,9 +106,8 @@ mod cfg; #[macro_use] mod trace; -#[macro_use] -mod common; pub mod body; +mod common; mod error; pub mod ext; #[cfg(test)] diff --git a/src/proto/h1/conn.rs b/src/proto/h1/conn.rs index 233d8cfffb..36283a3740 100644 --- a/src/proto/h1/conn.rs +++ b/src/proto/h1/conn.rs @@ -8,6 +8,7 @@ use std::time::Duration; use crate::rt::{Read, Write}; use bytes::{Buf, Bytes}; +use futures_util::ready; use http::header::{HeaderValue, CONNECTION, TE}; use http::{HeaderMap, Method, Version}; use httparse::ParserConfig; diff --git a/src/proto/h1/decode.rs b/src/proto/h1/decode.rs index 4e316a7f78..e5b1826fa0 100644 --- a/src/proto/h1/decode.rs +++ b/src/proto/h1/decode.rs @@ -5,6 +5,7 @@ use std::task::{Context, Poll}; use std::usize; use bytes::Bytes; +use futures_util::ready; use super::io::MemRead; use super::DecodedLength; diff --git a/src/proto/h1/dispatch.rs b/src/proto/h1/dispatch.rs index 2256790bfb..3a4faf0487 100644 --- a/src/proto/h1/dispatch.rs +++ b/src/proto/h1/dispatch.rs @@ -8,6 +8,7 @@ use std::{ use crate::rt::{Read, Write}; use bytes::{Buf, Bytes}; +use futures_util::ready; use http::Request; use super::{Http1Transaction, Wants}; diff --git a/src/proto/h1/io.rs b/src/proto/h1/io.rs index d0c0cba3bf..9f23ac16ff 100644 --- a/src/proto/h1/io.rs +++ b/src/proto/h1/io.rs @@ -10,6 +10,7 @@ use std::task::{Context, Poll}; use crate::rt::{Read, ReadBuf, Write}; use bytes::{Buf, BufMut, Bytes, BytesMut}; +use futures_util::ready; use super::{Http1Transaction, ParseContext, ParsedMessage}; use crate::common::buf::BufList; diff --git a/src/proto/h2/client.rs b/src/proto/h2/client.rs index b5ef4d8b74..7929f7c680 100644 --- a/src/proto/h2/client.rs +++ b/src/proto/h2/client.rs @@ -12,6 +12,7 @@ use bytes::Bytes; use futures_channel::mpsc::{Receiver, Sender}; use futures_channel::{mpsc, oneshot}; use futures_util::future::{Either, FusedFuture, FutureExt as _}; +use futures_util::ready; use futures_util::stream::{StreamExt as _, StreamFuture}; use h2::client::{Builder, Connection, SendRequest}; use h2::SendStream; diff --git a/src/proto/h2/mod.rs b/src/proto/h2/mod.rs index 15afe48d23..b344f84cbb 100644 --- a/src/proto/h2/mod.rs +++ b/src/proto/h2/mod.rs @@ -6,6 +6,7 @@ use std::pin::Pin; use std::task::{Context, Poll}; use bytes::{Buf, Bytes}; +use futures_util::ready; use h2::{Reason, RecvStream, SendStream}; use http::header::{HeaderName, CONNECTION, TE, TRAILER, TRANSFER_ENCODING, UPGRADE}; use http::HeaderMap; diff --git a/src/proto/h2/server.rs b/src/proto/h2/server.rs index 33f76344cc..e2890b306d 100644 --- a/src/proto/h2/server.rs +++ b/src/proto/h2/server.rs @@ -6,6 +6,7 @@ use std::task::{Context, Poll}; use std::time::Duration; use bytes::Bytes; +use futures_util::ready; use h2::server::{Connection, Handshake, SendResponse}; use h2::{Reason, RecvStream}; use http::{Method, Request}; diff --git a/src/server/conn/http1.rs b/src/server/conn/http1.rs index 673d4f280b..e3eff1a02d 100644 --- a/src/server/conn/http1.rs +++ b/src/server/conn/http1.rs @@ -12,6 +12,7 @@ use std::time::Duration; use crate::rt::{Read, Write}; use crate::upgrade::Upgraded; use bytes::Bytes; +use futures_util::ready; use crate::body::{Body, Incoming as IncomingBody}; use crate::proto; diff --git a/src/server/conn/http2.rs b/src/server/conn/http2.rs index a4fd1ede4f..d0117b65fe 100644 --- a/src/server/conn/http2.rs +++ b/src/server/conn/http2.rs @@ -10,6 +10,7 @@ use std::task::{Context, Poll}; use std::time::Duration; use crate::rt::{Read, Write}; +use futures_util::ready; use pin_project_lite::pin_project; use crate::body::{Body, Incoming as IncomingBody};