This project is a desktop application built with **Tauri**. It functions as an **Agentic Code Assistant** capable of safely executing tools on the host system.
## Core Stack
***Backend:** Rust (Tauri Core)
***MSRV:** Stable (latest)
***Framework:** Tauri v2
***Frontend:** TypeScript + React
***Build Tool:** Vite
***Styling:** CSS Modules or Tailwind (TBD - Defaulting to CSS Modules)
***State Management:** React Context / Hooks
***Chat UI:** Rendered Markdown with syntax highlighting.
## Agent Architecture
The application follows a **Tool-Use (Function Calling)** architecture:
1.**Frontend:** Collects user input and sends it to the LLM.
2.**LLM:** Decides to generate text OR request a **Tool Call** (e.g., `execute_shell`, `read_file`).
3.**Tauri Backend (The "Hand"):**
* Intercepts Tool Calls.
* Validates the request against the **Safety Policy**.
* Executes the native code (File I/O, Shell Process, Search).
* Returns the output (stdout/stderr/file content) to the LLM.
## LLM Provider Abstraction
To support both Remote and Local models, the system implements a `ModelProvider` abstraction layer.
***Strategy:**
* Abstract the differences between API formats (OpenAI-compatible vs Anthropic vs Gemini).
* Normalize "Tool Use" definitions, as each provider handles function calling schemas differently.
***Supported Providers:**
***Anthropic:** Focus on Claude 3.5 Sonnet for coding tasks.
***Google:** Gemini 1.5 Pro for massive context windows.
***Ollama:** Local inference (e.g., Llama 3, DeepSeek Coder) for privacy and offline usage.
***Configuration:**
* Provider selection is runtime-configurable by the user.
* API Keys must be stored securely (using OS native keychain where possible).
## Tooling Capabilities
### 1. Filesystem (Native)
***Scope:** Strictly limited to the user-selected `project_root`.
***Operations:** Read, Write, List, Delete.
***Constraint:** Modifications to `.git/` are strictly forbidden via file APIs (use Git tools instead).
### 2. Shell Execution
***Library:**`tokio::process` for async execution.
***Constraint:** We do **not** run an interactive shell (repl). We run discrete, stateless commands.
***Allowlist:** The agent may only execute specific binaries:
*`git`
*`cargo`, `rustc`, `rustfmt`, `clippy`
*`npm`, `node`, `yarn`, `pnpm`, `bun`
*`ls`, `find`, `grep` (if not using internal search)