loading…
Search for a command to run...
loading…
Local-first cross-agent memory MCP. 6-layer structured brain (goal/context/emotion/impl/caveat/learning) with token-saving file diff cache (86% measured savings
Local-first cross-agent memory MCP. 6-layer structured brain (goal/context/emotion/impl/caveat/learning) with token-saving file diff cache (86% measured savings on re-reads)
Your agent forgets everything when a session ends. Worse — it silently drifts from what you decided last week.
Linksee Memory catches when your project drifts from its own decisions — the option abandoned at a fork, the pipeline that quietly stalled, the code that contradicts what you agreed — and a re-injection guard re-surfaces the locked decision before the agent acts. Hard contradictions get blocked.
Underneath sits a local-first cross-LLM memory MCP — one SQLite file that Claude Code, Cursor, Windsurf, OpenAI Codex, and Gemini CLI all read from. Not just "what happened" but WHY: 6-layer structured memory with precision recall and an AST-aware diff cache (50–99% token savings on re-reads).
npx linksee-memory-setup— one command, done.
npm license mcp-registry glama-score
🌐 Landing page: linksee-site.vercel.app (includes non-developer onboarding for Claude Desktop / Cursor / Claude Code / OpenAI Codex / Gemini CLI)
「Cordex/Cursor/Code/Gemini 全部につなげられるから、 横断的にできてる MCP ってところがこれのすごいところ」 — Hatena Bookmark, May 2026 (165+ users)
Drift, caught. Decisions don't survive session boundaries — but their consequences do. Ask any session:
You: What's drifting right now?
Agent: [calls drift_status]
28 anchors: ⚪ 1 held · 🔵 27 aligned
Needs attention:
⚪ HELD — "Focus on 4 areas: Recipe layer, agent-native API,
Japanese market, Agent Insights"
↻ Reopens 2026-07-04
Everything else is aligned — no unaccounted divergence.
The memory underneath. Drift detection only works because the why survives the session boundary:
Without linksee-memory — Monday morning, new Claude session:
You: We deployed last week but it crashed. How did we fix it?
Claude: I don't have access to previous sessions. Can you describe
what happened and walk me through the problem?
[30 minutes of log-spelunking and re-explanation]
With linksee-memory — Same question, different outcome:
You: We deployed last week but it crashed. How did we fix it?
Claude: Let me check my caveats...
🧠 [caveat] NextAuth sessions invalidate when JWT_SECRET
rotates — redeploy all affected projects in parallel.
(from session 2026-04-13, importance: 0.9)
Is this the deploy you're asking about? We hit it when
we rotated secrets mid-flow.
You: Yes, exactly. Let's not repeat that.
That single caveat memory is what separates "flat fact storage" from "the agent actually remembers the WHY". linksee-memory stores it across six explicit layers so retrieval stays explainable.
Most teams make decisions, then forget them. The agent from last week decided "we'll use FTS5 instead of vector search" — but this week a new session installs pgvector without knowing why that was rejected. That's drift. Not a bug. Not malice. Just forgotten context.
Memory tools remember what you did. Nothing notices when you drift from what you decided — that's the layer Linksee Memory adds. Think "Datadog for product decisions": unaccounted divergences surface as drift, intentional evolution (recorded as supersede/fix) stays quiet.
declare_anchor({ kind: "decision", statement: "We use FTS5, not vector search", violation_signal: ["pgvector", "embedding"] })fix, supersede, acknowledge, or dismissThe make-or-break rule: a divergence accounted for by a recorded resolution (supersede/fix/acknowledge) is NOT drift. Only unaccounted gaps are flagged. This means intentional evolution stays quiet while silent abandonment gets caught.
Anchors are classified into four species with different display formats:
| Species | Icon | Display Format | Example |
|---|---|---|---|
| Hypothesis | 🧪 | Decision Card (journal format) | "We'll launch English-first on HN" |
| Constraint | 🔒 | Rule (pass/fail checklist) | "All writes go through remember()" |
| Commitment | 🔁 | Heartbeat (alive/dead) | "Ship a new version every week" |
| Source of Truth | 📍 | Reference (stable anchor) | "MCP server runs on stdio, single SQLite" |
Drift detection (above) is post-hoc — it tells you reality diverged after the change lands. The re-injection guard is the pre-action half: it re-surfaces the decision you locked before the agent runs the tool that would break it.
It exists for one specific, infuriating failure mode (anthropics/claude-code#15443): "Claude read the rule, understood it, and still used cp." Having the rule in context isn't enough — so the guard runs outside the agent's volition, as a Claude Code hook:
| Hook event | Fires on | What it does |
|---|---|---|
PreToolUse |
Edit / Write / Bash |
Checks the pending action against your accepted anchors. A gate_mode:'hard' contradiction is denied; a softer match re-injects the decision as a reminder; no match → nothing happens. |
SessionStart |
startup / resume / compact |
Replays your locked decisions + open forks into the fresh session — killing the "groundhog day" amnesia where a new agent repeats last week's call. |
It is fail-open by construction: any parse / DB / logic error surfaces nothing and lets the action through. The only thing that ever blocks is an explicit hard contradiction on a decision you declared.
npx linksee-memory-setup offers to wire this into your project's .claude/settings.json (Step 4). To do it by hand, drop this block into .claude/settings.json at your project root — it points at the globally-installed linksee-memory-guard bin, so no build step is needed:
{
"hooks": {
"SessionStart": [
{
"matcher": "startup|resume|compact",
"hooks": [
{ "type": "command", "command": "npx -y linksee-memory-guard", "timeout": 15 }
]
}
],
"PreToolUse": [
{
"matcher": "Edit|Write|Bash",
"hooks": [
{ "type": "command", "command": "npx -y linksee-memory-guard", "timeout": 8 }
]
}
]
}
}
It's project-scoped on purpose — the guard enforces this repo's decisions, and you opt in per project rather than letting it deny tool calls everywhere (the Stop hook from setup, by contrast, is user-global). Declare what it should watch with declare_anchor(...); set card_policy.gate_mode:'hard' on an anchor to make a contradiction block instead of just warn (the soft default only re-injects). Anchors that are stale (at_risk), superseded, or card-disabled never gate.
Developing linksee-memory itself? The repo dogfoods the guard via a (gitignored)
.claude/settings.jsonthat points at the local build (node ${CLAUDE_PROJECT_DIR}/dist/bin/guard-hook.js) so it runs against your uncommitted changes. End-user projects should use the publishednpx -y linksee-memory-guardform above.
Most "agent memory" services (Mem0, Letta, Zep) save a flat list of facts. Then the agent looks at "edited file X 30 times" and has no idea why. And none of them notice when this week's work contradicts last week's decision. linksee-memory keeps the WHY — and watches the drift.
It is a Model Context Protocol (MCP) server with 10 tools that gives any AI agent structured memory + drift detection:
| Mem0 / Letta / Zep | Claude Code auto-memory | linksee-memory | |
|---|---|---|---|
| Drift detection | ❌ | ❌ | ✅ intent ↔ reality divergence tracking |
| Cross-agent | △ (cloud) | ❌ Claude only | ✅ single SQLite file |
| 6-layer WHY structure | ❌ flat | ❌ flat markdown | ✅ goal / context / emotion / impl / caveat / learning |
| File diff cache | ❌ | ❌ | ✅ AST-aware, 50-99% token savings on re-reads |
| Active forgetting | △ | ❌ | ✅ Ebbinghaus curve, caveat layer protected |
| Local-first / private | ❌ | ✅ | ✅ |
~/.linksee-memory/memory.db. Same brain for Claude Code, Cursor, Windsurf, OpenAI Codex, Gemini CLI.goal / context / emotion / implementation / caveat / learning). Solves "flat fact memory is useless without goals".read_smart — sha256 + AST/heading/indent chunking. Re-reads return only diffs. Measured 86% saved on a typical TS file edit, 99% saved on unchanged re-reads.┌─────────────────────────────────────────────────────────────┐
│ 🎯 goal ← what the user is working toward │
├─────────────────────────────────────────────────────────────┤
│ 🧭 context ← why this, why now — constraints, people │
├─────────────────────────────────────────────────────────────┤
│ 💗 emotion ← user tone signals (frustration, etc.) │
├─────────────────────────────────────────────────────────────┤
│ 🛠 implementation ← how it was done (+ what failed) │
├─────────────────────────────────────────────────────────────┤
│ ⚠️ caveat ← "never do this again" · auto-protected │
├─────────────────────────────────────────────────────────────┤
│ 🌱 learning ← patterns distilled from cold memories │
└─────────────────────────────────────────────────────────────┘
│
▼
Ranked recall via relevance × heat × momentum × importance
Returns match_reasons explaining each hit
Every memory is tagged with exactly one layer. caveat-layer entries are protected from auto-forgetting. Cold low-importance memories are auto-consolidated into learning entries on server startup.
npx linksee-memory-setup
This does everything:
Restart Claude Code, then just chat normally. Add "Use Linksee" to any prompt to trigger memory recall.
Install & register:
claude mcp add -s user linksee -- npx -y linksee-memory
Tools appear as mcp__linksee__remember, mcp__linksee__recall, mcp__linksee__read_smart.
Install the skill (auto-invocation):
npx -y linksee-memory-install-skill
Copies SKILL.md to ~/.claude/skills/linksee-memory/. Agent auto-fires on phrases like "前に…", "また同じエラー", "覚えておいて", new task starts, file edits, etc.
Configure auto-capture (Stop hook):
Add to ~/.claude/settings.json:
{
"hooks": {
"Stop": [
{
"matcher": "",
"hooks": [
{ "type": "command", "command": "npx -y linksee-memory-sync" }
]
}
]
}
}
Each turn end takes ~100 ms. Failures are silent. Logs at ~/.linksee-memory/hook.log.
Linksee Memory is a standard MCP server (stdio). Any tool that speaks MCP can connect:
Add to ~/.cursor/mcp.json:
{
"mcpServers": {
"linksee": {
"command": "npx",
"args": ["-y", "linksee-memory"]
}
}
}
Restart Cursor. Memory tools appear in the agent panel.
Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"linksee": {
"command": "npx",
"args": ["-y", "linksee-memory"]
}
}
}
codex --mcp-server "npx -y linksee-memory"
Or add to ~/.codex/config.json:
{
"mcpServers": {
"linksee": {
"command": "npx",
"args": ["-y", "linksee-memory"]
}
}
}
Add to ~/.gemini/settings.json:
{
"mcpServers": {
"linksee": {
"command": "npx",
"args": ["-y", "linksee-memory"]
}
}
}
All editors share the same ~/.linksee-memory/memory.db. A decision made in Claude Code is recalled in Cursor. A caveat recorded in Windsurf prevents the same mistake in Codex.
Default: ~/.linksee-memory/memory.db. Override with LINKSEE_MEMORY_DIR env var.
| Feature | Detail |
|---|---|
| Re-injection guard | The pre-action half of drift detection. A Claude Code PreToolUse hook re-surfaces (or, on a hard contradiction, blocks) an accepted decision before the agent runs Edit/Write/Bash; a SessionStart boot digest replays your locked decisions into each fresh session. Fail-open by design. See Re-injection Guard. |
| Shippable hook wiring | linksee-memory-setup now offers to merge the guard hooks into your project's .claude/settings.json (pointing at the published linksee-memory-guard bin), and the block is documented for copy-paste. Previously the wiring lived only in a gitignored dogfood config. |
| Feature | Detail |
|---|---|
| 4 drift detection tools | drift_status, check_decision, declare_anchor, resolve_drift — agents can now query and act on intent ↔ reality divergence. The biggest gap in agent memory (decisions are forgotten across sessions) is now closed. |
| Truth engine | State derivation logic (drift/review/held/aligned) now lives in the MCP engine, not just the dashboard. Any MCP client can query drift status. |
| 4-species taxonomy | Anchors classified as hypothesis/constraint/commitment/source_of_truth with species-appropriate display formats. |
| Resolution priority | When multiple resolutions exist for an anchor, the most recent one wins (prevents stale acknowledge from shadowing a newer fix). |
| Feature | Detail |
|---|---|
| 3-tool unified surface | 8 tools → 3: remember (create + update + delete), recall (search + file history + overview), read_smart (token-saving reads). Fewer tools = better cross-LLM consistency. Follows Context7's proven pattern. |
| Auto-consolidate | Consolidation runs automatically on server startup (non-blocking, 7-day threshold). No manual consolidate() calls needed. |
| Deprecation guidance | Old tool names (forget, recall_file, etc.) return specific migration examples instead of silent failures. |
| "Use Linksee Memory" trigger | Add "Use Linksee Memory" to any prompt to force memory recall — same adoption pattern as Context7. |
| Claude Code Plugin | claude plugin add -- linksee-memory — ships MCP server + auto-invocation skill in one install. |
| Feature | Detail |
|---|---|
| One-command setup | npx linksee-memory-setup — registers MCP server, installs skill, configures auto-capture hook. One command instead of three. |
| Structured memory v2 | 3-axis classification (altitude × type × state) for every memory. Auto-extraction from sessions produces machine-scannable JSON, not raw chat dumps. |
| Precision recall guide | SKILL.md now teaches agents HOW to write effective queries, WHEN to recall vs skip, and WHEN to proactively surface caveats before risky actions. |
| Five MCP Blocks | Tools + Resources + Prompts + Sampling + Roots + Elicitation. Most MCP servers expose only Tools; linksee-memory implements all five primitives. |
| Tool | What it does |
|---|---|
remember |
Save / update / delete memories. Auto-classifies into 6 layers. Modes: create (default), update (memory_id + fields), delete (forget: true + memory_id). |
recall |
Search / file history / overview. Modes: search (query), file history (path), entity overview (no params). FTS5 + heat × momentum ranking with match_reasons. |
read_smart |
Token-saving file reader with AST diff caching. First read = full content. Re-read unchanged = ~50 tokens. Re-read modified = changed chunks only. |
| Tool | What it does |
|---|---|
drift_status |
"What's drifting right now?" Returns the truth map with 4-species classification (hypothesis/constraint/commitment/source_of_truth) and per-node state (🔴 drift / 🟡 review / ⚪ held / 🔵 aligned). |
check_decision |
Deep-dive into a specific decision. Returns the full context: what was decided, why, what reality says, pending candidates, and drift edges. |
declare_anchor |
Record a decision as a truth-map anchor. The drift detector checks these against committed reality. Supports v9 fields (domain, confidence, lifecycle, review_after). |
resolve_drift |
Close the loop. Record a resolution: fix (reality now matches), supersede (intent evolved), acknowledge (parking with review date), or dismiss (false positive). |
| Tool | What it does |
|---|---|
flag_proposals |
Record orphaned proposals — options you presented that the user never addressed. Conversations are tree-shaped but experienced linearly; the branches nobody engaged with become unresolved fork points that both you and the user lose track of. |
dream |
Consolidate orphaned proposals against the North Star. Returns the project's direction/goals/ICP alongside unresolved proposals; the evaluating agent decides per candidate: surface (genuinely important fork) or dismiss (outdated / irrelevant / implicitly resolved). |
resolve_proposal |
Record the verdict for each dreamed proposal: surface (keep visible on the dashboard for human decision) or dismiss (remove from the dashboard). |
Previous versions exposed 3 tools — v0.8.0 added 4 drift tools that let agents query and act on product-level intent ↔ reality divergence; v0.10 added the fork-point trio for orphaned-proposal triage. The memory tools are unchanged.
| Command | Purpose |
|---|---|
npx linksee-memory-setup |
One-command setup: MCP server + skill + Stop hook, then offers to wire the re-injection guard into this project. Idempotent — skips what's already done. |
npx linksee-memory |
MCP server (stdio) |
npx linksee-memory-sync |
Claude Code Stop-hook entry point |
npx linksee-memory-guard |
Re-injection guard hook: PreToolUse gate (Edit/Write/Bash) + SessionStart boot digest. Wired per-project (see Re-injection Guard); fail-open. |
npx linksee-memory-import |
Batch-import Claude Code session JSONL history |
npx linksee-memory-install-skill |
Install the Claude Code Skill that teaches the agent when to call recall/remember/read_smart |
npx linksee-memory-stats |
Summary of the local DB (entity count / layer breakdown / top entities / top edited files). Add --json for machine-readable output. |
Each entity (person / company / project / file / concept) can have memories across six layers. Since v0.4, each memory uses the 3-axis structured format (altitude × type × state):
{
"title": "freee OAuth token expires in 24h",
"altitude": "implementation",
"type": "outcome",
"state": "done",
"what": "freee OAuth token expires in 24 hours. Must refresh proactively.",
"why": "freee uses short-lived tokens unlike most SaaS (usually 30-90 day expiry)",
"affects": ["src/integrations/freee/auth.ts"],
"next_action": null
}
caveat memories are auto-protected from forgetting (pain lessons, never lost).goal memories bypass decay while the goal is active.state tracks lifecycle: open → decided → in_progress → done / stalled / superseded.A single SQLite file (better-sqlite3 + FTS5 trigram tokenizer for JP/EN) contains five layers:
entities (facts: people / companies / projects / concepts / files)edges (associations, graph adjacency)memories (6-layer structured meanings per entity)events (time-series log for heat / momentum computation)file_snapshots + session_file_edits (diff cache + conversation↔file linkage)The conversation↔file linkage is the key. Every file edit captured by the Stop hook is stored alongside the user message that drove the edit. So recall({ path: "server.ts" }) returns "this file was edited 30 times across 3 days, and here are the actual user instructions that motivated each change".
memory.db is one portable artifact. Backup = file copy.heat_score / momentum_score ported from a production sales-intelligence codebase. Rule-based, no LLM dependency in the hot path.claude plugin add -- linksee-memory)npx linksee-memory-setup)sqlite-vec (already in deps, embedding backend pending)Claude Code ships a built-in memory feature at ~/.claude/projects/<path>/memory/*.md — flat markdown notes for user preferences. linksee-memory complements it:
Use both.
linksee-memory ships with opt-in anonymous telemetry that helps us understand which MCP servers and workflows actually work in the wild. Nothing is sent unless you explicitly enable it. No conversation content, no file content, no entity names, no project paths — ever.
export LINKSEE_TELEMETRY=basic # opt in
export LINKSEE_TELEMETRY=off # opt out (or just unset the variable)
After each Claude Code session ends, the Stop hook sends one POST to https://kansei-link-mcp-production.up.railway.app/api/telemetry/linksee containing only these fields:
| Field | Example | What it is |
|---|---|---|
anon_id |
d7924ced-3879-… |
Random UUID generated locally on first opt-in. Stored at ~/.linksee-memory/telemetry-id — delete the file to reset. |
linksee_version |
0.0.3 |
Package version |
session_turn_count |
120 |
How many turns the session had |
session_duration_sec |
3600 |
How long the session lasted |
file_ops_edit/write/read |
12, 2, 40 |
Counts only |
mcp_servers |
["kansei-link","freee","slack"] |
Names of MCP servers configured (from ~/.claude.json). Names only — never command paths. |
file_extensions |
{".ts":60,".md":30} |
Percent distribution of file extensions touched |
read_smart_*, recall_* |
counts | Tool usage counters |
What is NEVER sent:
Aggregated MCP-usage data helps the KanseiLink project rank which agent integrations actually work for real developers. If you're happy to contribute, LINKSEE_TELEMETRY=basic takes 1 second to set and helps the entire MCP ecosystem improve.
The full payload schema and validation logic is open-source — read src/lib/telemetry.ts if you want to verify exactly what leaves your machine.
Free forever.
linksee-memory is local-first and runs entirely on your machine. There is no hosted component you need to pay for. The SQLite DB lives in your home directory; backup = file copy.
No account, no credit card, no API key. Just install and use.
recall when I ask about past work.ls ~/.claude/skills/linksee-memory/SKILL.md
If absent, run npx -y linksee-memory-install-skill.linksee (the skill expects mcp__linksee__* tool names):claude mcp list | grep linksee
If it's registered as something else, either re-register or edit ~/.claude/skills/linksee-memory/SKILL.md to match.cat ~/.linksee-memory/hook.logecho '{"session_id":"test","transcript_path":"/path/to/some.jsonl"}' | npx linksee-memory-sync
Stop hook in ~/.claude/settings.json points to npx -y linksee-memory-sync (not the old -import).v0.0.6+ fixed the entity detection bug that collapsed all memories into the session's starting cwd. To re-index existing history with correct project attribution, run:
npx linksee-memory-import --all
The importer is idempotent (wipes existing session data before re-inserting). Typical runtime: a few minutes for hundreds of sessions. Expect a dramatic improvement in recall precision afterward.
recall returns too much — the context window fills up fast.Reduce max_tokens:
recall({ query: "...", max_tokens: 800 }) // default is 2000
Or narrow with entity_name and layer:
recall({ query: "...", entity_name: "my-project", layer: "caveat" })
rm -rf ~/.linksee-memory # nuke everything; next run creates a fresh DB
Or delete individual memories via remember({ forget: true, memory_id: <id> }).
Consolidation runs automatically on server startup (7-day threshold). It clusters old cold memories into compressed learning-layer summaries. Caveat and active-goal layers are always preserved.
If you want to force a manual consolidation, restart the MCP server — auto-consolidate triggers on every startup.
Drift = when your code reality silently diverges from what you decided. Example: Last week you decided "FTS5, not vector search" but this week a new agent session installs pgvector without knowing the history.
Linksee Memory tracks this by letting you declare decisions as "anchors" and then automatically checking committed code against them. The make-or-break rule: intentional evolution (recorded as fix/supersede) stays quiet, while unaccounted gaps get flagged. It's like Datadog but for product decisions instead of server metrics.
You don't need to use drift detection to benefit from linksee-memory — the 3 memory tools (remember/recall/read_smart) work independently. Drift tools are an additional layer for teams and solo devs managing multiple projects.
Three axes:
goal/context/emotion/implementation/caveat/learning) so retrieval returns structured reasoning, not just data.read_smart tool saves 86–99% of tokens on file re-reads via AST-aware chunking. None of the memory services do this — it's a feature usually shipped in IDEs.Claude Code's auto-memory is Claude-only (doesn't help if you switch to Cursor, OpenAI Codex, or Gemini CLI) and stores flat markdown with no structure. linksee-memory is the same local-first principle but:
Yes — see tools/bench-read-smart.ts in the repo. The read_smart tool:
~50 tokens of "unchanged" confirmation instead of re-sending the file.For a typical TypeScript file edit in an agentic loop, this cuts round-trip token costs by ~86%. On pure re-reads (user navigating back to a previously-read file), savings exceed 99%.
The default is no sync — the SQLite file lives at ~/.linksee-memory/memory.db and stays there. If you want multi-machine sync, put that directory under Syncthing / iCloud Drive / Dropbox / Google Drive — it's a single file, so any file-sync tool works. (Avoid simultaneous edits from two machines while the MCP server is running on both; SQLite's WAL mode handles single-writer well but multi-writer conflicts can corrupt.)
Two mechanisms:
caveat layer and memories with importance ≥ 0.9 are always protected.learning-layer summary, then deletes the originals. No manual scheduling needed.In practice a solo developer hits ~100MB after 6 months of heavy use. A year-old DB I tested with 80K memories still recalls in <10ms.
Yes — any MCP-compatible client works:
claude mcp add -s user linksee -- npx -y linksee-memoryclaude_desktop_config.json (see onboarding on the LP)codex mcp add linksee -- npx -y linksee-memory (or ~/.codex/config.toml with [mcp_servers.linksee] block)~/.gemini/settings.json mcpServers sectionBy default: zero network calls, zero telemetry. There's an optional Level-1 telemetry mode you can enable that sends anonymized aggregate metrics (tool call counts, error rates, latency percentiles — never memory content, never file paths, never queries). The exact payload schema is documented in the Telemetry section and you see every byte before opting in.
After install, in a new Claude session ask: "Can you remember that I prefer TypeScript over JavaScript? Use Linksee Memory." Claude should confirm it called mcp__linksee__remember and stored this. Then in a different session ask: "What languages do I prefer? Use Linksee Memory." It should recall via mcp__linksee__recall and return the preference with match_reasons showing why.
enhancement label3 tools → 7 tools. The biggest update since launch — agents can now detect, query, and resolve intent ↔ reality drift.
New tools:
drift_status — returns the truth map with 4-species classification and per-node drift statecheck_decision — deep-dive into a single anchor: state, edges, pending candidatesdeclare_anchor — record a decision/constraint/prohibition as a truth-map node (with v9 ProjectCoreNode fields)resolve_drift — close the feedback loop: fix / supersede / acknowledge / dismissNew engine module:
truth-engine.ts — state derivation logic migrated from the dashboard into the MCP engine. Any MCP client can now query drift status without a dashboard.resolved_at timestamp). Prevents a stale acknowledge from shadowing a newer fix.decision_mode into hypothesis / constraint / commitment / source_of_truth with display format guidance.No breaking changes to existing memory tools. All 3 memory tools (remember, recall, read_smart) are unchanged.
Quality pass on v0.7.0 / v0.7.1 — sharper day-to-day agent UX and cleaner data for the dashboard:
recall token discipline: drops the redundant content_raw from the response (parsed content was already there — it was a 2× duplicate), and actually enforces max_tokens by greedy assembly that measures real serialized size (was a flat ~100 tok/memory estimate). Adds approx_tokens to the response so the agent can see its budget usage. The same query that previously returned ~15,800 tokens for a 1200 budget now stays inside it.recall precision: near-duplicate memories — same entity + near-identical core text, e.g. the same message captured under both goal and learning — collapse to one in the result set. Composite weights adapt to query specificity: multi-term queries weight relevance higher so off-topic-but-pinned memories don't crowd narrow recalls.session-extractor now produces AT MOST one memory per user turn, with priority goal[first_intent] > caveat > decision > context. A first-intent message containing decision words (e.g. "決めた" / "これで進めよう") is no longer double-saved as both goal and learning.memory_edges auto-detection: the previously-empty memory_edges table is now populated during the sleep-mode consolidation sweep. detectMemoryEdges() links a later DECISION memory to the most-recent earlier same-topic decision within an entity (chain, not clique) so the dashboard can render Pivot Chains. The default relation is extends — a same-topic later decision builds on, but does NOT deactivate, the earlier one. Explicit reversal markers (やめる / revert / instead of) produce contradicts; explicit replacement markers (の代わり / replaces / deprecate) produce supersedes. Prevents silent deactivation of still-valid decisions.inferType / inferState precision: chitchat acknowledgements ("そうだね" / "ありがとう"), pasted terminal/git/email content, and meta-noise no longer classify as decision — they return note / open before pattern matching. The learning-layer default → decision is gated by this guard. Real decisions (採用 / 決めた, even after an acknowledgement opener) survive.No schema migration, no breaking API changes. Existing rows keep their stored content; the classifier improvements apply to new captures going forward.
Based on Opus 4.7 design review of v0.7.0:
remember tool description now includes "REQUIRED PARAMS BY MODE" section so LLMs know exactly which fields are needed for create vs update vs delete.forget, recall_file, etc.) now return specific migration examples instead of generic errors.path and query are provided to recall, results from file history and memory search are merged into a single response.sqlite_master before querying consolidations table, preventing errors on fresh databases.8 tools → 3 tools. Following Context7's proven pattern of fewer tools = better cross-LLM consistency.
Breaking change: The following tools are removed from the MCP surface. Calling them returns a migration guide:
| Old tool | New equivalent |
|---|---|
forget |
remember({ forget: true, memory_id: <id> }) |
update_memory |
remember({ memory_id: <id>, content: "..." }) |
recall_file |
recall({ path: "server.ts" }) |
list_entities |
recall({}) (no params = entity overview) |
consolidate |
Auto-runs on server startup (7-day threshold) |
New unified tools:
remember — create + update + delete in one tool. Mode is inferred from params.recall — search + file history + overview in one tool. Mode is inferred from params.read_smart — unchanged.Other changes:
setTimeout, 7-day threshold, sqlite_master safety check)claude plugin add -- linksee-memory)All internal handler functions are preserved — this is a surface change, not a logic rewrite.
Prepares the package for a broader (primarily English-speaking) audience on Reddit, Hacker News, and Anthropic Discord. No breaking API changes.
SKILL.md (auto-invocation skill). The bundled skill that linksee-memory-install-skill copies into ~/.claude/skills/linksee-memory/SKILL.md was Japanese-first; it is now English-primary with Japanese trigger phrases preserved inline. English speakers now get the skill firing on natural English phrases ("how did we solve this before?", "same error again", "remember this") in addition to the existing JP triggers.linksee-memory-import): expanded regex patterns for decisions, failures, and caveats so English Claude Code session logs get auto-tagged correctly. Additions include let's go, pivot, switch to, settled on, approved, doesn't work, stuck, same error again, hit an error, debug, broke, revert.No code changes to the MCP protocol surface; all existing MCP clients continue to work unchanged.
Based on real-world feedback that importance=0.95 memories were not
being treated as pinned despite intent.
>= 1.0 to >= 0.9. Memories with
importance >= 0.9 are now exempt from the auto-forget sweep and
surface pinned: true in recall and remember responses. This
matches the natural mental model ("0.9 = high importance = should
survive cleanup") without requiring exact 1.0.importance >= 0.9 (including older ones
set to 0.9 or 0.95) become pinned automatically — no migration
needed.Based on one week of dogfooding, here's what changed:
New tools
update_memory — atomic edit with preserved memory_id. Solves the "forget+remember breaks session_file_edits links" bug.list_entities — fast "what do I know about?" primitive for session init. Supports kind/min_memories filters and returns layer breakdown.npx linksee-memory-stats — local DB summary CLI.recall enhancements
match_reasons array on each memory: e.g. ["content_match_fts", "heat:hot", "pinned"].score_breakdown with per-dimension scores (relevance / heat / momentum / importance).offset / has_more / stopped_by.limit parameter (hard cap, complements max_tokens budget).band filter to request only hot/warm/cold/frozen memories.mark_accessed=false for preview queries that shouldn't bump heat.decisions → learning, warnings → caveat, how → implementation, etc.remember enhancements
force=true.importance=1.0 now implicitly pins the memory (survives auto-forget).forget changes
sample_ids_to_drop.consolidate changes
dry_run: true preview mode — reports cluster count + candidates without writing.Infra
meta table before it existed).All changes are backward compatible — existing integrations continue to work. Server.ts version banner now reports v0.1.0.
See GitHub Releases.
MIT — Synapse Arrows PTE. LTD.
Run in your terminal:
claude mcp add linksee-memory -- npx CSA PROJECT - FZCO © 2026 IFZA Business Park, DDP, Premises Number 31174 - 001
Security
Low riskAutomated heuristic from public metadata — not a security guarantee.