diff options
| author | OpeOginni <[email protected]> | 2026-02-06 18:21:47 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2026-02-06 17:21:47 +0000 |
| commit | 8069197329d2d1b958d8e7f63daaf9662a97027d (patch) | |
| tree | 9f38c854ebca35fbfce7fafe21b73e619f08584f /packages/desktop/src-tauri | |
| parent | 3f7ca0494b065a52933d12f1965758405ca86c2e (diff) | |
| download | opencode-8069197329d2d1b958d8e7f63daaf9662a97027d.tar.gz opencode-8069197329d2d1b958d8e7f63daaf9662a97027d.zip | |
feat(desktop): added Macos support for displaying only installed editors & added sublime text editor (#12501)
Diffstat (limited to 'packages/desktop/src-tauri')
| -rw-r--r-- | packages/desktop/src-tauri/src/lib.rs | 60 |
1 files changed, 59 insertions, 1 deletions
diff --git a/packages/desktop/src-tauri/src/lib.rs b/packages/desktop/src-tauri/src/lib.rs index 135f7b072..14105e5dd 100644 --- a/packages/desktop/src-tauri/src/lib.rs +++ b/packages/desktop/src-tauri/src/lib.rs @@ -20,6 +20,7 @@ use std::{ path::PathBuf, sync::{Arc, Mutex}, time::Duration, + process::Command, }; use tauri::{AppHandle, Manager, RunEvent, State, ipc::Channel}; #[cfg(any(target_os = "linux", all(debug_assertions, windows)))] @@ -142,6 +143,62 @@ async fn await_initialization( .map_err(|_| "Failed to get server status".to_string())? } +#[tauri::command] +#[specta::specta] +fn check_app_exists(app_name: &str) -> bool { + #[cfg(target_os = "windows")] + { + check_windows_app(app_name) + } + + #[cfg(target_os = "macos")] + { + check_macos_app(app_name) + } + + #[cfg(target_os = "linux")] + { + check_linux_app(app_name) + } +} + +#[cfg(target_os = "windows")] +fn check_windows_app(app_name: &str) -> bool { + // Check if command exists in PATH, including .exe + return true; +} + +#[cfg(target_os = "macos")] +fn check_macos_app(app_name: &str) -> bool { + // Check common installation locations + let mut app_locations = vec![ + format!("/Applications/{}.app", app_name), + format!("/System/Applications/{}.app", app_name), + ]; + + if let Ok(home) = std::env::var("HOME") { + app_locations.push(format!("{}/Applications/{}.app", home, app_name)); + } + + for location in app_locations { + if std::path::Path::new(&location).exists() { + return true; + } + } + + // Also check if command exists in PATH + Command::new("which") + .arg(app_name) + .output() + .map(|output| output.status.success()) + .unwrap_or(false) +} + +#[cfg(target_os = "linux")] +fn check_linux_app(app_name: &str) -> bool { + return true; +} + #[cfg_attr(mobile, tauri::mobile_entry_point)] pub fn run() { let builder = tauri_specta::Builder::<tauri::Wry>::new() @@ -152,7 +209,8 @@ pub fn run() { await_initialization, server::get_default_server_url, server::set_default_server_url, - markdown::parse_markdown_command + markdown::parse_markdown_command, + check_app_exists ]) .events(tauri_specta::collect_events![LoadingWindowComplete]) .error_handling(tauri_specta::ErrorHandlingMode::Throw); |
