Project file map generator for AI-assisted development
Project description
AITree
Project file map generator for AI-assisted development.
Scans a directory and prints a clean, annotated tree that you can paste directly into any AI chat. Instead of uploading your entire codebase, share the map first — then only send the files the AI actually asks for.
webapp/
├── src/
│ ├── components/
│ │ ├── Header.jsx [4KB]
│ │ └── Footer.jsx [2KB]
│ ├── App.jsx [8KB]
│ └── index.js [1KB]
├── public/
│ └── index.html [3KB]
└── package.json [1KB]
# 2 directories, 6 files (18KB total)
#
# File types:
# .jsx 3 ███
# .js 1 █
# .html 1 █
# .json 1 █
Installation
Via pip (recommended):
pip install paracci-aitree
One-liner (Linux / macOS):
curl -fsSL https://raw.githubusercontent.com/paracci/aitree/main/install.sh | bash
From source:
git clone https://github.com/paracci/aitree.git
cd aitree
pip install .
Optional dependencies — install only what you need:
pip install "paracci-aitree[live]" # --live mode (watchdog)
pip install "paracci-aitree[tokens]" # --tokens (tiktoken)
pip install "paracci-aitree[git]" # --git-changed (gitpython)
pip install "paracci-aitree[mcp]" # MCP server (mcp)
pip install "paracci-aitree[all]" # everything + clipboard (pyperclip)
Usage
aitree [path] [options]
path defaults to the current directory if omitted.
Output modes
| Flag | Description |
|---|---|
| (none) | Print tree to stdout |
--save |
Save to _aitree.txt (or _aitree.json / _aitree.md) |
--copy |
Copy output to clipboard |
--live |
Watch for changes and auto-update the saved file |
--serve |
Launch the web UI in your browser |
Output formats
| Flag | Description |
|---|---|
--format text |
Plain text with # comments (default) |
--format json |
Structured JSON with tree + stats + meta |
--format markdown |
Markdown with fenced code block + stats table |
Filtering
| Flag | Description |
|---|---|
--depth N |
Limit tree depth (e.g. --depth 2) |
--include GLOB |
Show only matching files (repeatable) |
--exclude GLOB |
Hide matching files (repeatable) |
--no-gitignore |
Skip .gitignore / .aitreeignore parsing |
--git-changed |
Show only git-changed / untracked files |
Extras
| Flag | Description |
|---|---|
--tokens |
Append estimated token count to output |
--version |
Show version and exit |
Examples
aitree . # current directory → stdout
aitree ~/projects/webapp # specific path → stdout
aitree . --save # save to _aitree.txt
aitree . --copy # copy to clipboard
aitree . --depth 2 # top 2 levels only
aitree . --include "*.py" # Python files only
aitree . --include "*.py" --include "*.js" # multiple patterns
aitree . --exclude "*.test.*" # hide test files
aitree . --git-changed # only modified/untracked files
aitree . --format json --save # save as _aitree.json
aitree . --format markdown --save # save as _aitree.md
aitree . --tokens # append token count
aitree . --live # watch for changes
aitree . --live --depth 2 --git-changed # live + depth + git filter
aitree . --serve # open web UI
aitree . --serve --port 8080 # web UI on a custom port
AI workflow
1. aitree . --copy
2. Paste into your AI chat
3. Ask "Which files do you need?"
4. Send only those files
Web UI
--serve launches a local web server and opens the tree in your browser.
- Interactive tree with collapse / expand
- Filter panel: depth, include, exclude, git-changed
- File content preview on click
- Live reload when the directory changes
aitree . --serve
aitree . --serve --port 8080
MCP Server
AITree ships a Model Context Protocol server so AI assistants (Claude Desktop, etc.) can call it as a tool.
# Install MCP dependency
pip install "paracci-aitree[mcp]"
# Start the server
aitree-mcp
Available tools
| Tool | Description |
|---|---|
aitree_get_tree |
Generate a file tree for a local path or GitHub URL |
aitree_get_stats |
Return structured JSON statistics for a path |
aitree_get_changed |
List git-changed / untracked files |
aitree_read_file |
Read the contents of a file inside the project |
aitree_read_file lets an AI assistant fetch any file it spotted in the tree — without leaving the conversation:
aitree_get_tree(path=".", format="text")
aitree_read_file(path=".", file="src/auth/login.py")
Claude Desktop config (claude_desktop_config.json)
{
"mcpServers": {
"aitree": {
"command": "aitree-mcp"
}
}
}
GitHub URL support
Pass a GitHub repository URL instead of a local path:
aitree https://github.com/owner/repo
aitree https://github.com/owner/repo --depth 2
aitree https://github.com/owner/private-repo --token ghp_xxxx
Works entirely via the GitHub API — no cloning required.
Custom ignore rules
Create .aitreeignore in your project root — same syntax as .gitignore:
# .aitreeignore
*.secret
config/local.json
private/
AITree reads .aitreeignore first, then .gitignore. Use --no-gitignore to skip both.
What gets ignored by default
| Category | Examples |
|---|---|
| VCS & editors | .git, .idea, .vscode, .svn |
| Dependencies | node_modules, .venv, venv, env |
| Build output | dist, build, target, out, bin |
| Cache | __pycache__, .pytest_cache, .mypy_cache |
| Binary & temp | .pyc, .class, .exe, .log, .tmp |
| OS files | .DS_Store, Thumbs.db |
Live mode
--live watches the directory with watchdog and regenerates the output file whenever the structure actually changes. False positives (editor auto-saves, antivirus touches, etc.) are filtered out via content hashing and a 1-second debounce.
🟢 AITree LIVE — Watching: /home/user/projects/webapp [depth=2, git-changed]
Updates trigger only on real changes.
Press Ctrl+C to stop.
[14:32:10] Updated — initial snapshot
[14:33:05] Updated — filesystem change (3 false events skipped)
Combines with any filter flag: --depth, --include, --exclude, --git-changed.
Platform support
| Platform | Tested |
|---|---|
| Linux | ✅ |
| macOS | ✅ |
| Windows | ✅ |
| WSL | ✅ |
Requires Python 3.10+.
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file paracci_aitree-3.1.0.tar.gz.
File metadata
- Download URL: paracci_aitree-3.1.0.tar.gz
- Upload date:
- Size: 36.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2b2c29379cb852a66e35ef8a50f141af472dd828c4a9aec9fbe166d8666370e
|
|
| MD5 |
05aa229b90e8f5f83e4d440b55d4dc7a
|
|
| BLAKE2b-256 |
9e504bea055abd983371ccd1d34ac51c9b18a57db057f637c53b95099c710980
|
File details
Details for the file paracci_aitree-3.1.0-py3-none-any.whl.
File metadata
- Download URL: paracci_aitree-3.1.0-py3-none-any.whl
- Upload date:
- Size: 37.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
70804e1141882ad325210b399f64ce3a3fad9db40cc451bf8beec61d716e3293
|
|
| MD5 |
1275eb0ac140780207c96319ea5220f2
|
|
| BLAKE2b-256 |
122e7bf17459619eefc2f170a9f6f868b4713c21d21500f0289980aa15511d8b
|