Talk to your shell. Commands run. Questions go to AI. No prefixes. No context switching. You just type.
ls -la stay green (shell). Questions like what files are here turn magenta (AI). If a command fails with natural language patterns, it silently reroutes to AI.Works with ZSH and Bash 4+ on macOS, Linux, and WSL.
Supported installation methods:
npm,curl,homebrew,git
npxnpx lacy
curlcurl -fsSL https://lacy.sh/install | bash
# Homebrew
brew tap lacymorrow/tap
brew install lacy
# Manual
git clone https://github.com/lacymorrow/lacy.git ~/.lacy
echo 'source ~/.lacy/lacy.plugin.zsh' >> ~/.zshrc
Real-time visual feedback shows what will happen before you hit enter:
Commands execute in your shell. Natural language goes to your AI agent. No prefixes, no context switching — you just type.
| Input | Routes to | Why |
|---|---|---|
ls -la | Shell | Valid command |
what files are here | AI | Natural language |
git status | Shell | Valid command |
do we have a way to install? | AI | Reserved word — never a real command |
fix the bug | AI | Multi-word, not a command |
kill the process on 3000 | Shell → AI | Valid command, but fails — rerouted |
go ahead and fix it | Shell → AI | "go" is valid, but "ahead" triggers reroute |
!rm -rf * | Shell | ! prefix forces shell |
The first word of your input is also syntax-highlighted in real-time: green for shell commands, magenta for AI queries.
Smart rerouting (auto mode): When a valid command contains natural language patterns (3+ bare words with articles, pronouns, etc.) and fails, lacy shows a hint and automatically re-sends it to the AI agent. Shell reserved words like do, then, in, else are routed directly to the agent — they pass command -v but are never standalone commands.
Terminal context: When you ask the AI a question, lacy automatically includes your current directory, git branch, recent commands, and exit codes, but only what changed since your last query. In supported terminals (tmux, screen, iTerm2, Terminal.app), it also captures the visible screen output so the agent can see error messages and stack traces.
| Mode | Behavior | Activate |
|---|---|---|
| Auto | Smart routing (default) | mode auto |
| Shell | Everything to shell | mode shell or Ctrl+Space |
| Agent | Everything to AI | mode agent or Ctrl+Space |
Lacy auto-detects your installed AI CLI. All tools handle their own auth — no API keys needed.
tool set claude # Use Claude Code
tool set lash # Use Lash
tool set auto # Auto-detect (first available)
Or edit ~/.lacy/config.yaml:
agent_tools:
active: claude # lash, claude, opencode, gemini, codex, custom, or empty for auto
| Command | Description |
|---|---|
mode | Show current mode |
mode [shell|agent|auto] | Switch mode |
tool | Show active AI tool |
tool set <name> | Set AI tool |
ask "query" | Direct query to AI |
Ctrl+Space | Toggle between modes |
After installation, the lacy command is available (no Node required):
lacy setup # Interactive settings (tool, mode, config)
lacy status # Show installation status
lacy doctor # Diagnose common issues
lacy update # Pull latest changes
lacy config edit # Open config in $EDITOR
lacy uninstall # Remove Lacy Shell
lacy help # Show all commands
lacy uninstall
# or
npx lacy --uninstall
# or
curl -fsSL https://lacy.sh/install | bash -s -- --uninstall
Config file: ~/.lacy/config.yaml
agent_tools:
active: claude # lash, claude, opencode, gemini, codex, or empty for auto
modes:
default: auto # shell, agent, auto
api_keys:
openai: "sk-..." # Only needed if no CLI tool installed
anthropic: "sk-ant-..."
No AI response — Check tool to see if a tool is detected. Install one: npm i -g lashcode or brew install claude.
Colors not showing — Ensure your terminal supports 256 colors (green=34, magenta=200, blue=75).
Command rerouted unexpectedly — In auto mode, commands with natural language patterns that fail are re-sent to the AI. Switch to mode shell to disable this, or prefix with !.
Emergency bypass — Prefix any command with ! to force shell execution: !rm -rf node_modules
Requires Bun, gh, and npm login.
bun run release # interactive — prompts for patch/minor/major
bun run release patch # patch bump (1.5.3 → 1.5.4)
bun run release minor # minor bump (1.5.3 → 1.6.0)
bun run release major # major bump (1.5.3 → 2.0.0)
bun run release 2.0.0 # explicit version
The script handles the full release flow:
package.json filesrelease: v<version> and tagsLacy Shell is free and open source. If it saves you time, consider sponsoring the project:
Your support keeps development active and helps cover infrastructure costs.
Lacy is open source and contributions are welcome! Whether you're fixing a typo, adding a feature, or improving docs, we'd love your help.
FSL-1.1-MIT — Functional Source License v1.1 with MIT Future License (converts to MIT after 2 years). See fsl.software for the full text.
No reviews yet. Be the first to rate this tool.
Sign in to leave a review.