diff --git a/ntex-async-std/CHANGES.md b/ntex-async-std/CHANGES.md index 76fa11ad..f9e11732 100644 --- a/ntex-async-std/CHANGES.md +++ b/ntex-async-std/CHANGES.md @@ -1,5 +1,9 @@ # Changes +## [0.3.1] - 2023-11-12 + +* Optimize io read task + ## [0.3.0] - 2023-06-22 * Release v0.3.0 diff --git a/ntex-async-std/Cargo.toml b/ntex-async-std/Cargo.toml index 6a3844b1..0ca99640 100644 --- a/ntex-async-std/Cargo.toml +++ b/ntex-async-std/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "ntex-async-std" -version = "0.3.0" +version = "0.3.1" authors = ["ntex contributors "] description = "async-std intergration for ntex framework" keywords = ["network", "framework", "async", "futures"] @@ -16,9 +16,9 @@ name = "ntex_async_std" path = "src/lib.rs" [dependencies] -ntex-bytes = "0.1.19" -ntex-io = "0.3.0" -ntex-util = "0.3.0" +ntex-bytes = "0.1.21" +ntex-io = "0.3.6" +ntex-util = "0.3.4" async-oneshot = "0.5.0" log = "0.4" pin-project-lite = "0.2" diff --git a/ntex-async-std/src/io.rs b/ntex-async-std/src/io.rs index fb2a603b..8c9a2aa7 100644 --- a/ntex-async-std/src/io.rs +++ b/ntex-async-std/src/io.rs @@ -50,9 +50,9 @@ impl Future for ReadTask { fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll { let this = self.as_ref(); - this.state.with_buf(|buf, hw, lw| { - match ready!(this.state.poll_ready(cx)) { - ReadStatus::Ready => { + match ready!(this.state.poll_ready(cx)) { + ReadStatus::Ready => { + this.state.with_buf(|buf, hw, lw| { // read data from socket let mut io = self.io.borrow_mut(); loop { @@ -80,13 +80,13 @@ impl Future for ReadTask { } }; } - } - ReadStatus::Terminate => { - log::trace!("read task is instructed to shutdown"); - Poll::Ready(Ok(())) - } + }) } - }) + ReadStatus::Terminate => { + log::trace!("read task is instructed to shutdown"); + Poll::Ready(()) + } + } } } diff --git a/ntex/Cargo.toml b/ntex/Cargo.toml index 21945300..3fbe6926 100644 --- a/ntex/Cargo.toml +++ b/ntex/Cargo.toml @@ -60,9 +60,9 @@ ntex-h2 = "0.4.4" ntex-rt = "0.4.10" ntex-io = "0.3.6" ntex-tls = "0.3.2" -ntex-tokio = { version = "0.3.0", optional = true } +ntex-tokio = { version = "0.3.1", optional = true } ntex-glommio = { version = "0.3.0", optional = true } -ntex-async-std = { version = "0.3.0", optional = true } +ntex-async-std = { version = "0.3.1", optional = true } async-oneshot = "0.5" async-channel = "2.0"