|
|
@ -28,13 +28,13 @@ pub mod stream; |
|
|
|
use std::io::{Read, Write}; |
|
|
|
use std::io::{Read, Write}; |
|
|
|
|
|
|
|
|
|
|
|
use compat::{cvt, AllowStd}; |
|
|
|
use compat::{cvt, AllowStd}; |
|
|
|
use futures::{Stream, Sink}; |
|
|
|
use futures::io::{AsyncRead, AsyncWrite}; |
|
|
|
|
|
|
|
use futures::{Sink, Stream}; |
|
|
|
use log::*; |
|
|
|
use log::*; |
|
|
|
use pin_project::pin_project; |
|
|
|
use pin_project::pin_project; |
|
|
|
use std::future::Future; |
|
|
|
use std::future::Future; |
|
|
|
use std::pin::Pin; |
|
|
|
use std::pin::Pin; |
|
|
|
use std::task::{Context, Poll}; |
|
|
|
use std::task::{Context, Poll}; |
|
|
|
use futures::io::{AsyncRead, AsyncWrite}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use tungstenite::{ |
|
|
|
use tungstenite::{ |
|
|
|
error::Error as WsError, |
|
|
|
error::Error as WsError, |
|
|
@ -297,7 +297,7 @@ where |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
impl<T> Sink<Message> for WebSocketStream<T> |
|
|
|
impl<T> Sink<Message> for WebSocketStream<T> |
|
|
|
where |
|
|
|
where |
|
|
|
T: AsyncRead + AsyncWrite + Unpin, |
|
|
|
T: AsyncRead + AsyncWrite + Unpin, |
|
|
|
AllowStd<T>: Read + Write, |
|
|
|
AllowStd<T>: Read + Write, |
|
|
|
{ |
|
|
|
{ |
|
|
@ -310,7 +310,9 @@ impl<T> Sink<Message> for WebSocketStream<T> |
|
|
|
fn start_send(mut self: Pin<&mut Self>, item: Message) -> Result<(), Self::Error> { |
|
|
|
fn start_send(mut self: Pin<&mut Self>, item: Message) -> Result<(), Self::Error> { |
|
|
|
match (*self).with_context(None, |s| s.write_message(item)) { |
|
|
|
match (*self).with_context(None, |s| s.write_message(item)) { |
|
|
|
Ok(()) => Ok(()), |
|
|
|
Ok(()) => Ok(()), |
|
|
|
Err(::tungstenite::Error::Io(ref err)) if err.kind() == std::io::ErrorKind::WouldBlock => { |
|
|
|
Err(::tungstenite::Error::Io(ref err)) |
|
|
|
|
|
|
|
if err.kind() == std::io::ErrorKind::WouldBlock => |
|
|
|
|
|
|
|
{ |
|
|
|
// the message was accepted and queued
|
|
|
|
// the message was accepted and queued
|
|
|
|
// isn't an error.
|
|
|
|
// isn't an error.
|
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
@ -354,7 +356,10 @@ where |
|
|
|
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> { |
|
|
|
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> { |
|
|
|
let this = self.project(); |
|
|
|
let this = self.project(); |
|
|
|
let message = this.message.take().expect("Cannot poll twice"); |
|
|
|
let message = this.message.take().expect("Cannot poll twice"); |
|
|
|
Poll::Ready(this.stream.with_context(Some(cx), |s| s.write_message(message))) |
|
|
|
Poll::Ready( |
|
|
|
|
|
|
|
this.stream |
|
|
|
|
|
|
|
.with_context(Some(cx), |s| s.write_message(message)), |
|
|
|
|
|
|
|
) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -381,11 +386,11 @@ where |
|
|
|
#[cfg(test)] |
|
|
|
#[cfg(test)] |
|
|
|
mod tests { |
|
|
|
mod tests { |
|
|
|
use crate::compat::AllowStd; |
|
|
|
use crate::compat::AllowStd; |
|
|
|
#[cfg(feature="connect")] |
|
|
|
#[cfg(feature = "connect")] |
|
|
|
use crate::connect::encryption::AutoStream; |
|
|
|
use crate::connect::encryption::AutoStream; |
|
|
|
use crate::WebSocketStream; |
|
|
|
use crate::WebSocketStream; |
|
|
|
use std::io::{Read, Write}; |
|
|
|
|
|
|
|
use futures::io::{AsyncReadExt, AsyncWriteExt}; |
|
|
|
use futures::io::{AsyncReadExt, AsyncWriteExt}; |
|
|
|
|
|
|
|
use std::io::{Read, Write}; |
|
|
|
|
|
|
|
|
|
|
|
fn is_read<T: Read>() {} |
|
|
|
fn is_read<T: Read>() {} |
|
|
|
fn is_write<T: Write>() {} |
|
|
|
fn is_write<T: Write>() {} |
|
|
@ -398,13 +403,13 @@ mod tests { |
|
|
|
is_read::<AllowStd<async_std::net::TcpStream>>(); |
|
|
|
is_read::<AllowStd<async_std::net::TcpStream>>(); |
|
|
|
is_write::<AllowStd<async_std::net::TcpStream>>(); |
|
|
|
is_write::<AllowStd<async_std::net::TcpStream>>(); |
|
|
|
|
|
|
|
|
|
|
|
#[cfg(feature="connect")] |
|
|
|
#[cfg(feature = "connect")] |
|
|
|
is_async_read::<AutoStream<async_std::net::TcpStream>>(); |
|
|
|
is_async_read::<AutoStream<async_std::net::TcpStream>>(); |
|
|
|
#[cfg(feature="connect")] |
|
|
|
#[cfg(feature = "connect")] |
|
|
|
is_async_write::<AutoStream<async_std::net::TcpStream>>(); |
|
|
|
is_async_write::<AutoStream<async_std::net::TcpStream>>(); |
|
|
|
|
|
|
|
|
|
|
|
is_unpin::<WebSocketStream<async_std::net::TcpStream>>(); |
|
|
|
is_unpin::<WebSocketStream<async_std::net::TcpStream>>(); |
|
|
|
#[cfg(feature="connect")] |
|
|
|
#[cfg(feature = "connect")] |
|
|
|
is_unpin::<WebSocketStream<AutoStream<async_std::net::TcpStream>>>(); |
|
|
|
is_unpin::<WebSocketStream<AutoStream<async_std::net::TcpStream>>>(); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|