https://github.com/CSCSoftware/AiDex
MCP Server for persistent code indexing. Gives AI assistants (Claude, Gemini, Copilot, Cursor) instant access to your codebase. 50x less context than grep.
https://github.com/CSCSoftware/AiDex
ai-coding claude claude-code code-indexing code-search copilot cursor developer-tools gemini gemini-cli mcp mcp-server sqlite tree-sitter vscode windsurf
Last synced: 10 days ago
JSON representation
MCP Server for persistent code indexing. Gives AI assistants (Claude, Gemini, Copilot, Cursor) instant access to your codebase. 50x less context than grep.
- Host: GitHub
- URL: https://github.com/CSCSoftware/AiDex
- Owner: CSCSoftware
- License: mit
- Created: 2026-01-26T18:22:10.000Z (5 months ago)
- Default Branch: master
- Last Pushed: 2026-05-31T17:24:21.000Z (13 days ago)
- Last Synced: 2026-05-31T18:24:54.097Z (13 days ago)
- Topics: ai-coding, claude, claude-code, code-indexing, code-search, copilot, cursor, developer-tools, gemini, gemini-cli, mcp, mcp-server, sqlite, tree-sitter, vscode, windsurf
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/aidex-mcp
- Size: 1.87 MB
- Stars: 34
- Watchers: 0
- Forks: 9
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-mcp-servers - AiDex - Persistent code index MCP server using Tree-sitter for fast, precise code search. Replaces grep with ~50 token responses instead of 2000+. Supports 11 languages including C#, TypeScript, Python, Rust, and Go. ([Read more](/details/aidex.md)) `Code Search` `Tree Sitter` `Multi Language` (Code Analysis)
- awesome-mcp-servers - **CSCSoftware/AiDex π πͺ π§** - Persistent code index MCP server using Tree-sitter for fast, precise code search. Replaces grep with ~50 token responses instead of 2000+. Supports 11 languages including C#, TypeScript, Python, Rust, and Go. `http` `ai` `git` `github` (π¦ Other)
README
# AiDex
[](https://www.npmjs.com/package/aidex-mcp)
[](LICENSE)
[](https://nodejs.org/)
[](https://modelcontextprotocol.io/)
[](https://github.com/CSCSoftware/AiDex/discussions)
**The persistent brain for AI coding agents.**
AiDex is an MCP server that gives AI coding assistants a memory, semantic search, and live telemetry β local-first, model-agnostic. Works with any MCP-compatible AI assistant: Claude Code, Claude Desktop, Cursor, Windsurf, Gemini CLI, VS Code Copilot, and more.
### Three Pillars
π§ **Memory** β Tasks, notes, and session-notes survive every chat. Auto-logged history, scheduled tasks, cross-session continuity. Your AI knows tomorrow what mattered today.
π **Search** β Three modes: `exact` (identifier), `semantic` (concept), `hybrid` (RRF fusion of both). Embeds code, docs, and workspace items into one ranking. Cross-project β every repo in one query. Optional LLM layer translates non-English queries and reranks results.
π **Telemetry** β LogHub receives live logs from any app via HTTP (no SDK). The AI watches what your code actually does, not just what it says. Live-streamed in the Viewer.
And yes β it's still 50Γ more token-efficient than grep.

| | Without AiDex | With AiDex |
|---|---|---|
| Find `PlayerHealth` | Grep β 200 hits in 40 files β reads 5 files β **2,000+ tokens** | 1 query β 3 exact locations β **~50 tokens** |
| Get file structure | Reads entire 500-line file β **1,500 tokens** | Signatures β classes + methods β **~80 tokens** |
| What changed today? | `git diff` + grep + context β **3,000+ tokens** | Time-filtered query β **~50 tokens** |

### What's Inside β 33 Tools in One Server
| Category | Tools | What it does |
|----------|-------|--------------|
| **Semantic Search** π | `search`, `settings` | Hybrid / semantic / exact retrieval over code, docs & workspace. Settings tab to configure embeddings + LLM layer |
| **Index & Identifier Search** | `init`, `query`, `update`, `remove`, `status` | Index your project, search identifiers by name (exact/contains/starts_with), time-based filtering |
| **Signatures** | `signature`, `signatures` | Get classes + methods of any file without reading it β single file or glob pattern |
| **Project Overview** | `summary`, `tree`, `describe`, `files` | Entry points, language breakdown, file tree with stats, file listing by type |
| **Cross-Project** | `link`, `unlink`, `links`, `scan` | Link dependencies, discover indexed projects |
| **Global Search** | `global_init`, `global_query`, `global_signatures`, `global_status`, `global_refresh` | Search identifiers across ALL your projects β "Have I ever written X?" |
| **Guidelines** | `global_guideline` | Persistent AI instructions & coding conventions β shared across all projects |
| **Sessions** | `session`, `note` | Track sessions, detect external changes, leave notes for next session (with searchable history) |
| **Task Backlog** | `task`, `tasks` | Built-in task management with priorities, tags, auto-logged history, and **scheduled/recurring tasks** |
| **Log Hub** | `log` | Universal log receiver β any program sends logs via HTTP, queryable by the AI, live in Viewer |
| **Screenshots** | `screenshot`, `windows` | Cross-platform screen capture with LLM optimization β scale + color reduction saves up to 95% tokens |
| **Viewer** | `viewer` | Interactive browser UI with file tree, signatures, tasks, logs, search, and live reload |
**12 languages** β C#, TypeScript, JavaScript, Rust, Python, C, C++, Java, Go, PHP, Ruby, HCL/Terraform
Quick Examples β see it in action
```
# Find where "PlayerHealth" is defined β 1 call, ~50 tokens
aidex_query({ term: "PlayerHealth" })
β Engine.cs:45, Player.cs:23, UI.cs:156
# All methods in a file β without reading the whole file
aidex_signature({ file: "src/Engine.cs" })
β class GameEngine { Update(), Render(), LoadScene(), ... }
# What changed in the last 2 hours?
aidex_query({ term: "render", modified_since: "2h" })
# Search across ALL your projects at once
aidex_global_query({ term: "TransparentWindow", mode: "contains" })
β Found in: LibWebAppGpu (3 hits), DebugViewer (1 hit)
# Leave a note for your next session
aidex_note({ path: ".", note: "Test the parser fix after restart" })
# Create a task while working
aidex_task({ path: ".", action: "create", title: "Fix edge case in parser", priority: 1, tags: "bug" })
```
## Table of Contents
- [What's Inside](#whats-inside--33-tools-in-one-server)
- [Semantic Search & LLM Layer](#semantic-search--llm-layer) π
- [The Problem](#the-problem)
- [The Solution](#the-solution)
- [Why Not Just Grep?](#why-not-just-grep)
- [How It Works](#how-it-works)
- [Features](#features)
- [Supported Languages](#supported-languages)
- [Quick Start](#quick-start)
- [Available Tools](#available-tools)
- [Time-based Filtering](#time-based-filtering)
- [Project Structure](#project-structure)
- [Session Notes](#session-notes)
- [Task Backlog](#task-backlog)
- [Global Search](#global-search)
- [AI Guidelines](#ai-guidelines)
- [Log Hub](#log-hub--universal-logging)
- [Debug Dashboard](#debug-dashboard)
- [Screenshots β LLM-Optimized](#screenshots--llm-optimized)
- [Interactive Viewer](#interactive-viewer)
- [CLI Usage](#cli-usage)
- [Performance](#performance)
- [Technology](#technology)
- [Contributing](#contributing)
- [License](#license)
## Semantic Search & LLM Layer
**v2.0** added semantic search via locally-run embeddings β your AI can find a function even when it doesn't know the exact identifier.
### Three modes β pick the right tool for the question
| Mode | What it does | When to use |
|------|--------------|-------------|
| `exact` | Identifier match (same as `aidex_query`) | You know the name. `PlayerHealth` β 3 hits |
| `semantic` | Vector KNN over embedded code+docs+workspace | You know the *concept*. "how do we cache the model" β finds `getQueryEmbedder` |
| `hybrid` (default) | RRF fusion of both | Mixed queries. Robust by default |
### What gets embedded
- **Code** β every method and type, three-tier chunking (signature + doc-comment + weighted identifier bag)
- **Docs** β Markdown sections (README, CHANGELOG, docs/, plan files), split at heading boundaries
- **Workspace** β tasks, task logs, session notes, archived note history
One ranking, all kinds. A query like *"how to write logs from external programs"* surfaces the README's `## Log Hub` section first, then the `log` method in `commands/log.ts`, then any related task.
### Setup
```js
// Enable embeddings on a project (one-time, ~30s for AiDex itself, cached afterwards)
aidex_init({ path: ".", embeddings: true })
// Search
aidex_search({ query: "how do we batch requests to the LLM", path: "." })
aidex_search({ query: "retry with backoff", scope: "all" }) // across every embedded project
```
Or use the **Settings tab** in the Viewer (`aidex_settings({ path: ".", open: true })`) β toggles for embeddings, LLM provider, model, and the privacy switch.
### Optional LLM layer
When an Anthropic / OpenAI / OpenRouter / Ollama / HuggingFace API key is configured, AiDex can:
- **Translate** non-English queries β "wie speichere ich Logs lokal" finds the right code
- **Expand** vague queries into 2-4 concrete subqueries (RRF-merged)
- **Rerank** top-N retrieval candidates
Privacy switch `llm_send_code` defaults to **off** β only your literal query and metadata (paths, names, anchors) are sent. Code bodies stay local. Per-project, easy to verify in Settings.
Local-first: works fully offline with pure embeddings. The LLM layer is opt-in, never required.
## The Problem
Every time your AI assistant searches for code, it:
- **Greps** through thousands of files β hundreds of results flood the context
- **Reads** file after file to understand the structure β more context consumed
- **Forgets** everything when the session ends β repeat from scratch
A single "Where is X defined?" question can eat 2,000+ tokens. Do that 10 times and you've burned half your context on navigation alone.
## The Solution
Index once, query forever:
```
# Before: grep flooding your context
AI: grep "PlayerHealth" β 200 hits in 40 files
AI: read File1.cs, File2.cs, File3.cs...
β 2000+ tokens consumed, 5+ tool calls
# After: precise results, minimal context
AI: aidex_query({ term: "PlayerHealth" })
β Engine.cs:45, Player.cs:23, UI.cs:156
β ~50 tokens, 1 tool call
```
**Result: 50-80% less context used for code navigation.**
## Why Not Just Grep?
| | Grep/Ripgrep | AiDex |
|---|---|---|
| **Context usage** | 2000+ tokens per search | ~50 tokens |
| **Results** | All text matches | Only identifiers |
| **Precision** | `log` matches `catalog`, `logarithm` | `log` finds only `log` |
| **Persistence** | Starts fresh every time | Index survives sessions |
| **Structure** | Flat text search | Knows methods, classes, types |
**The real cost of grep**: Every grep result includes surrounding context. Search for `User` in a large project and you'll get hundreds of hits - comments, strings, partial matches. Your AI reads through all of them, burning context tokens on noise.
**AiDex indexes identifiers**: It uses Tree-sitter to actually parse your code. When you search for `User`, you get the class definition, the method parameters, the variable declarations - not every comment that mentions "user".
## How It Works
1. **Index your project once** (~1 second per 1000 files)
```
aidex_init({ path: "/path/to/project" })
```
2. **AI searches the index instead of grepping**
```
aidex_query({ term: "Calculate", mode: "starts_with" })
β All functions starting with "Calculate" + exact line numbers
aidex_query({ term: "Player", modified_since: "2h" })
β Only matches changed in the last 2 hours
```
3. **Get file overviews without reading entire files**
```
aidex_signature({ file: "src/Engine.cs" })
β All classes, methods, and their signatures
```
The index lives in `.aidex/index.db` (SQLite) - fast, portable, no external dependencies.
## Features
- **Tree-sitter Parsing**: Real code parsing, not regex β indexes identifiers, ignores keywords and noise
- **~50 Tokens per Search**: vs 2000+ with grep β your AI keeps its context for actual work
- **Persistent Index**: Survives between sessions β no re-scanning, no re-reading
- **Incremental Updates**: Re-index single files after changes, not the whole project
- **Time-based Filtering**: Find what changed in the last hour, day, or week
- **Auto-Cleanup**: Excluded files (e.g., build outputs) are automatically removed from index
- **Zero Dependencies**: SQLite with WAL mode β single file, fast, portable
## Supported Languages
| Language | Extensions |
|----------|------------|
| C# | `.cs` |
| TypeScript | `.ts`, `.tsx` |
| JavaScript | `.js`, `.jsx`, `.mjs`, `.cjs` |
| Rust | `.rs` |
| Python | `.py`, `.pyw` |
| C | `.c`, `.h` |
| C++ | `.cpp`, `.cc`, `.cxx`, `.hpp`, `.hxx` |
| Java | `.java` |
| Go | `.go` |
| PHP | `.php` |
| Ruby | `.rb`, `.rake` |
| HCL/Terraform | `.tf`, `.tfvars`, `.hcl` |
## Quick Start
### Prerequisites
- **Node.js β₯ 18** (check with `node --version`)
- macOS: `brew install node` or `nvm install 18 && nvm use 18`
- Linux: use your package manager or [nvm](https://github.com/nvm-sh/nvm)
- Windows: [nodejs.org](https://nodejs.org/)
- If you use `nvm`, the repo ships a `.nvmrc` β `nvm use` picks the right version automatically.
### 1. Install
```bash
npm install -g aidex-mcp
```
**That's it.** Setup runs automatically after install β it detects your installed AI clients (Claude Code, Claude Desktop, Cursor, Windsurf, Gemini CLI, VS Code Copilot) and registers AiDex as an MCP server. It also adds usage instructions to your AI's config (`~/.claude/CLAUDE.md`, `~/.gemini/GEMINI.md`).
To re-run setup manually: `aidex setup` | To unregister: `aidex unsetup` | To skip auto-setup: `AIDEX_NO_SETUP=1 npm install -g aidex-mcp`
### 2. Or register manually with your AI assistant
**For Claude Code** (`~/.claude/settings.json` or `~/.claude.json`):
```json
{
"mcpServers": {
"aidex": {
"type": "stdio",
"command": "aidex",
"env": {}
}
}
}
```
**For Claude Desktop** (`%APPDATA%/Claude/claude_desktop_config.json` on Windows):
```json
{
"mcpServers": {
"aidex": {
"command": "aidex"
}
}
}
```
> **Note:** Both `aidex` and `aidex-mcp` work as command names.
> **Important:** The server name in your config determines the MCP tool prefix. Use `"aidex"` as shown above β this gives you tool names like `aidex_query`, `aidex_signature`, etc. Using a different name (e.g., `"codegraph"`) would change the prefix accordingly.
**For Gemini CLI** (`~/.gemini/settings.json`):
```json
{
"mcpServers": {
"aidex": {
"command": "aidex"
}
}
}
```
**For VS Code Copilot** (run `MCP: Open User Configuration` in Command Palette):
```json
{
"servers": {
"aidex": {
"type": "stdio",
"command": "aidex"
}
}
}
```
**For other MCP clients**: See your client's documentation for MCP server configuration.
### 3. Make your AI actually use it
Add to your AI's instructions (e.g., `~/.claude/CLAUDE.md` for Claude Code, or the equivalent for your AI client). This tells the AI **when and how** to use AiDex instead of grepping:
```markdown
## AiDex - Persistent Code Index (MCP Server)
AiDex provides fast, precise code search through a pre-built index.
**Always prefer AiDex over Grep/Glob for code searches.**
### REQUIRED: Before using Grep/Glob/Read for code searches
```
Do I want to search code?
βββ .aidex/ exists β STOP! Use AiDex instead
βββ .aidex/ missing β run aidex_init (don't ask), THEN use AiDex
βββ Config/Logs/Text β Grep/Read is fine
```
**NEVER do this when .aidex/ exists:**
- β `Grep pattern="functionName"` β β
`aidex_query term="functionName"`
- β `Grep pattern="class.*Name"` β β
`aidex_query term="Name" mode="contains"`
- β `Read file.cs` to see methods β β
`aidex_signature file="file.cs"`
- β `Glob pattern="**/*.cs"` + Read β β
`aidex_signatures pattern="**/*.cs"`
### Session-Start Rule (REQUIRED β every session, no exceptions)
1. Call `aidex_session({ path: "" })` β detects external changes, auto-reindexes
2. If `.aidex/` does NOT exist β run `aidex_init` automatically (don't ask)
3. If a session note exists β **show it to the user** before continuing
4. **Before ending a session:** always leave a note about what to do next
### Question β Right Tool
| Question | Tool |
|----------|------|
| "Where is X defined?" | `aidex_query term="X"` |
| "Find anything containing X" | `aidex_query term="X" mode="contains"` |
| "All functions starting with X" | `aidex_query term="X" mode="starts_with"` |
| "What methods does file Y have?" | `aidex_signature file="Y"` |
| "Explore all files in src/" | `aidex_signatures pattern="src/**"` |
| "Project overview" | `aidex_summary` + `aidex_tree` |
| "What changed recently?" | `aidex_query term="X" modified_since="2h"` |
| "What files changed today?" | `aidex_files path="." modified_since="8h"` |
| "Have I ever written X?" | `aidex_global_query term="X" mode="contains"` |
| "Which project has class Y?" | `aidex_global_signatures term="Y" kind="class"` |
| "All indexed projects?" | `aidex_global_status` |
### Search Modes
- **`exact`** (default): Finds only the exact identifier β `log` won't match `catalog`
- **`contains`**: Finds identifiers containing the term β `render` matches `preRenderSetup`
- **`starts_with`**: Finds identifiers starting with the term β `Update` matches `UpdatePlayer`, `UpdateUI`
### All Tools (30)
| Category | Tools | Purpose |
|----------|-------|---------|
| Search & Index | `aidex_init`, `aidex_query`, `aidex_update`, `aidex_remove`, `aidex_status` | Index project, search identifiers (exact/contains/starts_with), time filter |
| Signatures | `aidex_signature`, `aidex_signatures` | Get classes + methods without reading files |
| Overview | `aidex_summary`, `aidex_tree`, `aidex_describe`, `aidex_files` | Entry points, file tree, file listing by type |
| Cross-Project | `aidex_link`, `aidex_unlink`, `aidex_links`, `aidex_scan` | Link dependencies, discover projects |
| Global Search | `aidex_global_init`, `aidex_global_query`, `aidex_global_signatures`, `aidex_global_status`, `aidex_global_refresh` | Search across ALL projects |
| Guidelines | `aidex_global_guideline` | Persistent AI instructions & conventions (key-value, global) |
| Sessions | `aidex_session`, `aidex_note` | Track sessions, leave notes (with searchable history) |
| Tasks | `aidex_task`, `aidex_tasks` | Built-in backlog with priorities, tags, summaries, auto-logged history, scheduled/recurring tasks |
| Log Hub | `aidex_log` | Universal log receiver β any program sends logs via HTTP, AI queries them, live in Viewer |
| Screenshots | `aidex_screenshot`, `aidex_windows` | Screen capture with LLM optimization (scale + color reduction, no index needed) |
| Viewer | `aidex_viewer` | Interactive browser UI with file tree, signatures, tasks, and live logs |
**12 languages:** C#, TypeScript, JavaScript, Rust, Python, C, C++, Java, Go, PHP, Ruby, HCL/Terraform
### Session Notes
Leave notes for the next session β they persist in the database:
```
aidex_note({ path: ".", note: "Test the fix after restart" }) # Write
aidex_note({ path: ".", note: "Also check edge cases", append: true }) # Append
aidex_note({ path: "." }) # Read
aidex_note({ path: ".", search: "parser" }) # Search history
aidex_note({ path: ".", clear: true }) # Clear
```
- **Before ending a session:** automatically leave a note about next steps
- **User says "remember for next session: ..."** β write it immediately
### Task Backlog
Track TODOs, bugs, and features right next to your code index:
```
aidex_task({ path: ".", action: "create", title: "Fix bug", priority: 1, tags: "bug" })
aidex_task({ path: ".", action: "update", id: 1, status: "done" })
aidex_task({ path: ".", action: "log", id: 1, note: "Root cause found" })
aidex_tasks({ path: ".", status: "active" })
# Scheduled & recurring tasks
aidex_task({ path: ".", action: "create", title: "Check PR status", due: "3d", interval: "3d", task_action: "gh pr list" })
```
Priority: 1=high, 2=medium, 3=low | Status: `backlog β active β done | cancelled`
### Global Search (across all projects)
```
aidex_global_init({ path: "/path/to/all/repos" }) # Scan & register
aidex_global_init({ path: "...", index_unindexed: true }) # + auto-index small projects
aidex_global_query({ term: "TransparentWindow", mode: "contains" }) # Search everywhere
aidex_global_signatures({ term: "Render", kind: "method" }) # Find methods everywhere
aidex_global_status({ sort: "recent" }) # List all projects
```
### Screenshots
```
aidex_screenshot() # Full screen
aidex_screenshot({ mode: "active_window" }) # Active window
aidex_screenshot({ mode: "window", window_title: "VS Code" }) # Specific window
aidex_screenshot({ scale: 0.5, colors: 2 }) # B&W, half size (ideal for LLM)
aidex_screenshot({ colors: 16 }) # 16 colors (UI readable)
aidex_windows({ filter: "chrome" }) # Find window titles
```
No index needed. Returns file path β use `Read` to view immediately.
**LLM optimization strategy:** Always start with aggressive settings, then retry if unreadable:
1. First try: `scale: 0.5, colors: 2` (B&W, half size β smallest possible)
2. If unreadable: retry with `colors: 16` (adds shading for UI elements)
3. If still unclear: `scale: 0.75` or omit `colors` for full quality
4. **Remember** what works for each window/app during the session β don't retry every time.
```
### 4. Index your project
Ask your AI: *"Index this project with AiDex"*
Or manually in the AI chat:
```
aidex_init({ path: "/path/to/your/project" })
```
## Available Tools
| Tool | Description |
|------|-------------|
| `aidex_init` | Index a project (creates `.aidex/`) |
| `aidex_query` | Search by term (exact/contains/starts_with) |
| `aidex_signature` | Get one file's classes + methods |
| `aidex_signatures` | Get signatures for multiple files (glob) |
| `aidex_update` | Re-index a single changed file |
| `aidex_remove` | Remove a deleted file from index |
| `aidex_summary` | Project overview |
| `aidex_tree` | File tree with statistics |
| `aidex_describe` | Add documentation to summary |
| `aidex_link` | Link another indexed project |
| `aidex_unlink` | Remove linked project |
| `aidex_links` | List linked projects |
| `aidex_status` | Index statistics |
| `aidex_scan` | Find indexed projects in directory tree |
| `aidex_files` | List project files by type (code/config/doc/asset) |
| `aidex_note` | Read/write session notes (persists between sessions) |
| `aidex_session` | Start session, detect external changes, auto-reindex |
| `aidex_viewer` | Open interactive project tree in browser |
| `aidex_task` | Create, read, update, delete tasks with priority and tags |
| `aidex_tasks` | List and filter tasks by status, priority, or tag |
| `aidex_screenshot` | Take a screenshot (fullscreen, window, region) with optional scale + color reduction |
| `aidex_windows` | List open windows for screenshot targeting |
| `aidex_global_init` | Scan directory tree, register all indexed projects in global DB |
| `aidex_global_status` | List all registered projects with stats |
| `aidex_global_query` | Search terms across ALL registered projects |
| `aidex_global_signatures` | Search methods/types by name across all projects |
| `aidex_global_refresh` | Update stats and remove stale projects from global DB |
| `aidex_global_guideline` | Store/retrieve AI guidelines and coding conventions (key-value, global) |
| `aidex_log` | Universal log receiver β start HTTP server, query logs, live stream in Viewer |
## Time-based Filtering
Track what changed recently with `modified_since` and `modified_before`:
```
aidex_query({ term: "render", modified_since: "2h" }) # Last 2 hours
aidex_query({ term: "User", modified_since: "1d" }) # Last day
aidex_query({ term: "API", modified_since: "1w" }) # Last week
```
Supported formats:
- **Relative**: `30m` (minutes), `2h` (hours), `1d` (days), `1w` (weeks)
- **ISO date**: `2026-01-27` or `2026-01-27T14:30:00`
Perfect for questions like *"What did I change in the last hour?"*
## Project Structure
AiDex indexes ALL files in your project (not just code), letting you query the structure:
```
aidex_files({ path: ".", type: "config" }) # All config files
aidex_files({ path: ".", type: "test" }) # All test files
aidex_files({ path: ".", pattern: "**/*.md" }) # All markdown files
aidex_files({ path: ".", modified_since: "30m" }) # Changed this session
```
File types: `code`, `config`, `doc`, `asset`, `test`, `other`, `dir`
Use `modified_since` to find files changed in this session - perfect for *"What did I edit?"*
## Session Notes
Leave reminders for the next session - no more losing context between chats:
```
aidex_note({ path: ".", note: "Test the glob fix after restart" }) # Write
aidex_note({ path: ".", note: "Also check edge cases", append: true }) # Append
aidex_note({ path: "." }) # Read
aidex_note({ path: ".", clear: true }) # Clear
```
**Note History** (v1.10): Old notes are automatically archived when overwritten or cleared. Browse and search past notes:
```
aidex_note({ path: ".", history: true }) # Browse archived notes (shows summaries)
aidex_note({ path: ".", search: "parser" }) # Search note history (searches summaries too)
aidex_note({ path: ".", history: true, limit: 5 }) # Last 5 archived notes
```
**Note Summaries** (v1.15): Provide a `summary` when writing/clearing a note β the archived note gets this one-sentence description. History then shows summaries instead of truncated text:
```
aidex_note({ path: ".", note: "New focus", summary: "Previous session: finished parser refactoring" })
```
**Use cases:**
- Before ending a session: *"Remember to test X next time"*
- AI auto-reminder: Save what to verify after a restart
- Handover notes: Context for the next session without editing config files
- Search past sessions: *"What did we do about the parser?"*
Notes are stored in the SQLite database (`.aidex/index.db`) and persist indefinitely.
## Task Backlog
Keep your project tasks right next to your code index - no Jira, no Trello, no context switching:
```
aidex_task({ path: ".", action: "create", title: "Fix parser bug", priority: 1, tags: "bug", summary: "Parser crashes on nested generics in C#" })
aidex_task({ path: ".", action: "update", id: 1, status: "done" })
aidex_task({ path: ".", action: "log", id: 1, note: "Root cause: unbounded buffer" })
aidex_tasks({ path: ".", status: "active" })
```
### Scheduled & Recurring Tasks
Tasks can have due dates and repeat intervals. Overdue tasks are reported at every session start across ALL projects:
```
# One-shot: remind in 3 days
aidex_task({ path: ".", action: "create", title: "Review PR", due: "3d", task_action: "Check if PR was submitted" })
# Recurring: check every week
aidex_task({ path: ".", action: "create", title: "Check dependencies", due: "1w", interval: "1w", task_action: "npm outdated" })
# Auto-execute: runs the action automatically when due
aidex_task({ path: ".", action: "create", title: "Refresh stats", due: "1d", interval: "1d", auto_go: true })
```
**Due formats:** Relative (`"30m"`, `"2h"`, `"3d"`, `"1w"`) or ISO date (`"2026-04-10"`)
At every `aidex_session` call, the **Task Scheduler** checks `~/.aidex/global.db` for due tasks across all projects β even if you're working on a different project. Recurring tasks automatically advance their due date after each trigger.
**Features:**
- **Summaries**: One-sentence table-of-contents per task β scan the backlog without reading full details
- **Priorities**: π΄ high, π‘ medium, βͺ low
- **Statuses**: `backlog β active β done | cancelled`
- **Tags**: Categorize tasks (`bug`, `feature`, `docs`, etc.)
- **History log**: Every status change is auto-logged, plus manual notes
- **Scheduling**: Due dates, recurring intervals, actions, auto-execute across all projects
- **Viewer integration**: Tasks tab in the browser viewer with live updates
- **Persistent**: Tasks survive between sessions, stored in `.aidex/index.db`
Your AI assistant can create tasks while working (*"found a bug in the parser, add it to the backlog"*), track progress, and pick up where you left off next session.
## Global Search
Search across ALL your indexed projects at once. Perfect for *"Have I ever written a transparent window?"* or *"Where did I use that algorithm?"*
### Setup
```
aidex_global_init({ path: "Q:/develop" }) # Scan & register
aidex_global_init({ path: "Q:/develop", exclude: ["llama.cpp"] }) # Skip external repos
aidex_global_init({ path: "Q:/develop", index_unindexed: true }) # Auto-index all found projects
aidex_global_init({ path: "Q:/develop", index_unindexed: true, show_progress: true }) # With browser progress UI
```
This scans your project directory, registers all AiDex-indexed projects in a global database (`~/.aidex/global.db`), and reports any unindexed projects it finds by detecting project markers (`.csproj`, `package.json`, `Cargo.toml`, etc.).
With `index_unindexed: true`, it also auto-indexes all discovered projects with β€500 code files. Larger projects are listed separately for user decision. Add `show_progress: true` to open a live progress UI in your browser (`http://localhost:3334`).
### Search
```
aidex_global_query({ term: "TransparentWindow" }) # Exact match
aidex_global_query({ term: "transparent", mode: "contains" }) # Fuzzy search
aidex_global_signatures({ term: "Render", kind: "method" }) # Find methods
aidex_global_signatures({ term: "Player", kind: "class" }) # Find classes
```
### How it works
- Uses SQLite `ATTACH DATABASE` to query project databases directly β no data copying
- Results are cached in memory (5-minute TTL) for fast repeated queries
- Projects are batched (8 at a time) to respect SQLite's attachment limit
- Each project keeps its own `.aidex/index.db` as the single source of truth
- **Auto-deduplication**: Parent projects that contain sub-projects are automatically skipped (e.g., `MyApp/` is removed when `MyApp/Frontend/` and `MyApp/Backend/` exist as separate indexed projects)
### Management
```
aidex_global_status() # List all projects
aidex_global_status({ sort: "recent" }) # Most recently indexed first
aidex_global_refresh() # Update stats, remove stale
```
## AI Guidelines
Store persistent coding conventions, review checklists, and AI instructions in a single place β shared across all projects.
```
aidex_global_guideline({ action: "set", key: "review", value: "Always check: error handling, null safety, no hardcoded strings" })
aidex_global_guideline({ action: "set", key: "style", value: "Use PascalCase for classes, camelCase for methods, 4-space indent" })
aidex_global_guideline({ action: "get", key: "review" }) # Retrieve a guideline
aidex_global_guideline({ action: "list" }) # Show all guidelines
aidex_global_guideline({ action: "list", filter: "code" }) # Filter by name
aidex_global_guideline({ action: "delete", key: "old-rule" }) # Remove a guideline
```
**Use cases:**
- **Code review checklist**: Tell your AI exactly what to look for every time
- **Coding conventions**: Store team style rules once, reference them in any project
- **Release checklist**: Step-by-step process for shipping
- **Project-agnostic instructions**: No more pasting the same context into every session
Guidelines are stored in `~/.aidex/global.db` β available across all your projects without `aidex_init`. Ask your AI: *"Load the review guideline and apply it to this file."*
## Log Hub β Universal Logging
Turn any program into a log source for your AI assistant. Your app sends logs via HTTP POST, the AI queries them via MCP, and you see them live in the Viewer β zero dependencies, zero setup in your code.
### How it works
```
Your Program ββHTTP POSTβββ AiDex Log Hub (port 3335) βββ Ring Buffer
β β
β WebSocket β MCP query
β β
Viewer (Logs tab) AI Assistant
(you see live) (queries & analyzes)
```
### Quick start
1. AI starts the Log Hub: `aidex_log({ action: "init" })`
2. AI opens the Viewer: `aidex_viewer({ path: "." })` β Logs tab shows live stream
3. Add one line to your program:
```csharp
// C#
await new HttpClient().PostAsJsonAsync("http://localhost:3335/log",
new { level = "info", source = "MyApp", message = "Player spawned", data = new { x = 10, y = 20 } });
```
```python
# Python
requests.post("http://localhost:3335/log", json={"level": "info", "source": "MyApp", "message": "Done"})
```
```javascript
// JavaScript
fetch("http://localhost:3335/log", {
method: "POST", headers: {"Content-Type": "application/json"},
body: JSON.stringify({level: "info", source: "MyApp", message: "Started"})
});
```
```powershell
# PowerShell
Invoke-RestMethod -Uri http://localhost:3335/log -Method POST -ContentType "application/json" -Body '{"level":"info","source":"Script","message":"Done"}'
```
### HTTP API
| Endpoint | Method | Body | Description |
|----------|--------|------|-------------|
| `/log` | POST | `{ level, source, message, data? }` | Single log entry |
| `/logs` | POST | `[{ ... }, ...]` | Batch (multiple at once) |
| `/health` | GET | β | Status + buffer usage |
**Fields:** `level` (`debug`/`info`/`warn`/`error`), `source` (app name), `message` (text, required), `data` (optional JSON), `timestamp` (optional, ms)
### Features
- **Ring Buffer**: Fixed-size in-memory FIFO (default 10,000 entries) β oldest entries overwritten
- **Zero-cost**: No server, no buffer, no resources until `init` is called
- **Persistence**: Optional SQLite storage with 7-day auto-cleanup (`persist: true`)
- **Consume pattern**: `query` with `consume: true` removes returned entries β ideal for polling
- **Viewer integration**: Logs tab with WebSocket live-stream, level/source/text filters, auto-scroll
- **Fire & forget**: Just POST and go β if the server isn't running, the POST silently fails
## Debug Dashboard
The scrolling log stream is great for *what happened when* β but useless for fast, repeating values (audio levels, buffer fill, FPS, sensor readings). The **Debug Dashboard** is the opposite: a fixed-slot panel where each value has a permanent spot and **overwrites in place** instead of scrolling away. Live in the Viewer's **Debug tab**, styled like a hardware monitor (MSI Afterburner / HWiNFO).
It rides on the same Log Hub server β no extra setup. Your program sends widget updates via HTTP POST; sending the same `id` again updates that widget.
### Widget types
| Type | Looks like | Use for |
|------|-----------|---------|
| `label` | big value + unit | FPS, state text, counters |
| `progress` | bar with warn/crit colouring | buffer fill, percentages |
| `gauge` | radial tachometer (or status LED for strings) | temperature, load, ok/warn/error |
| `plot` | real-time line graph with grid + min/max/avg | audio signal, latency, any time series |
### Send a widget
```bash
# A single widget β id is the fixed slot, type is required on first send
curl -X POST http://localhost:3335/panel -H "Content-Type: application/json" \
-d '{"id":"mic","type":"plot","value":0.73,"group":"Audio","label":"Mic Level","unit":"dB"}'
# A gauge with threshold zones (green < warn < yellow < crit < red)
curl -X POST http://localhost:3335/panel -H "Content-Type: application/json" \
-d '{"id":"gpu_temp","type":"gauge","value":67,"min":0,"max":100,"warn":75,"crit":90,"group":"Hardware"}'
```
**Fields:** `id` (required), `type` (`label`/`progress`/`gauge`/`plot`, required on first send), `value` (number, status string, or number array for a full plot frame), `group`, `label`, `unit`, `min`, `max`, `warn`, `crit`, `color`, `order`.
**Endpoints:** `POST /panel` (one), `POST /panels` (batch), `POST /panel/clear` (`{id}` for one, empty for all).
### Lifecycle
- The server keeps the last state per `id`, so a freshly-opened or reloaded Viewer shows the whole dashboard immediately.
- Cards with no update for ~3 s grey out as "stale".
- **Clear** is a full reset: it empties the store. A source only reappears if it sends widgets *with their `type`* again (plain value-only updates to a cleared id are ignored).
- Backpressure-guarded β a slow browser can't make the server's send-queue grow without bound.
### Try it β the built-in demo
A ready-to-run showcase animates all widget types (audio waveform, GPU gauges drifting through their zones, a signal generator cycling sine β sawtooth β triangle β square, latency spikes):
```bash
# 1. Start the Log Hub + Viewer from your AI assistant:
# aidex_log({ action: "init" })
# aidex_viewer({ path: "." }) β click the Debug tab
# 2. Run the demo (from the AiDex repo root):
node scripts/demo-dashboard.mjs # endless loop, Ctrl+C to stop (clears on exit)
```
Or use the **β· Demo** button on the Debug tab β it copies the run command to your clipboard; paste it into a terminal. (The browser can't spawn a process itself.) `scripts/demo-dashboard.ps1` is a one-command launcher that checks the Log Hub first.
> Running it twice starts two instances that fight over the same widgets (visible flicker) β stop the old one (Ctrl+C) before starting another.
## Screenshots β LLM-Optimized
Take screenshots and **reduce them up to 95%** for LLM context. A typical screenshot goes from ~100 KB to ~5 KB β that's thousands of tokens saved per image.
### Why this matters
| | Raw Screenshot | Optimized (scale=0.5, colors=2) |
|---|---|---|
| **File size** | ~100-500 KB | ~5-15 KB |
| **Tokens consumed** | ~5,000-25,000 | ~250-750 |
| **Text readable?** | Yes | Yes |
| **Colors** | 16M (24-bit) | 2 (black & white) |
Most screenshots in AI context are for reading text β error messages, logs, UI labels. You don't need 16 million colors for that.
### Usage
```
aidex_screenshot() # Full screen (full quality)
aidex_screenshot({ mode: "active_window" }) # Active window
aidex_screenshot({ mode: "window", window_title: "VS Code" }) # Specific window
aidex_screenshot({ scale: 0.5, colors: 2 }) # B&W, half size (best for text)
aidex_screenshot({ scale: 0.5, colors: 16 }) # 16 colors (UI readable)
aidex_screenshot({ colors: 256 }) # 256 colors (good quality)
aidex_screenshot({ mode: "region" }) # Interactive selection
aidex_screenshot({ mode: "rect", x: 100, y: 200, width: 800, height: 600 }) # Coordinates
aidex_windows({ filter: "chrome" }) # Find window titles
```
### Optimization parameters
| Parameter | Values | Description |
|-----------|--------|-------------|
| `scale` | 0.1 - 1.0 | Scale factor (0.5 = half resolution). Most HiDPI screens are 2-3x anyway. |
| `colors` | 2, 4, 16, 256 | Color reduction. 2 = black & white, ideal for text screenshots. |
### Recommended strategy for AI assistants
The tool description tells LLMs to optimize automatically:
1. **Start aggressive**: `scale: 0.5, colors: 2` (smallest possible)
2. **If unreadable**: retry with `colors: 16` (adds shading for UI elements)
3. **If still unclear**: try `scale: 0.75` or full color
4. **Remember**: cache what works per window/app for the rest of the session
This way the AI learns the right settings per app without wasting tokens on oversized images.
### Features
- **5 capture modes**: Fullscreen, active window, specific window (by title), interactive region selection, coordinate-based rectangle
- **Cross-platform**: Windows (PowerShell + System.Drawing), macOS (sips + ImageMagick), Linux (ImageMagick)
- **Multi-monitor**: Select which monitor to capture
- **Delay**: Wait N seconds before capturing (e.g., to open a menu first)
- **Size reporting**: Shows original β optimized size and percentage saved
- **Auto-path**: Default saves to temp directory with fixed filename
- **No index required**: Works standalone, no `.aidex/` needed
## Interactive Viewer
Explore your indexed project visually in the browser:
```
aidex_viewer({ path: "." })
```
Opens `http://localhost:3333` with:
- **Interactive file tree** - Click to expand directories
- **File signatures** - Click any file to see its types and methods
- **Live reload** - Changes detected automatically while you code
- **Git status icons** - See which files are modified, staged, or untracked
- **Logs tab** - Live log stream from Log Hub with filters (level, source, text search)
- **Tasks tab** - View and manage your task backlog





Close with `aidex_viewer({ path: ".", action: "close" })`
## CLI Usage
```bash
aidex scan Q:/develop # Find all indexed projects
aidex init ./myproject # Index a project from command line
```
> `aidex-mcp` works as an alias for `aidex`.
## Performance
| Project | Files | Items | Index Time | Query Time |
|---------|-------|-------|------------|------------|
| Small (AiDex) | 19 | 1,200 | <1s | 1-5ms |
| Medium (RemoteDebug) | 10 | 1,900 | <1s | 1-5ms |
| Large (LibPyramid3D) | 18 | 3,000 | <1s | 1-5ms |
| XL (MeloTTS) | 56 | 4,100 | ~2s | 1-10ms |
## Technology
- **Parser**: [Tree-sitter](https://tree-sitter.github.io/) - Real parsing, not regex
- **Database**: SQLite with WAL mode - Fast, single file, zero config
- **Protocol**: [MCP](https://modelcontextprotocol.io/) - Works with any compatible AI
## Project Structure
```
.aidex/ β Created in YOUR project
βββ index.db β SQLite database
βββ summary.md β Optional documentation
AiDex/ β This repository
βββ src/
β βββ commands/ β Tool implementations
β βββ db/ β SQLite wrapper
β βββ parser/ β Tree-sitter integration
β βββ server/ β MCP protocol handler
βββ build/ β Compiled output
```
## Community
**[GitHub Discussions](https://github.com/CSCSoftware/AiDex/discussions)** β Ask questions, share your setup, suggest ideas.
| Category | For |
|----------|-----|
| [Q&A](https://github.com/CSCSoftware/AiDex/discussions/new?category=q-a) | Setup help, usage questions |
| [Ideas](https://github.com/CSCSoftware/AiDex/discussions/new?category=ideas) | Feature suggestions |
| [Show & Tell](https://github.com/CSCSoftware/AiDex/discussions/new?category=show-and-tell) | Share your workflow |
| [Announcements](https://github.com/CSCSoftware/AiDex/discussions) | Release news (maintainer only) |
## Contributing
See [CONTRIBUTING.md](CONTRIBUTING.md) for full details. Quick summary:
- **Bug?** β [Open an issue](https://github.com/CSCSoftware/AiDex/issues/new?template=bug_report.yml)
- **Idea?** β [Start a Discussion](https://github.com/CSCSoftware/AiDex/discussions/new?category=ideas)
- **New language?** β Add a keyword file in `src/parser/languages/` and open a PR
## License
MIT License - see [LICENSE](LICENSE)
## Authors
Uwe Chalas & Claude