When to use this skill
ALWAYS use this skill when the user mentions:
- Frontend-to-Rust IPC or invoke calls
- Defining Tauri commands
- Type-safe IPC bindings (tauri-specta)
Trigger phrases include:
- "IPC", "invoke", "tauri command", "type-safe", "tauri-specta", "calling rust"
How to use this skill
- Define a Rust command:
#[tauri::command] fn greet(name: &str) -> String { format!("Hello, {}!", name) } - Register the command in the Tauri builder:
tauri::Builder::default() .invoke_handler(tauri::generate_handler![greet]) - Call from the frontend:
import { invoke } from '@tauri-apps/api/core'; const greeting = await invoke<string>('greet', { name: 'World' }); - For type-safe bindings, use
tauri-spectato auto-generate TypeScript types from Rust commands:cargo add tauri-specta specta - Bidirectional events for Rust-to-frontend communication:
app.emit("update", payload)?; // Rust -> Frontendimport { listen } from '@tauri-apps/api/event'; await listen('update', (event) => console.log(event.payload)); - Handle errors by returning
Result<T, String>from Rust commands
Outputs
- Rust command definition and registration
- Frontend invoke call pattern
- Type-safe IPC with tauri-specta
- Bidirectional event communication
References
- https://v2.tauri.app/develop/calling-rust/
- https://v2.tauri.app/develop/calling-frontend/
Keywords
tauri IPC, invoke, tauri command, type-safe, tauri-specta, events