Skip to content

lucasrosati/claude-code-memory-setup

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

4 Commits
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Claude Code + Obsidian + Graphify: The Definitive Guide to Token Savings & Persistent Memory

71.5x fewer tokens per session with Graphify + permanent memory across sessions with Obsidian Zettelkasten.

A complete setup to turn Claude Code into an agent with long-term memory and full codebase awareness β€” without wasting tokens re-reading files.

πŸ‡§πŸ‡· Leia em PortuguΓͺs


Table of Contents

  1. The Problem
  2. The Solution (Overview)
  3. Part 1 β€” Obsidian as Persistent Memory
  4. Part 2 β€” Chat Import Pipeline
  5. Part 3 β€” Graphify (Codebase Knowledge Graph)
  6. Part 4 β€” Complete Workflow
  7. Real Results
  8. Troubleshooting

The Problem

When working with Claude Code, two problems silently eat your tokens:

Problem 1 β€” Amnesia between sessions. Every time you open a new session, you have to re-explain your project: stack, past decisions, current bugs, what's left to do. Claude Code remembers nothing from the previous session.

Problem 2 β€” Codebase re-reading. Claude Code re-reads all your project files every session to understand the structure. A project with ~40 files burns ~20,000 tokens just for Claude to orient itself β€” before you even ask a question. If you run 10 sessions a day, that's 200,000 wasted tokens.


The Solution (Overview)

Two complementary systems, each solving a different problem:

Layer Tool Problem Solved Cost
Project memory Obsidian Zettelkasten Amnesia between sessions Free
Code map Graphify Codebase re-reading Free (AST mode)
Conversation history Import pipeline Lost chat insights Free
Continuity /resume and /save commands Picking up where you left off Free

Obsidian handles what was decided (declarative memory). Graphify handles how the code is structured (structural map). Together, Claude Code starts every session knowing everything β€” without re-reading anything.


Part 1 β€” Obsidian as Persistent Memory

Concept

A single, centralized Obsidian vault acts as Claude Code's "second brain." It stores decisions, context, progress, and knowledge for all your projects. Notes follow the Zettelkasten method: atomic (one idea per note), densely interlinked, with standardized metadata.

Claude Code accesses the vault through CLAUDE.md and custom skills.

Recommended Structure

~/vault/                              # SINGLE vault for all projects
β”œβ”€β”€ CLAUDE.md                         # global instructions for Claude Code
β”œβ”€β”€ permanent/                        # consolidated atomic notes
β”œβ”€β”€ inbox/                            # raw capture (ideas, drafts)
β”œβ”€β”€ fleeting/                         # quick temporary notes
β”œβ”€β”€ templates/                        # note templates
β”œβ”€β”€ logs/                             # global session logs
β”œβ”€β”€ references/                       # reference material
β”œβ”€β”€ my-project/                       # MOCs and notes for project X
β”‚   β”œβ”€β”€ architecture/                 #   architecture, decisions, conventions
β”‚   β”œβ”€β”€ pipeline/                     #   data flows, APIs
β”‚   β”œβ”€β”€ data/                         #   schema, data model
β”‚   β”œβ”€β”€ features/                     #   planned/implemented features
β”‚   └── logs/                         #   project session logs
β”œβ”€β”€ another-project/                  # MOCs and notes for project Y
β”‚   └── ...
β”œβ”€β”€ chats/                            # imported Claude chats
β”‚   β”œβ”€β”€ code/                         #   from Claude Code
β”‚   └── web/                          #   from Claude Web/App
└── graphify/                         # codebase knowledge graphs
    β”œβ”€β”€ my-project/                   #   graph notes for project X
    └── another-project/              #   graph notes for project Y

Why a single vault? Having one vault per project fragments knowledge. With a single vault, a note about "Supabase Auth" links to both project A and B. The graph view reveals cross-project connections you didn't expect.

Step-by-Step Setup

Prerequisites:

  • Claude Code installed and authenticated
  • Obsidian installed (free: obsidian.md)

1. Create the vault:

Obsidian β†’ "Create new vault" β†’ choose a name and location.

2. Create the folder structure:

cd ~/vault  # adjust to your path
mkdir -p permanent inbox fleeting templates logs references
mkdir -p my-project/{architecture,pipeline,data,features,logs}

3. Create the CLAUDE.md:

This is the file Claude Code reads automatically. Create CLAUDE.md at the vault root:

# Vault β€” Instructions for Claude Code

## What is this vault
Centralized knowledge base for all projects.
Persistent memory across sessions.

## Project stacks
- Project X: React + Supabase
- Project Y: Python + FastAPI
(adapt to your projects)

## Zettelkasten Rules

### Note creation
- Use wikilinks: [[note-name]] (not markdown links)
- Mandatory YAML frontmatter on every note
- Filenames in kebab-case: `auth-flow.md`, not `Auth Flow.md`
- 1 concept per permanent note (atomicity)
- Minimum 2 wikilinks per note (dense linking)

### Standard frontmatter
---
title: Note Name
tags: [project, topic]
created: YYYY-MM-DD
updated: YYYY-MM-DD
status: active
type: permanent
---

### Never do
- Don't delete notes without asking
- Don't use markdown links for internal notes (use wikilinks)
- Don't create notes without frontmatter
- Don't change folder structure without documenting it

## Session Commands

### /resume
When you receive this command:
1. Read the 3 most recent session logs in logs/
2. Read architecture/decisions.md for the current project
3. Summarize current state and what's left to do

### /save
When you receive this command:
1. Create a session log in logs/YYYY-MM-DD-description.md
2. Record: what was done, decisions made, pending items
3. Add wikilinks to created/modified notes
4. Run git commit + push if in a repository

4. Create a note template:

cat > templates/default-note.md << 'EOF'
---
title: {{title}}
tags: []
created: {{date}}
updated: {{date}}
status: draft
type: permanent
---

# {{title}}

## Context

## Details

## Related links
EOF

5. Recommended Obsidian plugins:

Plugin Purpose Install method
BRAT Install beta plugins Community Plugins β†’ Browse
3D Graph 3D vault visualization Via BRAT (v2.4.1)
Folders to Graph Folders as graph nodes Community Plugins β†’ Browse
Calendar Daily note navigation Community Plugins β†’ Browse

Part 2 β€” Chat Import Pipeline

Concept

Your Claude chats (both Code and Web) contain valuable decisions, insights, and context that get lost in the history. This pipeline exports, processes, and imports those conversations as vault notes β€” with frontmatter, automatic tags, and wikilinks to existing notes.

Components

~/scripts/
β”œβ”€β”€ claude_to_obsidian.py          # processor (frontmatter, tags, wikilinks)
└── sync_claude_obsidian.sh        # automation (export + process)

~/claude-exports/                   # temporary staging area (outside vault)
β”œβ”€β”€ code/                           # Claude Code exports
└── web/                            # Claude Web exports

Setup

1. Install the Claude Code extractor:

pip install claude-conversation-extractor

2. Create staging directories:

mkdir -p ~/claude-exports/code ~/claude-exports/web

3. Create the post-processing script (~/scripts/claude_to_obsidian.py):

The script should:

  • Read each exported .md file
  • Detect origin (Code vs Web)
  • Generate automatic tags based on content keywords
  • Add standardized YAML frontmatter
  • Insert [[wikilinks]] for notes that already exist in the vault
  • Copy to chats/code/ or chats/web/ inside the vault

Example keyword-to-tag mapping:

KEYWORD_TAG_MAP = {
    "python": "python",
    "react": "react",
    "supabase": "supabase",
    "deploy": "deploy",
    "bug": "debugging",
    "refactor": "refactoring",
    # add your own
}

4. Create the automation script (~/scripts/sync_claude_obsidian.sh):

#!/bin/bash
EXPORT_DIR="$HOME/claude-exports"
VAULT_DIR="$HOME/vault"  # adjust to your path
SCRIPT_DIR="$HOME/scripts"
LOG="$SCRIPT_DIR/sync.log"

echo "[$(date)] Sync started" >> "$LOG"

# Export Claude Code chats
claude-extract --all --output "$EXPORT_DIR/code" 2>> "$LOG"

# Process and send to vault
python3 "$SCRIPT_DIR/claude_to_obsidian.py" \
    --export-dir "$EXPORT_DIR" \
    --vault-dir "$VAULT_DIR" \
    --move 2>> "$LOG"

echo "[$(date)] Sync completed" >> "$LOG"

5. Schedule automatic execution:

chmod +x ~/scripts/sync_claude_obsidian.sh

# Run daily at 10 PM
(crontab -l 2>/dev/null; echo "0 22 * * * $HOME/scripts/sync_claude_obsidian.sh") | crontab -

6. For Claude Web chats:

Install the "Export Claude Chat to Markdown" browser extension for Chrome/Edge. Do periodic bulk exports, save the .md files to ~/claude-exports/web/, and the cron job handles the rest.

7. Add a section to the vault's CLAUDE.md:

## Chat Import Pipeline

### Structure
- `chats/code/` β†’ imported Claude Code conversations
- `chats/web/` β†’ imported Claude Web/App conversations
- All chats get frontmatter with `type: chat` and `chat-import` tag

### Filter in Graph View
- `tag:chat-import` β†’ chats only
- `-path:chats` β†’ hide chats

Part 3 β€” Graphify (Codebase Knowledge Graph)

Concept

Graphify transforms your codebase into a queryable knowledge graph. Instead of Claude Code re-reading every file, it queries the graph β€” which is persistent across sessions and costs a fraction of the tokens.

  • Code: processed 100% locally via tree-sitter AST. No code content leaves your machine.
  • Cache: SHA256 β€” re-runs only process modified files.
  • Cost: 0 tokens in default mode (pure AST). --deep mode uses LLM for semantic edges.
  • Languages: Python, JavaScript, TypeScript, Go, Rust, Java, C, C++, Ruby, C#, Kotlin, Scala, PHP, Swift, Lua, Zig, and more (20 languages via tree-sitter).

Setup

1. Install:

pip install graphifyy
graphify install

graphify install creates the skill at ~/.claude/skills/graphify/SKILL.md.

2. Generate the graph:

From your project root:

# Full pipeline + Obsidian notes in the centralized vault
graphify . --obsidian --obsidian-dir ~/vault/graphify/project-name

Generated output:

your-project/
└── graphify-out/
    β”œβ”€β”€ graph.json          # queryable graph (Claude Code uses this)
    β”œβ”€β”€ graph.html          # interactive visualization (open in browser)
    β”œβ”€β”€ GRAPH_REPORT.md     # god nodes, connections, metrics
    β”œβ”€β”€ wiki/               # Wikipedia-style articles (agent navigation)
    └── cache/              # SHA256 cache

~/vault/graphify/project-name/
    └── (Obsidian notes)    # each function/module as a node in graph view

3. Update .gitignore:

# Graphify
graphify-out/cache/

Keep graph.json and GRAPH_REPORT.md versioned β€” they're useful for the team.

4. Add to the project's CLAUDE.md:

Append to the CLAUDE.md at the repository root:

## Context Navigation (Graphify)

### 3-Layer Query Rule
1. **First:** query `graphify-out/graph.json` or `graphify-out/wiki/index.md`
   to understand code structure and connections
2. **Second:** query the Obsidian vault for decisions, progress, and project context
3. **Third:** only read raw code files when editing
   or when the first two layers don't have the answer

### When to rebuild the graph
- After structural changes (new modules, major refactors)
- Command: `graphify . --update` (only processes modified files)
- The graph is persistent β€” NO need to rebuild every session

### Do NOT
- Don't manually modify files inside `graphify-out/`
- Don't re-read the entire codebase if the graph already has the information

5. Add to the vault's CLAUDE.md:

## Graphify (Codebase Maps)

### Structure
- `graphify/project-x/` β†’ knowledge graph for project X
- Future projects get their own subfolders
- Notes are auto-generated β€” do NOT edit manually

### In Graph View
- Filter by `path:graphify` to see only code nodes
- Filter by `-path:graphify` to hide code nodes

6. Git Hook (optional):

Automatically rebuilds the graph on every commit:

graphify hook install

7. Watch Mode (optional):

Auto-rebuild on file save (run in a separate terminal):

graphify . --watch

Useful Commands

Command Description
graphify . Full pipeline on current directory
graphify ./src Scan specific folder
graphify . --update Only process modified files
graphify . --mode deep Semantic extraction (uses LLM, costs tokens)
graphify . --watch Auto-rebuild on save
graphify query "question" Query the graph directly
open graphify-out/graph.html Open interactive visualization

Adding New Projects

With a centralized vault, each project is just a subfolder:

cd ~/another-project
graphify . --obsidian --obsidian-dir ~/vault/graphify/another-project

Notes automatically appear in Obsidian's graph view alongside everything else.


Part 4 β€” Complete Workflow

Typical session

Open Claude Code session
    β”‚
    β”œβ”€β”€ /resume                      ← loads vault context
    β”‚                                   (recent logs, decisions, progress)
    β”‚
    β”œβ”€β”€ Claude queries graph.json     ← understands code structure
    β”‚                                   without re-reading all files
    β”‚
    β”œβ”€β”€ Work on code                  ← features, bugs, refactors
    β”‚
    β”œβ”€β”€ /save                        ← generates session log in vault
    β”‚
    └── git commit                   ← hook rebuilds graph automatically

Savings per layer

Layer Without it With it
/resume Re-explain project every session Claude already knows the context
Graphify Re-read ~40 files (~20k tokens) Query 1 graph (~280 tokens)
Chat pipeline Insights lost in chat history Everything indexed and searchable
/save + logs Forget what was done Complete history with wikilinks

Graph View Filters

Filter What it shows
path:permanent Only permanent notes (consolidated knowledge)
path:graphify Only codebase nodes (functions, modules, imports)
tag:chat-import Only imported chats
-path:graphify -path:chats Only manual notes (pure vault)

Real Results

Tested on a React + Supabase project with 126 TypeScript files:

Metric Value
Graph nodes 332
Edges (connections) 258
Communities detected 124
graph.json size 172 KB
Obsidian notes generated 456
Token reduction per query 499x
LLM cost for generation 0 tokens (AST mode)
Imported chats in vault 137
Accumulated permanent notes 65+
Total vault notes 780+

Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                    OBSIDIAN VAULT (single)                   β”‚
β”‚                                                             β”‚
β”‚  permanent/  ← consolidated knowledge (Zettelkasten)        β”‚
β”‚  logs/       ← session logs (/save)                         β”‚
β”‚  chats/      ← imported conversations (cron pipeline)       β”‚
β”‚  graphify/   ← codebase knowledge graphs                    β”‚
β”‚  project-x/  ← MOCs, decisions, architecture                β”‚
β”‚                                                             β”‚
β”‚  CLAUDE.md   ← global instructions for Claude Code          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                          β”‚
                    Claude Code reads/writes
                          β”‚
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                   PROJECT REPOSITORY                         β”‚
β”‚                                                             β”‚
β”‚  src/            ← source code                              β”‚
β”‚  CLAUDE.md       ← project instructions + Context Nav       β”‚
β”‚  graphify-out/   ← graph.json, graph.html, report           β”‚
β”‚  .git/hooks/     ← post-commit rebuilds the graph           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Troubleshooting

Graphify notes don't appear in Obsidian: Confirm the notes are inside the actual vault directory. Obsidian doesn't always point where you think β€” create a note in Obsidian and run find ~ -name "note-name.md" to discover the real path. Then move the notes there and Cmd+Q / reopen.

Graph view empty with filter applied: Disable "Orphans" and "Existing files only" in the graph filters. Cmd+Q and reopen Obsidian to force reindexing.

Claude Code doesn't query the graph: Check that the project's CLAUDE.md has the "Context Navigation" section and that graphify-out/graph.json exists at the repo root.

Cron doesn't run (macOS): Grant Full Disk Access to your terminal in System Preferences β†’ Privacy & Security.

Graphify doesn't generate wiki: The wiki requires semantic edges. In AST-only mode, use graphify query "question" or run --mode deep (costs API tokens).

Files with parentheses in name: Graphify generates notes like myFunction().md. Obsidian may struggle indexing files with () in the name. If needed, batch rename:

cd ~/vault/graphify/project
for f in *"("*; do mv "$f" "$(echo "$f" | sed 's/[()]//g')"; done

Credits & Links

  • Graphify β€” codebase knowledge graphs (MIT)
  • Obsidian β€” PKM and second brain (free)
  • Claude Code β€” Anthropic's coding agent
  • Inspired by Andrej Karpathy's system and the r/ClaudeAI community

If this guide helped you, give the repo a ⭐ and share it with other devs using Claude Code.

About

Up to 71.5x fewer tokens per session on Claude Code with Obsidian + Graphify. Persistent memory, codebase knowledge graphs, and chat import pipeline. πŸ‡§πŸ‡· PT-BR included.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors