Your AI's black box recorder. CLI + MCP server.
One command captures your entire project state. Switch between Claude Code, Cursor, Copilot, Codex — the next AI picks up instantly. Zero re-explaining.
npm install mindswap --save-dev
npx mindswap init # once — auto-detects everything
npx mindswap # save state when switching tools
npx mindswap mcp-install # enable MCP for Claude Code / CursorYou're mid-feature in Codex. Tokens run out. You switch to Claude Code. It has zero context — doesn't know your architecture, your decisions, or that you're halfway through implementing auth middleware.
You spend 20 minutes re-explaining. Every. Single. Time.
Just run mindswap. That's it.
$ npx mindswap
⚡ Saving project state...
Task: user auth (auto-detected from branch)
Branch: feat/user-auth
Changed: 4 files
Tests: ✓ 12 passed, 0 failed
Decisions: 2 auto-logged from deps
✓ State saved — ready to switch toolsIt auto-detects your task from the branch name, captures git state, logs dependency changes as decisions, and generates context files for every AI tool:
| AI Tool | Generated File | Behavior |
|---|---|---|
| Universal | HANDOFF.md |
Full overwrite |
| Claude Code | CLAUDE.md |
Safe merge |
| Cursor | .cursor/rules/mindswap-context.mdc |
Own file |
| GitHub Copilot | .github/copilot-instructions.md |
Safe merge |
| Codex | CODEX.md |
Safe merge |
| Gemini CLI | GEMINI.md |
Safe merge |
| Windsurf | .windsurfrules |
Own file |
| Cline | .cline/mindswap-context.md |
Own file |
| Roo Code | .roo/rules/mindswap-context.md |
Own file |
| Aider | CONVENTIONS.md |
Safe merge |
| Amp | .amp/mindswap-context.md |
Own file |
| AGENTS.md | AGENTS.md |
Safe merge |
npx mindswap init # once per project
npx mindswap # when switching tools
npx mindswap done # when feature is completeEverything else is automatic — git hooks track commits, dependencies are auto-logged, branch state is auto-managed.
| Command | Alias | What it does |
|---|---|---|
mindswap |
save |
THE one command. Auto-detects task, deps, state — generates all context files |
mindswap init |
— | Initialize. Auto-detects 30+ frameworks, imports existing AI context files |
mindswap switch <tool> |
sw |
One-command tool switch — save + generate + open (cursor/claude/copilot/codex/windsurf) |
mindswap done [msg] |
d |
Mark task complete, archive to history, reset to idle |
mindswap log <msg> |
l |
Log a decision. Warns if it conflicts with existing decisions |
mindswap status |
s |
Current state — task, branch, build/test, conflicts. --stats for charts |
mindswap summary |
sum |
Full session narrative — task, commits, decisions, conflicts. --json for scripts |
mindswap gen --all |
gen |
Generate context files for all AI tools. Safe merge — never overwrites |
mindswap watch |
w |
Background watcher — auto-updates HANDOFF.md on file changes |
mindswap reset |
r |
Clear task state. Decisions preserved. --full to clear everything |
- Task detection — from branch name (
feat/user-auth→ "user auth") + recent commits - Dependency tracking — added Stripe? Auto-logged. Removed Redis? Logged too.
- Git hooks — auto-saves state on every commit
Each git branch has its own state. Switch to feat/payments — it loads that branch's task and decisions. Switch back to main — your main state is restored.
Log "NOT using Redis" then later "using Redis"? mindswap warns you. Also catches reversed choices and package.json contradictions.
Already have a CLAUDE.md? mindswap appends its section inside <!-- mindswap:start/end --> markers. Your content is never touched.
npx mindswap --check # runs tests, captures results
# Tests: ✓ 47 passed, 0 failedThe next AI knows "tests were passing" or exactly what's broken.
Next.js, Remix, Astro, SolidJS, Angular, NestJS, Express, Fastify, Hono, Django, FastAPI, Flask, Gin, Echo, GoFr, Fiber, Actix, Axum, Rails, Spring Boot, and more. Plus databases, monorepo tools, CI/CD, and infrastructure.
.mindswap/
├── HANDOFF.md ← any AI reads this
├── state.json ← machine-readable state
├── decisions.log ← WHY you made each decision
├── config.json ← your preferences
├── branches/ ← per-branch state (auto)
└── history/ ← checkpoint timeline
Commit these (handoff context): state.json, decisions.log, config.json, HANDOFF.md
Don't commit (auto-added to .gitignore): history/, branches/
AI tools can query mindswap natively via Model Context Protocol instead of reading static files. 3 tools, stdio transport.
npx mindswap mcp-install # auto-configures Claude Code, Cursor, VS Code| MCP Tool | When AI calls it | What it returns |
|---|---|---|
mindswap_get_context |
Session start — "What do I need to know?" | Synthesized briefing: task, decisions, conflicts, tests, recent work |
mindswap_save_context |
Session end — "Here's what I did" | Persists summary, decisions, next steps, blockers |
mindswap_search |
Mid-session — "What did we decide about auth?" | Searches decisions + history + state |
Only 3 tools by design. Research shows AI accuracy drops from 82% to 73% past 20 tools. We chose quality over quantity.
All generated context files are scanned for secrets before writing:
- 25+ patterns: AWS keys, GitHub tokens, Stripe keys, OpenAI keys, DB URLs, private keys, JWT secrets, passwords
- Auto-redacted — secrets never reach your HANDOFF.md
- Placeholder-aware — skips
YOUR_KEY_HEREpatterns
npx mindswap pr # adds context summary to your GitHub PRAuto-injects task, decisions, test status into the PR description with safe markers.
Will it overwrite my existing CLAUDE.md?
No. Uses <!-- mindswap:start/end --> markers. Your content is preserved.
Does it work with my AI tool? If it reads markdown files (all of them do), yes.
Does it slow things down? No. Only runs when you call it. Git hook runs silently on commit.
Multiple branches? State is auto per-branch. Switch branches, state switches too.
What languages? JS/TS, Python, Go, Rust, Ruby, Java/Kotlin. Auto-detects from project files.
MIT