Skip to main content

File-based memory system for AI coding assistants

Project description

Mind

Mind gives Claude a mind - not just memory across sessions, but focus within them. It remembers what worked, what didn't, and what it's supposed to be building.

When you're vibe coding with Claude, it forgets everything between sessions. What you decided, what broke, what worked - gone. Even worse, in long sessions it starts suggesting the same failed fixes over and over.

Mind fixes both problems with two-layer memory:

  • MEMORY.md - Long-term memory across sessions
  • SESSION.md - Short-term focus within a session

Why Mind?

4 commands + 1 prompt. Clone, sync, init, connect. Done.

Fully automated. Memory just works - no commands required:

  • Claude writes memories as it works
  • Session gaps auto-detected (30 min)
  • Learnings auto-promoted to long-term memory
  • Context auto-injected into CLAUDE.md
  • Reminders auto-surface when due or when keywords match

Optional tools are there when you want them, but the core memory flow runs hands-free.

Two-layer memory:

  • Cross-session recall (MEMORY.md)
  • Within-session focus (SESSION.md)

Zero friction. Claude writes to files, MCP reads them lazily. No database, no cloud, no sync issues.

Human-readable. Plain .md files you can open, edit, or git-track anytime.

Open source. See exactly how it works. No black box.


Ready to Give Claude a Mind?

4 commands + 1 prompt. Zero friction.

1. Install Mind

git clone https://github.com/vibeforge1111/vibeship-mind.git
cd vibeship-mind
uv sync
uv run mind init
If uv sync fails, install uv first
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# Windows (PowerShell)
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

2. Tell Claude Code to connect

Just paste this to Claude:

Add Mind MCP server to my config

Then in any project, say: "Let's run The Mind"


MCP Config Reference (if Claude needs help)

Config file location:

  • Mac/Linux: ~/.config/claude/mcp.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json

Add this (replace path with where you cloned vibeship-mind):

{
  "mcpServers": {
    "mind": {
      "command": "uv",
      "args": ["--directory", "/path/to/vibeship-mind", "run", "mind", "mcp"]
    }
  }
}

Restart Claude Code after adding.


MCP Tools (12 total)

Core:

Tool What it does
mind_recall() Load session context - CALL FIRST every session
mind_log(msg, type) Log to session or memory (routes by type)

Type routing for mind_log():

  • SESSION.md: experience, blocker, assumption, rejected
  • MEMORY.md: decision, learning, problem, progress
  • SELF_IMPROVE.md: feedback, preference, blind_spot, skill
  • Special: reinforce (boosts pattern confidence)

Reading:

Tool What it does
mind_session() Check current session state
mind_search(query) Search past memories
mind_status() Check memory health
mind_reminders() List pending reminders

Actions:

Tool What it does
mind_blocker(desc) Log blocker + auto-search memory for solutions
mind_remind(msg, when) Set reminder - time or context-based
mind_reminder_done(index) Mark a reminder as done
mind_edges(intent) Check for gotchas before risky code
mind_checkpoint() Force process pending memories
mind_add_global_edge() Add cross-project gotcha

How It Works

Long-term (MEMORY.md): Permanent knowledge - decisions, learnings, problems, progress. mind_recall() loads this as context each session.

Short-term (SESSION.md): Working memory buffer:

  • Experience - Raw moments, thoughts, what's happening
  • Blockers - Things stopping progress
  • Rejected - What didn't work and why
  • Assumptions - What you're assuming true

When a new session starts (30 min gap), valuable items get promoted from SESSION.md to MEMORY.md automatically.

See docs/HOW_IT_WORKS.md for the full architecture.


Reminders

Mind supports two types of reminders:

Time-based:

  • "tomorrow", "in 3 days", "next session", "2025-12-20"

Context-based:

  • "when I mention auth" - triggers when relevant keywords come up
  • "when we work on database" - Claude sees keywords and surfaces reminder naturally

Example: "Remind me to check the security audit when we work on auth"

Reminders are stored in .mind/REMINDERS.md and shown in mind_recall() output.


Initialize Mind in Any Project

Run this command, replacing the paths:

uv --directory /path/to/vibeship-mind run mind init /path/to/your/project

Example (Windows):

uv --directory C:\Users\YOU\vibeship-mind run mind init C:\Users\YOU\my-project

Example (Mac/Linux):

uv --directory ~/vibeship-mind run mind init ~/my-project

Using Claude Code? Just paste this:

Run uv --directory /path/to/vibeship-mind run mind init . to set up Mind in this project

(Replace /path/to/vibeship-mind with where you cloned it)

This creates .mind/MEMORY.md and .mind/SESSION.md.


Quick Commands

# Check if everything is working
uv --directory /path/to/vibeship-mind run mind doctor

# See what Mind extracted from your notes (run from project dir, or pass path)
uv --directory /path/to/vibeship-mind run mind parse /path/to/your/project

# Check project status
uv --directory /path/to/vibeship-mind run mind status /path/to/your/project

# List all registered projects
uv --directory /path/to/vibeship-mind run mind list

The Problem This Solves

Across sessions:

  • "What did we decide yesterday?" → Forgotten
  • "What gotchas did we hit?" → Re-discovered every time

Within sessions:

  • "Didn't we already try that?" → Suggests same failed fix 3 times
  • "What are we building again?" → Drifts into rabbit holes

Mind fixes both. Two layers of memory, zero friction.


File Structure

your-project/
├── .mind/
│   ├── MEMORY.md     ← Long-term memory (persists)
│   ├── SESSION.md    ← Short-term focus (cleared each session)
│   ├── REMINDERS.md  ← Time and context-based reminders
│   ├── config.json   ← Feature flags for experiments
│   └── state.json    ← Timestamps for session detection
└── CLAUDE.md         ← Mind injects context here

Troubleshooting

Problem Fix
"Command not found" Use full path: uv --directory /path/to/vibeship-mind run mind ...
Nothing being captured Use keywords: decided, problem, learned, gotcha
Claude repeating mistakes Tell Claude: "Check SESSION.md" or "Add to Rejected Approaches"
Need to check health uv --directory /path/to/vibeship-mind run mind doctor

Documentation


License

Apache 2.0 - See LICENSE for details.


Built by @meta_alchemist

A vibeship.co ecosystem project

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mind_memory-2.1.0.tar.gz (13.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mind_memory-2.1.0-py3-none-any.whl (58.4 kB view details)

Uploaded Python 3

File details

Details for the file mind_memory-2.1.0.tar.gz.

File metadata

  • Download URL: mind_memory-2.1.0.tar.gz
  • Upload date:
  • Size: 13.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for mind_memory-2.1.0.tar.gz
Algorithm Hash digest
SHA256 6ffb7d987597fad2c7508b5afa6ae03bafc6fc2aa0c19287c6badc22ea2bff94
MD5 e5f27dbcadc1512df59ceb76043c5e49
BLAKE2b-256 33f8af4bf69063373cf3760f91700b838889378deb9aec299e0808e23f96e87d

See more details on using hashes here.

File details

Details for the file mind_memory-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: mind_memory-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 58.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for mind_memory-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aa259d1fdea993159ca60e6d6e673f591c3137b1053ac7ad9bf92958673b409d
MD5 b45e26b4dcf778b7c0421b9b03ce56e5
BLAKE2b-256 f649dc59076317496a85c4abd3ce74145ccbd0339c01cf7ab18fe1cb203b67c9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page