pub use models::*;
use std::thread;
use tauri::{
plugin::{Builder, TauriPlugin},
Manager, Runtime,
};
use tokio::sync::{mpsc, Mutex};
#[cfg(desktop)]
mod desktop;
#[cfg(mobile)]
mod mobile;
mod commands;
mod deno_lib;
mod deno_ops;
mod deno_ts_loader;
mod error;
mod models;
pub use error::{Error, Result};
#[cfg(desktop)]
use desktop::Deno;
#[cfg(mobile)]
use mobile::Deno;
pub trait DenoExt<R: Runtime> {
fn deno(&self) -> &Deno<R>;
}
impl<R: Runtime, T: Manager<R>> crate::DenoExt<R> for T {
fn deno(&self) -> &Deno<R> {
self.state::<Deno<R>>().inner()
}
}
pub fn init<R: Runtime>() -> TauriPlugin<R> {
Builder::new("deno")
.invoke_handler(tauri::generate_handler![
commands::run_code,
commands::register_function,
commands::call_function,
commands::read_variable
])
.setup(|app, api| {
#[cfg(mobile)]
let deno = mobile::init(app, api)?;
#[cfg(desktop)]
let deno = desktop::init(app, api)?;
app.manage(deno);
let (tx, rx) = mpsc::channel(1000);
app.manage(Mutex::new(tx));
start_deno_thread(rx);
Ok(())
})
.build()
}
fn start_deno_thread(rx: mpsc::Receiver<JsMsg>) {
let _detached = thread::spawn(move || deno_lib::js_runtime_thread(rx));
}