#[cfg(not(target_arch = "wasm32"))]
pub mod native;
#[cfg(not(target_arch = "wasm32"))]
pub use native::*;
#[cfg(target_arch = "wasm32")]
mod web;
#[cfg(target_arch = "wasm32")]
pub use web::*;
#[derive(Clone, Debug)]
pub enum EsEvent {
Opened,
Message(String),
Error(String),
Closed,
}
pub struct EsReceiver {
rx: std::sync::mpsc::Receiver<EsEvent>,
}
impl EsReceiver {
pub fn new() -> (Self, EventHandler) {
Self::new_with_callback(|| {})
}
pub fn new_with_callback(wake_up: impl Fn() + Send + Sync + 'static) -> (Self, EventHandler) {
let (tx, rx) = std::sync::mpsc::channel();
let on_event = Box::new(move |event| {
wake_up(); if tx.send(event).is_ok() {
std::ops::ControlFlow::Continue(())
} else {
std::ops::ControlFlow::Break(())
}
});
let ws_receiver = EsReceiver { rx };
(ws_receiver, on_event)
}
pub fn try_recv(&self) -> Option<EsEvent> {
self.rx.try_recv().ok()
}
}
pub type Error = String;
pub type Result<T> = std::result::Result<T, Error>;
pub type EventHandler = Box<dyn Send + Fn(EsEvent) -> std::ops::ControlFlow<()>>;
pub fn connect(url: impl Into<String>) -> Result<EsReceiver> {
let (ws_receiver, on_event) = EsReceiver::new();
es_connect(url.into(), on_event)?;
Ok(ws_receiver)
}
pub fn connect_with_wakeup(
url: impl Into<String>,
wake_up: impl Fn() + Send + Sync + 'static,
) -> Result<EsReceiver> {
let (receiver, on_event) = EsReceiver::new_with_callback(wake_up);
es_connect(url.into(), on_event)?;
Ok(receiver)
}