2
0
Fork 1
mirror of https://github.com/async-rs/async-std.git synced 2025-01-16 10:49:55 +00:00

fix lints

This commit is contained in:
Orion Gonzalez 2024-11-07 12:12:04 +01:00
parent fa29b508e1
commit baca31f404
34 changed files with 66 additions and 70 deletions

View file

@ -5,7 +5,7 @@ type Result<T> = std::result::Result<T, Box<dyn std::error::Error + Send + Sync>
fn main() -> Result<()> { fn main() -> Result<()> {
let mut args = std::env::args(); let mut args = std::env::args();
match (args.nth(1).as_ref().map(String::as_str), args.next()) { match (args.nth(1).as_deref(), args.next()) {
(Some("client"), None) => client::main(), (Some("client"), None) => client::main(),
(Some("server"), None) => server::main(), (Some("server"), None) => server::main(),
_ => Err("Usage: a-chat [client|server]".into()), _ => Err("Usage: a-chat [client|server]".into()),

View file

@ -696,7 +696,7 @@ impl LockGuard<State> {
// file. This call should not block because it doesn't touch the actual file on disk. // file. This call should not block because it doesn't touch the actual file on disk.
if pos == SeekFrom::Current(0) { if pos == SeekFrom::Current(0) {
// Poll the internal file cursor. // Poll the internal file cursor.
let internal = (&*self.file).seek(SeekFrom::Current(0))?; let internal = (&*self.file).stream_position()?;
// Factor in the difference caused by caching. // Factor in the difference caused by caching.
let actual = match self.mode { let actual = match self.mode {
@ -714,7 +714,7 @@ impl LockGuard<State> {
if let Some(new) = (start as i64).checked_add(diff) { if let Some(new) = (start as i64).checked_add(diff) {
if 0 <= new && new <= self.cache.len() as i64 { if 0 <= new && new <= self.cache.len() as i64 {
// Poll the internal file cursor. // Poll the internal file cursor.
let internal = (&*self.file).seek(SeekFrom::Current(0))?; let internal = (&*self.file).stream_position()?;
// Adjust the current position in the read cache. // Adjust the current position in the read cache.
self.mode = Mode::Reading(new as usize); self.mode = Mode::Reading(new as usize);

View file

@ -44,6 +44,6 @@ where
type Output = T; type Output = T;
fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<T> { fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<T> {
(&mut self.f)(cx) (self.f)(cx)
} }
} }

View file

@ -50,7 +50,7 @@ impl<R: BufRead> Stream for Lines<R> {
this.buf.pop(); this.buf.pop();
} }
} }
Poll::Ready(Some(Ok(mem::replace(this.buf, String::new())))) Poll::Ready(Some(Ok(std::mem::take(this.buf))))
} }
} }
@ -62,7 +62,7 @@ pub fn read_line_internal<R: BufRead + ?Sized>(
read: &mut usize, read: &mut usize,
) -> Poll<io::Result<usize>> { ) -> Poll<io::Result<usize>> {
let ret = futures_core::ready!(read_until_internal(reader, cx, b'\n', bytes, read)); let ret = futures_core::ready!(read_until_internal(reader, cx, b'\n', bytes, read));
if str::from_utf8(&bytes).is_err() { if str::from_utf8(bytes).is_err() {
Poll::Ready(ret.and_then(|_| { Poll::Ready(ret.and_then(|_| {
Err(io::Error::new( Err(io::Error::new(
io::ErrorKind::InvalidData, io::ErrorKind::InvalidData,

View file

@ -136,7 +136,7 @@ pub trait BufReadExt: BufRead {
{ {
ReadLineFuture { ReadLineFuture {
reader: self, reader: self,
bytes: unsafe { mem::replace(buf.as_mut_vec(), Vec::new()) }, bytes: unsafe { std::mem::take(buf.as_mut_vec()) },
buf, buf,
read: 0, read: 0,
} }

View file

@ -29,7 +29,7 @@ impl<T: BufRead + Unpin + ?Sized> Future for ReadLineFuture<'_, T> {
let reader = Pin::new(reader); let reader = Pin::new(reader);
let ret = futures_core::ready!(read_until_internal(reader, cx, b'\n', bytes, read)); let ret = futures_core::ready!(read_until_internal(reader, cx, b'\n', bytes, read));
if str::from_utf8(&bytes).is_err() { if str::from_utf8(bytes).is_err() {
Poll::Ready(ret.and_then(|_| { Poll::Ready(ret.and_then(|_| {
Err(io::Error::new( Err(io::Error::new(
io::ErrorKind::InvalidData, io::ErrorKind::InvalidData,

View file

@ -1,4 +1,3 @@
use std::mem;
use std::pin::Pin; use std::pin::Pin;
use pin_project_lite::pin_project; use pin_project_lite::pin_project;
@ -46,6 +45,6 @@ impl<R: BufRead> Stream for Split<R> {
if this.buf[this.buf.len() - 1] == *this.delim { if this.buf[this.buf.len() - 1] == *this.delim {
this.buf.pop(); this.buf.pop();
} }
Poll::Ready(Some(Ok(mem::replace(this.buf, vec![])))) Poll::Ready(Some(Ok(std::mem::take(this.buf))))
} }
} }

View file

@ -144,7 +144,7 @@ impl<T: BufRead, U: BufRead> BufRead for Chain<T, U> {
let this = self.project(); let this = self.project();
if !*this.done_first { if !*this.done_first {
match futures_core::ready!(this.first.poll_fill_buf(cx)) { match futures_core::ready!(this.first.poll_fill_buf(cx)) {
Ok(buf) if buf.is_empty() => { Ok([]) => {
*this.done_first = true; *this.done_first = true;
} }
Ok(buf) => return Poll::Ready(Ok(buf)), Ok(buf) => return Poll::Ready(Ok(buf)),

View file

@ -13,7 +13,6 @@ use read_to_end::{read_to_end_internal, ReadToEndFuture};
use read_to_string::ReadToStringFuture; use read_to_string::ReadToStringFuture;
use read_vectored::ReadVectoredFuture; use read_vectored::ReadVectoredFuture;
use std::mem;
use crate::io::IoSliceMut; use crate::io::IoSliceMut;
@ -168,7 +167,7 @@ pub trait ReadExt: Read {
let start_len = buf.len(); let start_len = buf.len();
ReadToStringFuture { ReadToStringFuture {
reader: self, reader: self,
bytes: unsafe { mem::replace(buf.as_mut_vec(), Vec::new()) }, bytes: unsafe { std::mem::take(buf.as_mut_vec()) },
buf, buf,
start_len, start_len,
} }

View file

@ -1,4 +1,3 @@
use std::mem;
use std::pin::Pin; use std::pin::Pin;
use std::future::Future; use std::future::Future;
@ -20,7 +19,7 @@ impl<T: Read + Unpin + ?Sized> Future for ReadExactFuture<'_, T> {
while !buf.is_empty() { while !buf.is_empty() {
let n = futures_core::ready!(Pin::new(&mut *reader).poll_read(cx, buf))?; let n = futures_core::ready!(Pin::new(&mut *reader).poll_read(cx, buf))?;
let (_, rest) = mem::replace(buf, &mut []).split_at_mut(n); let (_, rest) = std::mem::take(buf).split_at_mut(n);
*buf = rest; *buf = rest;
if n == 0 { if n == 0 {

View file

@ -29,7 +29,7 @@ impl<T: Read + Unpin + ?Sized> Future for ReadToStringFuture<'_, T> {
let reader = Pin::new(reader); let reader = Pin::new(reader);
let ret = futures_core::ready!(read_to_end_internal(reader, cx, bytes, *start_len)); let ret = futures_core::ready!(read_to_end_internal(reader, cx, bytes, *start_len));
if str::from_utf8(&bytes).is_err() { if str::from_utf8(bytes).is_err() {
Poll::Ready(ret.and_then(|_| { Poll::Ready(ret.and_then(|_| {
Err(io::Error::new( Err(io::Error::new(
io::ErrorKind::InvalidData, io::ErrorKind::InvalidData,

View file

@ -1,4 +1,3 @@
use std::mem;
use std::pin::Pin; use std::pin::Pin;
use std::future::Future; use std::future::Future;
@ -20,7 +19,7 @@ impl<T: Write + Unpin + ?Sized> Future for WriteAllFuture<'_, T> {
while !buf.is_empty() { while !buf.is_empty() {
let n = futures_core::ready!(Pin::new(&mut **writer).poll_write(cx, buf))?; let n = futures_core::ready!(Pin::new(&mut **writer).poll_write(cx, buf))?;
let (_, rest) = mem::replace(buf, &[]).split_at(n); let (_, rest) = std::mem::take(buf).split_at(n);
*buf = rest; *buf = rest;
if n == 0 { if n == 0 {

View file

@ -280,6 +280,6 @@ impl ToSocketAddrs for String {
impl Future<Output = Self::Iter>, impl Future<Output = Self::Iter>,
ToSocketAddrsFuture<Self::Iter> ToSocketAddrsFuture<Self::Iter>
) { ) {
(&**self).to_socket_addrs() (**self).to_socket_addrs()
} }
} }

View file

@ -261,7 +261,7 @@ impl Path {
/// assert_eq!(ancestors.next(), None); /// assert_eq!(ancestors.next(), None);
/// ``` /// ```
pub fn ancestors(&self) -> Ancestors<'_> { pub fn ancestors(&self) -> Ancestors<'_> {
Ancestors { next: Some(&self) } Ancestors { next: Some(self) }
} }
/// Returns the final component of the `Path`, if there is one. /// Returns the final component of the `Path`, if there is one.
@ -1011,13 +1011,13 @@ impl_cmp_os_str!(&'a Path, OsString);
impl<'a> From<&'a std::path::Path> for &'a Path { impl<'a> From<&'a std::path::Path> for &'a Path {
fn from(path: &'a std::path::Path) -> &'a Path { fn from(path: &'a std::path::Path) -> &'a Path {
&Path::new(path.as_os_str()) Path::new(path.as_os_str())
} }
} }
impl<'a> Into<&'a std::path::Path> for &'a Path { impl<'a> From<&'a Path> for &'a std::path::Path {
fn into(self) -> &'a std::path::Path { fn from(val: &'a Path) -> Self {
std::path::Path::new(&self.inner) std::path::Path::new(&val.inner)
} }
} }

View file

@ -364,9 +364,9 @@ impl From<std::path::PathBuf> for PathBuf {
} }
} }
impl Into<std::path::PathBuf> for PathBuf { impl From<PathBuf> for std::path::PathBuf {
fn into(self) -> std::path::PathBuf { fn from(val: PathBuf) -> Self {
self.inner val.inner
} }
} }

View file

@ -62,7 +62,7 @@ where
type Item = T; type Item = T;
fn poll_next(mut self: Pin<&mut Self>, _: &mut Context<'_>) -> Poll<Option<Self::Item>> { fn poll_next(mut self: Pin<&mut Self>, _: &mut Context<'_>) -> Poll<Option<Self::Item>> {
let item = (&mut self.f)(); let item = (self.f)();
Poll::Ready(item) Poll::Ready(item)
} }
} }

View file

@ -78,7 +78,7 @@ where
type Item = T; type Item = T;
fn poll_next(mut self: Pin<&mut Self>, _: &mut Context<'_>) -> Poll<Option<Self::Item>> { fn poll_next(mut self: Pin<&mut Self>, _: &mut Context<'_>) -> Poll<Option<Self::Item>> {
let item = (&mut self.f)(); let item = (self.f)();
Poll::Ready(Some(item)) Poll::Ready(Some(item))
} }
} }

View file

@ -37,7 +37,7 @@ where
match next { match next {
Some(v) => { Some(v) => {
let result = (&mut self.f)(v); let result = (self.f)(v);
if result { if result {
// don't forget to wake this task again to pull the next item from stream // don't forget to wake this task again to pull the next item from stream

View file

@ -37,7 +37,7 @@ where
match next { match next {
Some(v) => { Some(v) => {
let result = (&mut self.f)(v); let result = (self.f)(v);
if result { if result {
Poll::Ready(true) Poll::Ready(true)

View file

@ -19,7 +19,7 @@ impl<'a, S, P> FindFuture<'a, S, P> {
impl<S: Unpin, P> Unpin for FindFuture<'_, S, P> {} impl<S: Unpin, P> Unpin for FindFuture<'_, S, P> {}
impl<'a, S, P> Future for FindFuture<'a, S, P> impl<S, P> Future for FindFuture<'_, S, P>
where where
S: Stream + Unpin + Sized, S: Stream + Unpin + Sized,
P: FnMut(&S::Item) -> bool, P: FnMut(&S::Item) -> bool,
@ -30,7 +30,7 @@ where
let item = futures_core::ready!(Pin::new(&mut *self.stream).poll_next(cx)); let item = futures_core::ready!(Pin::new(&mut *self.stream).poll_next(cx));
match item { match item {
Some(v) if (&mut self.p)(&v) => Poll::Ready(Some(v)), Some(v) if (self.p)(&v) => Poll::Ready(Some(v)),
Some(_) => { Some(_) => {
cx.waker().wake_by_ref(); cx.waker().wake_by_ref();
Poll::Pending Poll::Pending

View file

@ -19,7 +19,7 @@ impl<'a, S, F> FindMapFuture<'a, S, F> {
impl<S: Unpin, F> Unpin for FindMapFuture<'_, S, F> {} impl<S: Unpin, F> Unpin for FindMapFuture<'_, S, F> {}
impl<'a, S, B, F> Future for FindMapFuture<'a, S, F> impl<S, B, F> Future for FindMapFuture<'_, S, F>
where where
S: Stream + Unpin + Sized, S: Stream + Unpin + Sized,
F: FnMut(S::Item) -> Option<B>, F: FnMut(S::Item) -> Option<B>,
@ -30,7 +30,7 @@ where
let item = futures_core::ready!(Pin::new(&mut *self.stream).poll_next(cx)); let item = futures_core::ready!(Pin::new(&mut *self.stream).poll_next(cx));
match item { match item {
Some(v) => match (&mut self.f)(v) { Some(v) => match (self.f)(v) {
Some(v) => Poll::Ready(Some(v)), Some(v) => Poll::Ready(Some(v)),
None => { None => {
cx.waker().wake_by_ref(); cx.waker().wake_by_ref();

View file

@ -19,7 +19,7 @@ impl<'a, S> NthFuture<'a, S> {
} }
} }
impl<'a, S> Future for NthFuture<'a, S> impl<S> Future for NthFuture<'_, S>
where where
S: Stream + Unpin + Sized, S: Stream + Unpin + Sized,
{ {

View file

@ -12,7 +12,7 @@ pub struct PositionFuture<'a, S, P> {
index: usize, index: usize,
} }
impl<'a, S, P> Unpin for PositionFuture<'a, S, P> {} impl<S, P> Unpin for PositionFuture<'_, S, P> {}
impl<'a, S, P> PositionFuture<'a, S, P> { impl<'a, S, P> PositionFuture<'a, S, P> {
pub(super) fn new(stream: &'a mut S, predicate: P) -> Self { pub(super) fn new(stream: &'a mut S, predicate: P) -> Self {
@ -24,7 +24,7 @@ impl<'a, S, P> PositionFuture<'a, S, P> {
} }
} }
impl<'a, S, P> Future for PositionFuture<'a, S, P> impl<S, P> Future for PositionFuture<'_, S, P>
where where
S: Stream + Unpin, S: Stream + Unpin,
P: FnMut(S::Item) -> bool, P: FnMut(S::Item) -> bool,
@ -36,7 +36,7 @@ where
match next { match next {
Some(v) => { Some(v) => {
if (&mut self.predicate)(v) { if (self.predicate)(v) {
Poll::Ready(Some(self.index)) Poll::Ready(Some(self.index))
} else { } else {
cx.waker().wake_by_ref(); cx.waker().wake_by_ref();

View file

@ -12,7 +12,7 @@ pub struct TryFoldFuture<'a, S, F, T> {
acc: Option<T>, acc: Option<T>,
} }
impl<'a, S, F, T> Unpin for TryFoldFuture<'a, S, F, T> {} impl<S, F, T> Unpin for TryFoldFuture<'_, S, F, T> {}
impl<'a, S, F, T> TryFoldFuture<'a, S, F, T> { impl<'a, S, F, T> TryFoldFuture<'a, S, F, T> {
pub(super) fn new(stream: &'a mut S, init: T, f: F) -> Self { pub(super) fn new(stream: &'a mut S, init: T, f: F) -> Self {
@ -24,7 +24,7 @@ impl<'a, S, F, T> TryFoldFuture<'a, S, F, T> {
} }
} }
impl<'a, S, F, T, E> Future for TryFoldFuture<'a, S, F, T> impl<S, F, T, E> Future for TryFoldFuture<'_, S, F, T>
where where
S: Stream + Unpin, S: Stream + Unpin,
F: FnMut(T, S::Item) -> Result<T, E>, F: FnMut(T, S::Item) -> Result<T, E>,
@ -38,7 +38,7 @@ where
match next { match next {
Some(v) => { Some(v) => {
let old = self.acc.take().unwrap(); let old = self.acc.take().unwrap();
let new = (&mut self.f)(old, v); let new = (self.f)(old, v);
match new { match new {
Ok(o) => self.acc = Some(o), Ok(o) => self.acc = Some(o),

View file

@ -11,7 +11,7 @@ pub struct TryForEachFuture<'a, S, F> {
f: F, f: F,
} }
impl<'a, S, F> Unpin for TryForEachFuture<'a, S, F> {} impl<S, F> Unpin for TryForEachFuture<'_, S, F> {}
impl<'a, S, F> TryForEachFuture<'a, S, F> { impl<'a, S, F> TryForEachFuture<'a, S, F> {
pub(crate) fn new(stream: &'a mut S, f: F) -> Self { pub(crate) fn new(stream: &'a mut S, f: F) -> Self {
@ -19,7 +19,7 @@ impl<'a, S, F> TryForEachFuture<'a, S, F> {
} }
} }
impl<'a, S, F, E> Future for TryForEachFuture<'a, S, F> impl<S, F, E> Future for TryForEachFuture<'_, S, F>
where where
S: Stream + Unpin, S: Stream + Unpin,
F: FnMut(S::Item) -> Result<(), E>, F: FnMut(S::Item) -> Result<(), E>,
@ -33,7 +33,7 @@ where
match item { match item {
None => return Poll::Ready(Ok(())), None => return Poll::Ready(Ok(())),
Some(v) => { Some(v) => {
let res = (&mut self.f)(v); let res = (self.f)(v);
if let Err(e) = res { if let Err(e) = res {
return Poll::Ready(Err(e)); return Poll::Ready(Err(e));
} }

View file

@ -154,7 +154,7 @@ impl Builder {
thread_local! { thread_local! {
/// Tracks the number of nested block_on calls. /// Tracks the number of nested block_on calls.
static NUM_NESTED_BLOCKING: Cell<usize> = Cell::new(0); static NUM_NESTED_BLOCKING: Cell<usize> = const { Cell::new(0) };
} }
// Run the future as a task. // Run the future as a task.

View file

@ -22,7 +22,7 @@ impl TaskId {
static COUNTER: AtomicUsize = AtomicUsize::new(1); static COUNTER: AtomicUsize = AtomicUsize::new(1);
let id = COUNTER.fetch_add(1, Ordering::Relaxed); let id = COUNTER.fetch_add(1, Ordering::Relaxed);
if id > usize::max_value() / 2 { if id > usize::MAX / 2 {
std::process::abort(); std::process::abort();
} }
TaskId(id) TaskId(id)

View file

@ -120,7 +120,7 @@ impl<T: Send + 'static> LocalKey<T> {
static COUNTER: AtomicU32 = AtomicU32::new(1); static COUNTER: AtomicU32 = AtomicU32::new(1);
let counter = COUNTER.fetch_add(1, Ordering::Relaxed); let counter = COUNTER.fetch_add(1, Ordering::Relaxed);
if counter > u32::max_value() / 2 { if counter > u32::MAX / 2 {
std::process::abort(); std::process::abort();
} }

View file

@ -6,7 +6,7 @@ use crate::utils::abort_on_panic;
thread_local! { thread_local! {
/// A pointer to the currently running task. /// A pointer to the currently running task.
static CURRENT: Cell<*const TaskLocalsWrapper> = Cell::new(ptr::null_mut()); static CURRENT: Cell<*const TaskLocalsWrapper> = const { Cell::new(ptr::null_mut()) };
} }
/// A wrapper to store task local data. /// A wrapper to store task local data.

View file

@ -71,7 +71,7 @@ pub(crate) fn timer_after(dur: std::time::Duration) -> timer::Timer {
Timer::after(dur) Timer::after(dur)
} }
#[cfg(any(all(target_arch = "wasm32", feature = "default"),))] #[cfg(all(target_arch = "wasm32", feature = "default"))]
mod timer { mod timer {
use std::pin::Pin; use std::pin::Pin;
use std::task::Poll; use std::task::Poll;

View file

@ -59,38 +59,38 @@ fn len_empty_full() {
let (s, r) = channel(2); let (s, r) = channel(2);
assert_eq!(s.len(), 0); assert_eq!(s.len(), 0);
assert_eq!(s.is_empty(), true); assert!(s.is_empty());
assert_eq!(s.is_full(), false); assert!(!s.is_full());
assert_eq!(r.len(), 0); assert_eq!(r.len(), 0);
assert_eq!(r.is_empty(), true); assert!(r.is_empty());
assert_eq!(r.is_full(), false); assert!(!r.is_full());
s.send(()).await.unwrap(); s.send(()).await.unwrap();
assert_eq!(s.len(), 1); assert_eq!(s.len(), 1);
assert_eq!(s.is_empty(), false); assert!(!s.is_empty());
assert_eq!(s.is_full(), false); assert!(!s.is_full());
assert_eq!(r.len(), 1); assert_eq!(r.len(), 1);
assert_eq!(r.is_empty(), false); assert!(!r.is_empty());
assert_eq!(r.is_full(), false); assert!(!r.is_full());
s.send(()).await.unwrap(); s.send(()).await.unwrap();
assert_eq!(s.len(), 2); assert_eq!(s.len(), 2);
assert_eq!(s.is_empty(), false); assert!(!s.is_empty());
assert_eq!(s.is_full(), true); assert!(s.is_full());
assert_eq!(r.len(), 2); assert_eq!(r.len(), 2);
assert_eq!(r.is_empty(), false); assert!(!r.is_empty());
assert_eq!(r.is_full(), true); assert!(r.is_full());
let _ = r.recv().await; let _ = r.recv().await;
assert_eq!(s.len(), 1); assert_eq!(s.len(), 1);
assert_eq!(s.is_empty(), false); assert!(!s.is_empty());
assert_eq!(s.is_full(), false); assert!(!s.is_full());
assert_eq!(r.len(), 1); assert_eq!(r.len(), 1);
assert_eq!(r.is_empty(), false); assert!(!r.is_empty());
assert_eq!(r.is_full(), false); assert!(!r.is_full());
}) })
} }

View file

@ -21,7 +21,7 @@ wasm_bindgen_test::wasm_bindgen_test_configure!(run_in_browser);
/// Generates a random number in `0..n`. /// Generates a random number in `0..n`.
pub fn random(n: u32) -> u32 { pub fn random(n: u32) -> u32 {
thread_local! { thread_local! {
static RNG: Cell<Wrapping<u32>> = Cell::new(Wrapping(1_406_868_647)); static RNG: Cell<Wrapping<u32>> = const { Cell::new(Wrapping(1_406_868_647)) };
} }
RNG.with(|rng| { RNG.with(|rng| {

View file

@ -60,7 +60,7 @@ fn smoke_std_stream_to_async_listener() -> io::Result<()> {
let listener = TcpListener::bind("127.0.0.1:0").await?; let listener = TcpListener::bind("127.0.0.1:0").await?;
let addr = listener.local_addr()?; let addr = listener.local_addr()?;
let mut std_stream = std::net::TcpStream::connect(&addr)?; let mut std_stream = std::net::TcpStream::connect(addr)?;
std_stream.write_all(THE_WINTERS_TALE)?; std_stream.write_all(THE_WINTERS_TALE)?;
let mut buf = vec![0; 1024]; let mut buf = vec![0; 1024];

View file

@ -96,7 +96,7 @@ async fn ping_pong_server(listener: UnixListener, iterations: u32) -> std::io::R
let mut s = s?; let mut s = s?;
let n = s.read(&mut buf[..]).await?; let n = s.read(&mut buf[..]).await?;
assert_eq!(&buf[..n], PING); assert_eq!(&buf[..n], PING);
s.write_all(&PONG).await?; s.write_all(PONG).await?;
} }
} }
Ok(()) Ok(())
@ -106,7 +106,7 @@ async fn ping_pong_client(socket: &std::path::PathBuf, iterations: u32) -> std::
let mut buf = [0; 1024]; let mut buf = [0; 1024];
for _ix in 0..iterations { for _ix in 0..iterations {
let mut socket = UnixStream::connect(&socket).await?; let mut socket = UnixStream::connect(&socket).await?;
socket.write_all(&PING).await?; socket.write_all(PING).await?;
let n = async_std::io::timeout(TEST_TIMEOUT, socket.read(&mut buf[..])).await?; let n = async_std::io::timeout(TEST_TIMEOUT, socket.read(&mut buf[..])).await?;
assert_eq!(&buf[..n], PONG); assert_eq!(&buf[..n], PONG);
} }