use std::pin::Pin;
use std::task::{Context, Poll};
use zmq::{Message, SocketType};
use crate::{
reactor::{AsRawSocket, ZmqSocket},
socket::{MultipartIter, Sender, SocketBuilder},
SendError, Sink, SocketError,
};
pub fn push<I: Iterator<Item = T> + Unpin, T: Into<Message>>(
endpoint: &str,
) -> Result<SocketBuilder<'_, Push<I, T>>, SocketError> {
Ok(SocketBuilder::new(SocketType::PUSH, endpoint))
}
pub struct Push<I: Iterator<Item = T> + Unpin, T: Into<Message>>(Sender<I, T>);
impl<I: Iterator<Item = T> + Unpin, T: Into<Message>> Push<I, T> {
pub fn as_raw_socket(&self) -> &zmq::Socket {
self.0.socket.as_socket()
}
}
impl<I: Iterator<Item = T> + Unpin, T: Into<Message>> Sink<MultipartIter<I, T>> for Push<I, T> {
type Error = SendError;
fn poll_ready(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Result<(), Self::Error>> {
Sink::poll_ready(Pin::new(&mut self.get_mut().0), cx)
.map(|result| result.map_err(Into::into))
}
fn start_send(self: Pin<&mut Self>, item: MultipartIter<I, T>) -> Result<(), Self::Error> {
Pin::new(&mut self.get_mut().0)
.start_send(item)
.map_err(Into::into)
}
fn poll_flush(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Result<(), Self::Error>> {
Sink::poll_flush(Pin::new(&mut self.get_mut().0), cx)
.map(|result| result.map_err(Into::into))
}
fn poll_close(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Result<(), Self::Error>> {
Sink::poll_close(Pin::new(&mut self.get_mut().0), cx)
.map(|result| result.map_err(Into::into))
}
}
impl<I: Iterator<Item = T> + Unpin, T: Into<Message>> From<zmq::Socket> for Push<I, T> {
fn from(socket: zmq::Socket) -> Self {
Self(Sender {
socket: ZmqSocket::from(socket),
buffer: None,
})
}
}