use crate::tools::*; pub use allo_isolate::ffi::DartCObject; pub use allo_isolate::IntoDart; use allo_isolate::Isolate; use core::fmt::Debug; use core::future::Future; use parking_lot::Mutex; use serde::*; use std::sync::Arc; #[derive(Clone)] pub struct DartIsolateWrapper { isolate: Isolate, } const MESSAGE_OK: i32 = 0; //const MESSAGE_ERR: i32 = 1; const MESSAGE_OK_JSON: i32 = 2; const MESSAGE_ERR_JSON: i32 = 3; //const MESSAGE_STREAM_ITEM: i32 = 4; const MESSAGE_STREAM_ITEM_JSON: i32 = 5; //const MESSAGE_STREAM_ABORT: i32 = 6; //const MESSAGE_STREAM_ABORT_JSON: i32 = 7; const MESSAGE_STREAM_CLOSE: i32 = 8; impl DartIsolateWrapper { pub fn new(port: i64) -> Self { DartIsolateWrapper { isolate: Isolate::new(port), } } pub fn spawn_result(self, future: F) where F: Future> + Send + 'static, T: IntoDart + Debug, E: Serialize + Debug, { spawn(async move { self.result(future.await); }); } pub fn spawn_result_json(self, future: F) where F: Future> + Send + 'static, T: Serialize + Debug, E: Serialize + Debug, { spawn(async move { self.result_json(future.await); }); } pub fn spawn_result_opt_json(self, future: F) where F: Future, E>> + Send + 'static, T: Serialize + Debug, E: Serialize + Debug, { spawn(async move { self.result_opt_json(future.await); }); } pub fn result(self, result: Result) -> bool { match result { Ok(v) => self.ok(v), Err(e) => self.err_json(e), } } pub fn result_json( self, result: Result, ) -> bool { match result { Ok(v) => self.ok_json(v), Err(e) => self.err_json(e), } } pub fn result_opt_json( self, result: Result, E>, ) -> bool { match result { Ok(Some(v)) => self.ok_json(v), Ok(None) => self.ok(()), Err(e) => self.err_json(e), } } pub fn ok(self, value: T) -> bool { self.isolate .post(vec![MESSAGE_OK.into_dart(), value.into_dart()]) } pub fn ok_json(self, value: T) -> bool { self.isolate.post(vec![ MESSAGE_OK_JSON.into_dart(), veilid_core::serialize_json(value).into_dart(), ]) } // pub fn err(self, error: E) -> bool { // self.isolate // .post(vec![MESSAGE_ERR.into_dart(), error.into_dart()]) // } pub fn err_json(self, error: E) -> bool { self.isolate.post(vec![ MESSAGE_ERR_JSON.into_dart(), veilid_core::serialize_json(error).into_dart(), ]) } } struct DartIsolateStreamInner { pub isolate: Option, } impl Drop for DartIsolateStreamInner { fn drop(&mut self) { if let Some(isolate) = self.isolate { isolate.post(vec![MESSAGE_STREAM_CLOSE.into_dart()]); } } } #[derive(Clone)] pub struct DartIsolateStream { inner: Arc>, } impl DartIsolateStream { pub fn new(port: i64) -> Self { DartIsolateStream { inner: Arc::new(Mutex::new(DartIsolateStreamInner { isolate: Some(Isolate::new(port)), })), } } // pub fn item(&self, value: T) -> bool { // let mut inner = self.inner.lock(); // if let Some(isolate) = inner.isolate.take() { // isolate.post(vec![MESSAGE_STREAM_ITEM.into_dart(), value.into_dart()]) // } else { // false // } // } pub fn item_json(&self, value: T) -> bool { let inner = self.inner.lock(); if let Some(isolate) = &inner.isolate { isolate.post(vec![ MESSAGE_STREAM_ITEM_JSON.into_dart(), veilid_core::serialize_json(value).into_dart(), ]) } else { false } } // pub fn abort(self, error: E) -> bool { // let mut inner = self.inner.lock(); // if let Some(isolate) = inner.isolate.take() { // isolate.post(vec![MESSAGE_STREAM_ABORT.into_dart(), error.into_dart()]) // } else { // false // } // } // pub fn abort_json(self, error: E) -> bool { // let mut inner = self.inner.lock(); // if let Some(isolate) = inner.isolate.take() { // isolate.post(vec![ // MESSAGE_STREAM_ABORT_JSON.into_dart(), // veilid_core::serialize_json(error).into_dart(), // ]) // } else { // false // } // } pub fn close(self) -> bool { let mut inner = self.inner.lock(); if let Some(isolate) = inner.isolate.take() { isolate.post(vec![MESSAGE_STREAM_CLOSE.into_dart()]) } else { false } } }