Make OpenCode and Claude Code share the same memory β zero config, local-first, and no migration required.
Claude Code writes memory β OpenCode reads it. OpenCode writes memory β Claude Code reads it.
Quick Start β’ Why this exists β’ What makes this different β’ How it works β’ Who this is for β’ FAQ
- Claude Code-compatible memory Uses Claude Codeβs existing memory paths, file format, and taxonomy.
- Zero config
Install + enable plugin, then keep using
opencodeas usual. - Local-first, no migration Memory stays as local Markdown files in the same directory Claude Code already uses.
- Auto-dream consolidation Periodically runs a background memory consolidation pass (Claude-style auto-dream gating).
opencodepython3available inPATH
python3 is a runtime dependency for the wrapper's scoped session detection and fork cleanup logic.
If it is missing or not executable, post-session maintenance becomes less reliable: session targeting can fall back to less precise heuristics, and fork cleanup is skipped for safety.
Common install commands:
# macOS (Homebrew)
brew install python
# Ubuntu / Debian
sudo apt-get update && sudo apt-get install -y python3
# Fedora
sudo dnf install -y python3
# Arch Linux
sudo pacman -S pythonnpm install -g opencode-claude-memory
opencode-memory install # one-time: installs shell hookThis installs:
- The plugin β memory tools + system prompt injection
- The
opencode-memoryCLI β wraps opencode with automatic memory extraction + auto-dream consolidation - A shell hook β defines an
opencode()function in your.zshrc/.bashrcthat delegates toopencode-memory
If python3 is not installed yet, install it first using the commands above before enabling the shell hook.
opencodeThatβs it. Memory extraction runs in the background after each session, and auto-dream consolidation is checked with time/session gates.
To uninstall:
opencode-memory uninstall # removes shell hook from .zshrc/.bashrc
npm uninstall -g opencode-claude-memoryTo print the wrapper package version:
opencode-memory self -vThis removes the shell hook, the CLI, and the plugin. Your saved memories in ~/.claude/projects/ are not deleted.
If you use both Claude Code and OpenCode on the same repository, memory often ends up in separate silos.
This project solves that by making OpenCode read and write memory in Claude Codeβs existing structure, so your context carries over naturally between both tools.
Most memory plugins introduce a new storage model or migration step.
This one is a compatibility layer, not a new memory system:
- same memory directory conventions as Claude Code
- same Markdown + frontmatter format
- same memory taxonomy (
user,feedback,project,reference) - same project/worktree resolution behavior
The outcome: shared context across Claude Code and OpenCode without maintaining two memory systems.
graph LR
A[You run opencode] --> B[Shell hook calls opencode-memory]
B --> C[opencode-memory finds real binary]
C --> D[Runs opencode normally]
D --> E[You exit]
E --> F[Extract memories if needed]
F --> G[Evaluate auto-dream gate]
G --> H[Consolidate memories if gate passes]
H --> I[Memories saved to ~/.claude/projects/]
The shell hook defines an opencode() function that delegates to opencode-memory:
- Shell function intercepts
opencodecommand (higher priority than PATH) opencode-memoryfinds the realopencodebinary in PATH- Runs it with all your arguments
- After you exit, it checks whether the session already wrote memory files
- If needed, it forks the session with a memory extraction prompt
- It evaluates the auto-dream gate (default: at least 24h since last consolidation and 5 touched sessions)
- If the gate passes, it runs a background consolidation pass to merge/prune memories
- Maintenance runs in the background unless
OPENCODE_MEMORY_FOREGROUND=1 - Terminal maintenance logs are shown in foreground mode by default, or can be forced on/off with
OPENCODE_MEMORY_TERMINAL_LOG=1|0
The wrapper expects python3 to be available at runtime.
It is used for:
- scoped session selection from
opencode session list - parsing
opencode exportoutput to resolve session directories - safely identifying and cleaning up forked extraction / auto-dream sessions
Without python3, the plugin tools still load, but wrapper maintenance is degraded and fork cleanup is intentionally skipped to avoid deleting the wrong session.
The implementation ports core logic from Claude Code for path hashing, git-root/worktree handling, memory format, and memory prompting behavior, so both tools can operate on the same files safely.
Key modules ported from Claude Code's src/memdir/:
| Module | Source | Purpose |
|---|---|---|
memoryScan.ts |
memoryScan.ts |
Recursive directory scan + frontmatter header parsing |
recall.ts |
findRelevantMemories.ts |
Memory recall via keyword scoring (heuristic, no LLM side-query) |
prompt.ts |
memoryTypes.ts + memdir.ts |
System prompt sections, type taxonomy, truncation |
memory.ts |
memdir.ts |
truncateEntrypoint() aligned with truncateEntrypointContent() |
- You use both Claude Code and OpenCode.
- You want one shared memory context across both tools.
- You prefer file-based, local-first memory you can inspect in Git/worktrees.
- You donβt want migration overhead or lock-in.
No. It is a compatibility layer that lets OpenCode use Claude Code-compatible memory layout and conventions.
No migration required. If you already have Claude Code memory files, OpenCode can work with them directly.
In local files under Claude-style project memory directories (for example, under ~/.claude/projects/<project>/memory/).
File-based memory is transparent, local-first, easy to inspect/diff/back up, and works naturally with existing developer workflows.
Yes. Set OPENCODE_MEMORY_EXTRACT=0.
Yes. Set OPENCODE_MEMORY_AUTODREAM=0. You can also tune gates with:
OPENCODE_MEMORY_AUTODREAM_MIN_HOURSOPENCODE_MEMORY_AUTODREAM_MIN_SESSIONS
OPENCODE_MEMORY_EXTRACT(default1): set0to disable automatic memory extractionOPENCODE_MEMORY_FOREGROUND(default0): set1to run maintenance in foregroundOPENCODE_MEMORY_TERMINAL_LOG(defaultforeground-only): set1to force terminal logs on,0to force them offOPENCODE_MEMORY_MODEL: override model used for extractionOPENCODE_MEMORY_AGENT: override agent used for extractionOPENCODE_MEMORY_AUTODREAM(default1): set0to disable auto-dream consolidationOPENCODE_MEMORY_AUTODREAM_MIN_HOURS(default24): min hours between consolidation runsOPENCODE_MEMORY_AUTODREAM_MIN_SESSIONS(default5): min touched sessions since last consolidationOPENCODE_MEMORY_AUTODREAM_MODEL: override model used for auto-dreamOPENCODE_MEMORY_AUTODREAM_AGENT: override agent used for auto-dream
Logs are written to $TMPDIR/opencode-memory-logs/:
extract-*.log: automatic memory extractiondream-*.log: auto-dream consolidation
By default, terminal log lines are only printed when maintenance runs in foreground (OPENCODE_MEMORY_FOREGROUND=1). Background runs stay quiet unless you explicitly set OPENCODE_MEMORY_TERMINAL_LOG=1.
Lock files prevent concurrent extraction/consolidation runs per project root. Stale locks are cleaned up automatically.
Each memory is a Markdown file with YAML frontmatter:
---
name: User prefers terse responses
description: User wants concise answers without trailing summaries
type: feedback
---
Skip post-action summaries. User reads diffs directly.
**Why:** User explicitly requested terse output style.
**How to apply:** Don't summarize changes at the end of responses.Supported memory types:
userfeedbackprojectreference
memory_save: save/update a memorymemory_delete: delete a memory by filenamememory_list: list memory metadatamemory_search: search by keywordmemory_read: read full memory content
# Run tests
bun test
# Build published artifacts
bun run build
# Release: push to main triggers semantic-release β npm publish