// Copyright 2019-2024 Tauri Programme within The Commons Conservancy // SPDX-License-Identifier: Apache-2.0 // SPDX-License-Identifier: MIT #![cfg(any(target_os = "macos", target_os = "linux", windows))] use std::sync::Arc; use napi::{ threadsafe_function::{ThreadsafeFunction, ThreadsafeFunctionCallMode}, Error, Result, Status, }; #[napi_derive::napi] pub fn run( args: Vec, bin_name: Option, callback: Arc>, ) -> Result<()> { // we need to run in a separate thread so Node.js consumers // can do work while `tauri dev` is running. std::thread::spawn(move || { let res = match std::panic::catch_unwind(std::panic::AssertUnwindSafe(|| { tauri_cli::try_run(args, bin_name).inspect_err(|e| eprintln!("{e:#}")) })) { Ok(t) => t, Err(_) => { return callback.call( Err(Error::new( Status::GenericFailure, "Tauri CLI unexpected panic", )), ThreadsafeFunctionCallMode::Blocking, ); } }; match res { Ok(_) => callback.call(Ok(true), ThreadsafeFunctionCallMode::Blocking), Err(e) => callback.call( Err(Error::new(Status::GenericFailure, format!("{e:#}"))), ThreadsafeFunctionCallMode::Blocking, ), } }); Ok(()) } #[napi_derive::napi] pub fn log_error(error: String) { log::error!("{}", error); }