@pcircle/memesh 2.9.2 → 2.9.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.de.md +119 -78
- package/README.es.md +116 -75
- package/README.fr.md +116 -75
- package/README.id.md +115 -74
- package/README.ja.md +111 -70
- package/README.ko.md +116 -75
- package/README.md +113 -72
- package/README.th.md +118 -77
- package/README.vi.md +116 -75
- package/README.zh-CN.md +120 -79
- package/README.zh-TW.md +116 -75
- package/dist/core/GitCommandParser.d.ts +11 -0
- package/dist/core/GitCommandParser.d.ts.map +1 -0
- package/dist/core/GitCommandParser.js +43 -0
- package/dist/core/GitCommandParser.js.map +1 -0
- package/dist/core/HookIntegration.d.ts +0 -3
- package/dist/core/HookIntegration.d.ts.map +1 -1
- package/dist/core/HookIntegration.js +6 -30
- package/dist/core/HookIntegration.js.map +1 -1
- package/dist/embeddings/EmbeddingService.d.ts +3 -0
- package/dist/embeddings/EmbeddingService.d.ts.map +1 -1
- package/dist/embeddings/EmbeddingService.js +32 -6
- package/dist/embeddings/EmbeddingService.js.map +1 -1
- package/dist/embeddings/InMemoryVectorAdapter.d.ts +15 -0
- package/dist/embeddings/InMemoryVectorAdapter.d.ts.map +1 -0
- package/dist/embeddings/InMemoryVectorAdapter.js +58 -0
- package/dist/embeddings/InMemoryVectorAdapter.js.map +1 -0
- package/dist/embeddings/SqliteVecAdapter.d.ts +15 -0
- package/dist/embeddings/SqliteVecAdapter.d.ts.map +1 -0
- package/dist/embeddings/SqliteVecAdapter.js +107 -0
- package/dist/embeddings/SqliteVecAdapter.js.map +1 -0
- package/dist/embeddings/VectorExtension.d.ts +2 -4
- package/dist/embeddings/VectorExtension.d.ts.map +1 -1
- package/dist/embeddings/VectorExtension.js.map +1 -1
- package/dist/embeddings/VectorSearchAdapter.d.ts +17 -0
- package/dist/embeddings/VectorSearchAdapter.d.ts.map +1 -0
- package/dist/embeddings/VectorSearchAdapter.js +2 -0
- package/dist/embeddings/VectorSearchAdapter.js.map +1 -0
- package/dist/embeddings/index.d.ts +6 -1
- package/dist/embeddings/index.d.ts.map +1 -1
- package/dist/embeddings/index.js +4 -1
- package/dist/embeddings/index.js.map +1 -1
- package/dist/knowledge-graph/ContentHasher.d.ts +4 -0
- package/dist/knowledge-graph/ContentHasher.d.ts.map +1 -0
- package/dist/knowledge-graph/ContentHasher.js +8 -0
- package/dist/knowledge-graph/ContentHasher.js.map +1 -0
- package/dist/knowledge-graph/KGSearchEngine.d.ts +36 -0
- package/dist/knowledge-graph/KGSearchEngine.d.ts.map +1 -0
- package/dist/knowledge-graph/KGSearchEngine.js +257 -0
- package/dist/knowledge-graph/KGSearchEngine.js.map +1 -0
- package/dist/knowledge-graph/index.d.ts +18 -7
- package/dist/knowledge-graph/index.d.ts.map +1 -1
- package/dist/knowledge-graph/index.js +147 -242
- package/dist/knowledge-graph/index.js.map +1 -1
- package/dist/mcp/ServerInitializer.d.ts.map +1 -1
- package/dist/mcp/ServerInitializer.js +1 -1
- package/dist/mcp/ServerInitializer.js.map +1 -1
- package/dist/mcp/StdinBufferManager.d.ts +11 -0
- package/dist/mcp/StdinBufferManager.d.ts.map +1 -0
- package/dist/mcp/StdinBufferManager.js +62 -0
- package/dist/mcp/StdinBufferManager.js.map +1 -0
- package/dist/mcp/daemon/StdioProxyClient.d.ts.map +1 -1
- package/dist/mcp/daemon/StdioProxyClient.js +6 -0
- package/dist/mcp/daemon/StdioProxyClient.js.map +1 -1
- package/dist/mcp/handlers/HookToolHandler.d.ts +10 -0
- package/dist/mcp/handlers/HookToolHandler.d.ts.map +1 -0
- package/dist/mcp/handlers/HookToolHandler.js +92 -0
- package/dist/mcp/handlers/HookToolHandler.js.map +1 -0
- package/dist/mcp/handlers/MemoryToolHandler.d.ts +21 -0
- package/dist/mcp/handlers/MemoryToolHandler.d.ts.map +1 -0
- package/dist/mcp/handlers/MemoryToolHandler.js +430 -0
- package/dist/mcp/handlers/MemoryToolHandler.js.map +1 -0
- package/dist/mcp/handlers/SystemToolHandler.d.ts +14 -0
- package/dist/mcp/handlers/SystemToolHandler.d.ts.map +1 -0
- package/dist/mcp/handlers/SystemToolHandler.js +224 -0
- package/dist/mcp/handlers/SystemToolHandler.js.map +1 -0
- package/dist/mcp/handlers/ToolHandlers.d.ts +4 -17
- package/dist/mcp/handlers/ToolHandlers.d.ts.map +1 -1
- package/dist/mcp/handlers/ToolHandlers.js +19 -689
- package/dist/mcp/handlers/ToolHandlers.js.map +1 -1
- package/dist/mcp/handlers/index.d.ts +3 -0
- package/dist/mcp/handlers/index.d.ts.map +1 -1
- package/dist/mcp/handlers/index.js +3 -0
- package/dist/mcp/handlers/index.js.map +1 -1
- package/dist/mcp/server-bootstrap.js +24 -59
- package/dist/mcp/server-bootstrap.js.map +1 -1
- package/dist/mcp/tools/create-entities.d.ts.map +1 -1
- package/dist/mcp/tools/create-entities.js +18 -24
- package/dist/mcp/tools/create-entities.js.map +1 -1
- package/dist/memory/MemorySearchEngine.d.ts +17 -0
- package/dist/memory/MemorySearchEngine.d.ts.map +1 -0
- package/dist/memory/MemorySearchEngine.js +88 -0
- package/dist/memory/MemorySearchEngine.js.map +1 -0
- package/dist/memory/ProactiveRecaller.d.ts +26 -0
- package/dist/memory/ProactiveRecaller.d.ts.map +1 -0
- package/dist/memory/ProactiveRecaller.js +96 -0
- package/dist/memory/ProactiveRecaller.js.map +1 -0
- package/dist/memory/UnifiedMemoryStore.d.ts +1 -0
- package/dist/memory/UnifiedMemoryStore.d.ts.map +1 -1
- package/dist/memory/UnifiedMemoryStore.js +7 -63
- package/dist/memory/UnifiedMemoryStore.js.map +1 -1
- package/dist/memory/index.d.ts +3 -0
- package/dist/memory/index.d.ts.map +1 -1
- package/dist/memory/index.js +2 -0
- package/dist/memory/index.js.map +1 -1
- package/dist/utils/index.d.ts +0 -2
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +0 -2
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/tracing/index.d.ts +0 -1
- package/dist/utils/tracing/index.d.ts.map +1 -1
- package/dist/utils/tracing/index.js +0 -1
- package/dist/utils/tracing/index.js.map +1 -1
- package/package.json +2 -11
- package/plugin.json +1 -1
- package/scripts/hooks/__tests__/post-tool-use-recall.test.js +192 -0
- package/scripts/hooks/__tests__/session-start-recall.test.js +86 -0
- package/scripts/hooks/post-tool-use-recall-utils.js +74 -0
- package/scripts/hooks/post-tool-use.js +79 -0
- package/scripts/hooks/session-start-recall-utils.js +40 -0
- package/scripts/hooks/session-start.js +66 -0
- package/scripts/hooks/templates/planning-template.md +46 -0
package/README.md
CHANGED
|
@@ -1,77 +1,106 @@
|
|
|
1
1
|
<div align="center">
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
<img src="https://img.shields.io/badge/%F0%9F%A7%A0-MeMesh-blueviolet?style=for-the-badge" alt="MeMesh" />
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
# MeMesh
|
|
6
6
|
|
|
7
|
-
|
|
7
|
+
### Your AI coding sessions deserve memory.
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
[](LICENSE)
|
|
11
|
-
[](https://modelcontextprotocol.io)
|
|
9
|
+
MeMesh gives Claude Code persistent, searchable memory — so every session builds on the last.
|
|
12
10
|
|
|
13
|
-
[
|
|
11
|
+
[](https://www.npmjs.com/package/@pcircle/memesh)
|
|
12
|
+
[](https://www.npmjs.com/package/@pcircle/memesh)
|
|
13
|
+
[](LICENSE)
|
|
14
|
+
[](https://nodejs.org)
|
|
15
|
+
[](https://modelcontextprotocol.io)
|
|
14
16
|
|
|
15
|
-
|
|
17
|
+
```bash
|
|
18
|
+
npm install -g @pcircle/memesh
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
[Get Started](#get-started) · [How It Works](#how-it-works) · [Commands](#commands) · [Docs](docs/USER_GUIDE.md)
|
|
22
|
+
|
|
23
|
+
[繁體中文](README.zh-TW.md) · [简体中文](README.zh-CN.md) · [日本語](README.ja.md) · [한국어](README.ko.md) · [Français](README.fr.md) · [Deutsch](README.de.md) · [Español](README.es.md) · [Tiếng Việt](README.vi.md) · [ภาษาไทย](README.th.md) · [Bahasa Indonesia](README.id.md)
|
|
16
24
|
|
|
17
25
|
</div>
|
|
18
26
|
|
|
27
|
+
> **Note**: This project was originally called "Claude Code Buddy" and has been renamed to MeMesh Plugin to avoid potential trademark issues.
|
|
28
|
+
|
|
19
29
|
---
|
|
20
30
|
|
|
21
|
-
##
|
|
31
|
+
## The Problem
|
|
22
32
|
|
|
23
|
-
|
|
33
|
+
You're deep into a project with Claude Code. You made important decisions three sessions ago — which auth library, why you chose that database schema, what patterns to follow. But Claude doesn't remember. You repeat yourself. You lose context. You waste time.
|
|
24
34
|
|
|
25
|
-
|
|
35
|
+
**MeMesh fixes this.** It gives Claude a persistent, searchable memory that grows with your project.
|
|
26
36
|
|
|
27
|
-
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## How It Works
|
|
40
|
+
|
|
41
|
+
<table>
|
|
42
|
+
<tr>
|
|
43
|
+
<td width="50%">
|
|
44
|
+
|
|
45
|
+
### Before MeMesh
|
|
46
|
+
```
|
|
47
|
+
Session 1: "Use JWT for auth"
|
|
48
|
+
Session 2: "Why did we pick JWT again?"
|
|
49
|
+
Session 3: "Wait, what auth library are we using?"
|
|
50
|
+
```
|
|
51
|
+
You repeat decisions. Claude forgets context. Progress stalls.
|
|
52
|
+
|
|
53
|
+
</td>
|
|
54
|
+
<td width="50%">
|
|
28
55
|
|
|
29
|
-
|
|
56
|
+
### After MeMesh
|
|
57
|
+
```
|
|
58
|
+
Session 1: "Use JWT for auth" → saved
|
|
59
|
+
Session 2: buddy-remember "auth" → instant recall
|
|
60
|
+
Session 3: Context auto-loaded on start
|
|
61
|
+
```
|
|
62
|
+
Every session picks up where you left off.
|
|
30
63
|
|
|
31
|
-
|
|
64
|
+
</td>
|
|
65
|
+
</tr>
|
|
66
|
+
</table>
|
|
32
67
|
|
|
33
|
-
|
|
68
|
+
---
|
|
34
69
|
|
|
35
|
-
|
|
70
|
+
## What You Get
|
|
36
71
|
|
|
37
|
-
**
|
|
38
|
-
- Show you a recap of your last session when you start
|
|
39
|
-
- Track which files you've changed and tested
|
|
40
|
-
- Remind you about code reviews before committing
|
|
41
|
-
- Route tasks to the right model (fast model for search, powerful model for planning)
|
|
72
|
+
**Searchable Project Memory** — Ask "what did we decide about auth?" and get an instant, semantically-matched answer. Not keyword search — *meaning* search, powered by local ONNX embeddings.
|
|
42
73
|
|
|
43
|
-
**
|
|
74
|
+
**Smart Task Analysis** — `buddy-do "add user auth"` doesn't just execute. It pulls relevant context from past sessions, checks what patterns you've established, and builds an enriched plan before writing a single line.
|
|
44
75
|
|
|
45
|
-
**
|
|
76
|
+
**Proactive Recall** — MeMesh automatically surfaces relevant memories when you start a session, hit a test failure, or encounter an error. No manual searching needed.
|
|
46
77
|
|
|
47
|
-
|
|
78
|
+
**Workflow Automation** — Session recaps on startup. File change tracking. Code review reminders before commits. All running silently in the background.
|
|
48
79
|
|
|
49
|
-
|
|
50
|
-
- **CLAUDE.md** = your instruction manual for Claude
|
|
51
|
-
- **MeMesh** = a searchable notebook + smart assistant that learns as your project grows
|
|
80
|
+
**Mistake Learning** — Record errors and fixes to build a knowledge base. The same mistake doesn't happen twice.
|
|
52
81
|
|
|
53
82
|
---
|
|
54
83
|
|
|
55
|
-
##
|
|
84
|
+
## Get Started
|
|
56
85
|
|
|
57
|
-
**
|
|
86
|
+
**Prerequisites**: [Claude Code](https://docs.anthropic.com/en/docs/claude-code) + Node.js 20+
|
|
58
87
|
|
|
59
88
|
```bash
|
|
60
89
|
npm install -g @pcircle/memesh
|
|
61
90
|
```
|
|
62
91
|
|
|
63
|
-
Restart Claude Code.
|
|
92
|
+
Restart Claude Code. That's it.
|
|
64
93
|
|
|
65
|
-
**
|
|
94
|
+
**Verify** — type in Claude Code:
|
|
66
95
|
|
|
67
96
|
```
|
|
68
97
|
buddy-help
|
|
69
98
|
```
|
|
70
99
|
|
|
71
|
-
You should see a list of commands.
|
|
100
|
+
You should see a list of available commands.
|
|
72
101
|
|
|
73
102
|
<details>
|
|
74
|
-
<summary>Install from source (
|
|
103
|
+
<summary><strong>Install from source</strong> (contributors)</summary>
|
|
75
104
|
|
|
76
105
|
```bash
|
|
77
106
|
git clone https://github.com/PCIRCLE-AI/claude-code-buddy.git
|
|
@@ -83,76 +112,88 @@ npm install && npm run build
|
|
|
83
112
|
|
|
84
113
|
---
|
|
85
114
|
|
|
86
|
-
##
|
|
87
|
-
|
|
88
|
-
MeMesh adds 3 commands to Claude Code:
|
|
115
|
+
## Commands
|
|
89
116
|
|
|
90
117
|
| Command | What it does |
|
|
91
118
|
|---------|-------------|
|
|
92
|
-
| `buddy-do "task"` |
|
|
93
|
-
| `buddy-remember "topic"` | Search
|
|
119
|
+
| `buddy-do "task"` | Execute a task with full memory context |
|
|
120
|
+
| `buddy-remember "topic"` | Search past decisions and context |
|
|
94
121
|
| `buddy-help` | Show available commands |
|
|
95
122
|
|
|
96
|
-
**
|
|
123
|
+
**Real examples:**
|
|
97
124
|
|
|
98
125
|
```bash
|
|
126
|
+
# Get oriented in a new-to-you codebase
|
|
99
127
|
buddy-do "explain this codebase"
|
|
128
|
+
|
|
129
|
+
# Build features with context from past work
|
|
100
130
|
buddy-do "add user authentication"
|
|
131
|
+
|
|
132
|
+
# Recall why decisions were made
|
|
101
133
|
buddy-remember "API design decisions"
|
|
102
134
|
buddy-remember "why we chose PostgreSQL"
|
|
103
135
|
```
|
|
104
136
|
|
|
105
|
-
|
|
137
|
+
All data stays on your machine. Decisions kept 90 days, session notes 30 days.
|
|
106
138
|
|
|
107
139
|
---
|
|
108
140
|
|
|
109
|
-
##
|
|
141
|
+
## How is this different from CLAUDE.md?
|
|
142
|
+
|
|
143
|
+
| | CLAUDE.md | MeMesh |
|
|
144
|
+
|---|-----------|--------|
|
|
145
|
+
| **Purpose** | Static instructions for Claude | Living memory that grows with your project |
|
|
146
|
+
| **Search** | Manual text search | Semantic search by meaning |
|
|
147
|
+
| **Updates** | You edit manually | Auto-captures decisions as you work |
|
|
148
|
+
| **Recall** | Always loaded (can get long) | Surfaces relevant context on demand |
|
|
149
|
+
| **Scope** | General preferences | Project-specific knowledge graph |
|
|
150
|
+
|
|
151
|
+
**They work together.** CLAUDE.md tells Claude *how* to work. MeMesh remembers *what* you've built.
|
|
152
|
+
|
|
153
|
+
---
|
|
154
|
+
|
|
155
|
+
## Platform Support
|
|
110
156
|
|
|
111
157
|
| Platform | Status |
|
|
112
158
|
|----------|--------|
|
|
113
|
-
|
|
|
114
|
-
|
|
|
115
|
-
|
|
|
116
|
-
|
|
117
|
-
**Works with:**
|
|
118
|
-
- Claude Code CLI (terminal)
|
|
119
|
-
- Claude Code VS Code Extension
|
|
120
|
-
- Cursor (via MCP)
|
|
121
|
-
- Other MCP-compatible editors
|
|
159
|
+
| macOS | ✅ |
|
|
160
|
+
| Linux | ✅ |
|
|
161
|
+
| Windows | ✅ (WSL2 recommended) |
|
|
122
162
|
|
|
123
|
-
**Claude
|
|
163
|
+
**Works with:** Claude Code CLI · VS Code Extension · Cursor (via MCP) · Any MCP-compatible editor
|
|
124
164
|
|
|
125
165
|
---
|
|
126
166
|
|
|
127
|
-
##
|
|
167
|
+
## Architecture
|
|
128
168
|
|
|
129
|
-
|
|
169
|
+
MeMesh runs as a local MCP server alongside Claude Code:
|
|
130
170
|
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
171
|
+
- **Knowledge Graph** — SQLite-backed entity store with FTS5 full-text search
|
|
172
|
+
- **Vector Embeddings** — ONNX runtime for semantic similarity (runs 100% locally)
|
|
173
|
+
- **Content Dedup** — SHA-256 hashing skips redundant embedding computation
|
|
174
|
+
- **Batch Processing** — Efficient bulk operations for large knowledge bases
|
|
175
|
+
- **Hook System** — Proactive recall on session start, test failures, and errors
|
|
134
176
|
|
|
135
|
-
|
|
136
|
-
node --version
|
|
177
|
+
Everything runs locally. No cloud. No API calls. Your data never leaves your machine.
|
|
137
178
|
|
|
138
|
-
|
|
139
|
-
memesh setup
|
|
140
|
-
```
|
|
179
|
+
---
|
|
141
180
|
|
|
142
|
-
|
|
181
|
+
## Documentation
|
|
143
182
|
|
|
144
|
-
|
|
183
|
+
| Doc | Description |
|
|
184
|
+
|-----|-------------|
|
|
185
|
+
| [Getting Started](docs/GETTING_STARTED.md) | Step-by-step setup guide |
|
|
186
|
+
| [User Guide](docs/USER_GUIDE.md) | Full usage guide with examples |
|
|
187
|
+
| [Commands](docs/COMMANDS.md) | Complete command reference |
|
|
188
|
+
| [Architecture](docs/ARCHITECTURE.md) | Technical deep dive |
|
|
189
|
+
| [Contributing](CONTRIBUTING.md) | Contribution guidelines |
|
|
190
|
+
| [Development](docs/DEVELOPMENT.md) | Dev setup for contributors |
|
|
145
191
|
|
|
146
192
|
---
|
|
147
193
|
|
|
148
|
-
##
|
|
194
|
+
## Contributing
|
|
149
195
|
|
|
150
|
-
|
|
151
|
-
- **[User Guide](docs/USER_GUIDE.md)** — Full usage guide with examples
|
|
152
|
-
- **[Commands](docs/COMMANDS.md)** — All available commands
|
|
153
|
-
- **[Architecture](docs/ARCHITECTURE.md)** — How it works under the hood
|
|
154
|
-
- **[Contributing](CONTRIBUTING.md)** — Want to help? Start here
|
|
155
|
-
- **[Development Guide](docs/DEVELOPMENT.md)** — For contributors
|
|
196
|
+
We welcome contributions! See [CONTRIBUTING.md](CONTRIBUTING.md) to get started.
|
|
156
197
|
|
|
157
198
|
---
|
|
158
199
|
|
|
@@ -164,8 +205,8 @@ MIT — See [LICENSE](LICENSE)
|
|
|
164
205
|
|
|
165
206
|
<div align="center">
|
|
166
207
|
|
|
167
|
-
|
|
208
|
+
**Built with Claude Code, for Claude Code.**
|
|
168
209
|
|
|
169
|
-
[Report Bug](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new?labels=bug&template=bug_report.yml)
|
|
210
|
+
[Report Bug](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new?labels=bug&template=bug_report.yml) · [Request Feature](https://github.com/PCIRCLE-AI/claude-code-buddy/discussions) · [Get Help](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new)
|
|
170
211
|
|
|
171
212
|
</div>
|
package/README.th.md
CHANGED
|
@@ -1,77 +1,106 @@
|
|
|
1
1
|
<div align="center">
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
<img src="https://img.shields.io/badge/%F0%9F%A7%A0-MeMesh-blueviolet?style=for-the-badge" alt="MeMesh" />
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
# MeMesh
|
|
6
6
|
|
|
7
|
-
|
|
7
|
+
### เซสชันเขียนโค้ดกับ AI ของคุณสมควรมีหน่วยความจำ
|
|
8
8
|
|
|
9
|
-
|
|
10
|
-
[](LICENSE)
|
|
11
|
-
[](https://modelcontextprotocol.io)
|
|
9
|
+
MeMesh มอบหน่วยความจำถาวรที่ค้นหาได้ให้ Claude Code — ทำให้ทุกเซสชันต่อยอดจากเซสชันก่อนหน้า
|
|
12
10
|
|
|
13
|
-
[
|
|
11
|
+
[](https://www.npmjs.com/package/@pcircle/memesh)
|
|
12
|
+
[](https://www.npmjs.com/package/@pcircle/memesh)
|
|
13
|
+
[](LICENSE)
|
|
14
|
+
[](https://nodejs.org)
|
|
15
|
+
[](https://modelcontextprotocol.io)
|
|
14
16
|
|
|
15
|
-
|
|
17
|
+
```bash
|
|
18
|
+
npm install -g @pcircle/memesh
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
[เริ่มต้นใช้งาน](#เริ่มต้นใช้งาน) · [วิธีการทำงาน](#วิธีการทำงาน) · [คำสั่ง](#คำสั่ง) · [เอกสาร](docs/USER_GUIDE.md)
|
|
22
|
+
|
|
23
|
+
[English](README.md) · [繁體中文](README.zh-TW.md) · [简体中文](README.zh-CN.md) · [日本語](README.ja.md) · [한국어](README.ko.md) · [Français](README.fr.md) · [Deutsch](README.de.md) · [Español](README.es.md) · [Tiếng Việt](README.vi.md) · **ภาษาไทย** · [Bahasa Indonesia](README.id.md)
|
|
16
24
|
|
|
17
25
|
</div>
|
|
18
26
|
|
|
27
|
+
> **หมายเหตุ**: โปรเจกต์นี้เดิมชื่อ "Claude Code Buddy" และถูกเปลี่ยนชื่อเป็น MeMesh Plugin เพื่อหลีกเลี่ยงปัญหาเครื่องหมายการค้า
|
|
28
|
+
|
|
19
29
|
---
|
|
20
30
|
|
|
21
|
-
##
|
|
31
|
+
## ปัญหา
|
|
22
32
|
|
|
23
|
-
|
|
33
|
+
คุณกำลังทำงานโปรเจกต์กับ Claude Code อย่างเข้มข้น คุณตัดสินใจเรื่องสำคัญไปเมื่อสามเซสชันก่อน — จะใช้ไลบรารี auth ตัวไหน ทำไมถึงเลือกสคีมาฐานข้อมูลแบบนั้น ควรใช้รูปแบบอะไร แต่ Claude จำไม่ได้ คุณต้องพูดซ้ำ เสียบริบท เสียเวลา
|
|
24
34
|
|
|
25
|
-
|
|
35
|
+
**MeMesh แก้ปัญหานี้** โดยมอบหน่วยความจำถาวรที่ค้นหาได้ซึ่งเติบโตไปพร้อมกับโปรเจกต์ของคุณ
|
|
26
36
|
|
|
27
|
-
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## วิธีการทำงาน
|
|
40
|
+
|
|
41
|
+
<table>
|
|
42
|
+
<tr>
|
|
43
|
+
<td width="50%">
|
|
44
|
+
|
|
45
|
+
### ก่อนใช้ MeMesh
|
|
46
|
+
```
|
|
47
|
+
Session 1: "Use JWT for auth"
|
|
48
|
+
Session 2: "Why did we pick JWT again?"
|
|
49
|
+
Session 3: "Wait, what auth library are we using?"
|
|
50
|
+
```
|
|
51
|
+
คุณต้องทวนการตัดสินใจซ้ำ Claude ลืมบริบท ความคืบหน้าหยุดชะงัก
|
|
52
|
+
|
|
53
|
+
</td>
|
|
54
|
+
<td width="50%">
|
|
28
55
|
|
|
29
|
-
|
|
56
|
+
### หลังใช้ MeMesh
|
|
57
|
+
```
|
|
58
|
+
Session 1: "Use JWT for auth" → saved
|
|
59
|
+
Session 2: buddy-remember "auth" → instant recall
|
|
60
|
+
Session 3: Context auto-loaded on start
|
|
61
|
+
```
|
|
62
|
+
ทุกเซสชันเริ่มต่อจากจุดที่คุณหยุดไว้
|
|
30
63
|
|
|
31
|
-
|
|
64
|
+
</td>
|
|
65
|
+
</tr>
|
|
66
|
+
</table>
|
|
32
67
|
|
|
33
|
-
|
|
68
|
+
---
|
|
34
69
|
|
|
35
|
-
|
|
70
|
+
## สิ่งที่คุณจะได้รับ
|
|
36
71
|
|
|
37
|
-
|
|
38
|
-
- แสดงสรุปการทำงานครั้งก่อนเมื่อเริ่มเซสชัน
|
|
39
|
-
- ติดตามไฟล์ที่แก้ไขและทดสอบ
|
|
40
|
-
- เตือนให้รีวิวโค้ดก่อน commit
|
|
41
|
-
- กำหนดเส้นทางงานไปยังโมเดลที่เหมาะสม
|
|
72
|
+
**หน่วยความจำโปรเจกต์ที่ค้นหาได้** — ถามว่า "เราตัดสินใจเรื่อง auth ยังไง?" แล้วได้คำตอบทันทีที่จับคู่ตามความหมาย ไม่ใช่การค้นหาด้วยคีย์เวิร์ด — แต่เป็นการค้นหาด้วย*ความหมาย* ขับเคลื่อนด้วย ONNX embeddings บนเครื่องของคุณ
|
|
42
73
|
|
|
43
|
-
|
|
74
|
+
**การวิเคราะห์งานอัจฉริยะ** — `buddy-do "add user auth"` ไม่ได้แค่รันคำสั่ง มันดึงบริบทที่เกี่ยวข้องจากเซสชันก่อนหน้า ตรวจสอบรูปแบบที่คุณกำหนดไว้ และสร้างแผนที่สมบูรณ์ก่อนเขียนโค้ดแม้แต่บรรทัดเดียว
|
|
44
75
|
|
|
45
|
-
|
|
76
|
+
**การเรียกคืนเชิงรุก** — MeMesh แสดงความทรงจำที่เกี่ยวข้องโดยอัตโนมัติเมื่อคุณเริ่มเซสชัน เจอเทสต์ล้มเหลว หรือพบข้อผิดพลาด ไม่ต้องค้นหาเอง
|
|
46
77
|
|
|
47
|
-
|
|
78
|
+
**ระบบอัตโนมัติของเวิร์กโฟลว์** — สรุปเซสชันเมื่อเริ่มงาน ติดตามการเปลี่ยนแปลงไฟล์ เตือนให้รีวิวโค้ดก่อน commit ทั้งหมดทำงานเงียบๆ ในเบื้องหลัง
|
|
48
79
|
|
|
49
|
-
|
|
50
|
-
- **CLAUDE.md** = คู่มือการใช้งานสำหรับ Claude
|
|
51
|
-
- **MeMesh** = สมุดบันทึกที่ค้นหาได้ + ผู้ช่วยอัจฉริยะที่เติบโตไปกับโปรเจกต์ของคุณ
|
|
80
|
+
**เรียนรู้จากข้อผิดพลาด** — บันทึกข้อผิดพลาดและการแก้ไขเพื่อสร้างฐานความรู้ ข้อผิดพลาดเดิมจะไม่เกิดขึ้นซ้ำ
|
|
52
81
|
|
|
53
82
|
---
|
|
54
83
|
|
|
55
|
-
##
|
|
84
|
+
## เริ่มต้นใช้งาน
|
|
56
85
|
|
|
57
|
-
**สิ่งที่ต้องมี**: [Claude Code](https://docs.anthropic.com/en/docs/claude-code)
|
|
86
|
+
**สิ่งที่ต้องมี**: [Claude Code](https://docs.anthropic.com/en/docs/claude-code) + Node.js 20+
|
|
58
87
|
|
|
59
88
|
```bash
|
|
60
89
|
npm install -g @pcircle/memesh
|
|
61
90
|
```
|
|
62
91
|
|
|
63
|
-
รีสตาร์ท Claude Code
|
|
92
|
+
รีสตาร์ท Claude Code เท่านั้นเอง
|
|
64
93
|
|
|
65
|
-
|
|
94
|
+
**ตรวจสอบ** — พิมพ์ใน Claude Code:
|
|
66
95
|
|
|
67
96
|
```
|
|
68
97
|
buddy-help
|
|
69
98
|
```
|
|
70
99
|
|
|
71
|
-
|
|
100
|
+
คุณจะเห็นรายการคำสั่งที่ใช้ได้
|
|
72
101
|
|
|
73
102
|
<details>
|
|
74
|
-
<summary
|
|
103
|
+
<summary><strong>ติดตั้งจากซอร์สโค้ด</strong> (สำหรับผู้ร่วมพัฒนา)</summary>
|
|
75
104
|
|
|
76
105
|
```bash
|
|
77
106
|
git clone https://github.com/PCIRCLE-AI/claude-code-buddy.git
|
|
@@ -83,76 +112,88 @@ npm install && npm run build
|
|
|
83
112
|
|
|
84
113
|
---
|
|
85
114
|
|
|
86
|
-
##
|
|
87
|
-
|
|
88
|
-
MeMesh เพิ่ม 3 คำสั่งใน Claude Code:
|
|
115
|
+
## คำสั่ง
|
|
89
116
|
|
|
90
117
|
| คำสั่ง | ทำอะไร |
|
|
91
|
-
|
|
92
|
-
| `buddy-do "
|
|
93
|
-
| `buddy-remember "
|
|
118
|
+
|---------|-------------|
|
|
119
|
+
| `buddy-do "task"` | รันงานพร้อมบริบทหน่วยความจำเต็มรูปแบบ |
|
|
120
|
+
| `buddy-remember "topic"` | ค้นหาการตัดสินใจและบริบทที่ผ่านมา |
|
|
94
121
|
| `buddy-help` | แสดงคำสั่งที่ใช้ได้ |
|
|
95
122
|
|
|
96
|
-
|
|
123
|
+
**ตัวอย่างจริง:**
|
|
97
124
|
|
|
98
125
|
```bash
|
|
99
|
-
|
|
100
|
-
buddy-do "
|
|
101
|
-
|
|
102
|
-
|
|
126
|
+
# ทำความเข้าใจ codebase ที่ไม่คุ้นเคย
|
|
127
|
+
buddy-do "explain this codebase"
|
|
128
|
+
|
|
129
|
+
# สร้างฟีเจอร์พร้อมบริบทจากงานที่ผ่านมา
|
|
130
|
+
buddy-do "add user authentication"
|
|
131
|
+
|
|
132
|
+
# เรียกดูเหตุผลของการตัดสินใจ
|
|
133
|
+
buddy-remember "API design decisions"
|
|
134
|
+
buddy-remember "why we chose PostgreSQL"
|
|
103
135
|
```
|
|
104
136
|
|
|
105
|
-
|
|
137
|
+
ข้อมูลทั้งหมดอยู่บนเครื่องของคุณ การตัดสินใจเก็บไว้ 90 วัน บันทึกเซสชันเก็บไว้ 30 วัน
|
|
138
|
+
|
|
139
|
+
---
|
|
140
|
+
|
|
141
|
+
## MeMesh ต่างจาก CLAUDE.md อย่างไร?
|
|
142
|
+
|
|
143
|
+
| | CLAUDE.md | MeMesh |
|
|
144
|
+
|---|-----------|--------|
|
|
145
|
+
| **วัตถุประสงค์** | คำสั่งคงที่สำหรับ Claude | หน่วยความจำที่มีชีวิตซึ่งเติบโตไปกับโปรเจกต์ |
|
|
146
|
+
| **การค้นหา** | ค้นหาข้อความด้วยตนเอง | ค้นหาเชิงความหมายตามความหมาย |
|
|
147
|
+
| **การอัปเดต** | คุณแก้ไขเอง | บันทึกการตัดสินใจอัตโนมัติขณะทำงาน |
|
|
148
|
+
| **การเรียกคืน** | โหลดทุกครั้ง (อาจยาวมาก) | แสดงบริบทที่เกี่ยวข้องตามต้องการ |
|
|
149
|
+
| **ขอบเขต** | การตั้งค่าทั่วไป | กราฟความรู้เฉพาะโปรเจกต์ |
|
|
150
|
+
|
|
151
|
+
**ทั้งสองทำงานร่วมกัน** CLAUDE.md บอก Claude ว่าต้องทำงาน*อย่างไร* MeMesh จำว่าคุณ*สร้างอะไร*ไปบ้าง
|
|
106
152
|
|
|
107
153
|
---
|
|
108
154
|
|
|
109
155
|
## รองรับแพลตฟอร์ม
|
|
110
156
|
|
|
111
157
|
| แพลตฟอร์ม | สถานะ |
|
|
112
|
-
|
|
113
|
-
|
|
|
114
|
-
|
|
|
115
|
-
|
|
|
116
|
-
|
|
117
|
-
**ใช้ร่วมกับ:**
|
|
118
|
-
- Claude Code CLI (เทอร์มินัล)
|
|
119
|
-
- Claude Code VS Code Extension
|
|
120
|
-
- Cursor (ผ่าน MCP)
|
|
121
|
-
- เอดิเตอร์อื่นที่รองรับ MCP
|
|
158
|
+
|----------|--------|
|
|
159
|
+
| macOS | ✅ |
|
|
160
|
+
| Linux | ✅ |
|
|
161
|
+
| Windows | ✅ (แนะนำ WSL2) |
|
|
122
162
|
|
|
123
|
-
|
|
163
|
+
**ใช้ร่วมกับ:** Claude Code CLI · VS Code Extension · Cursor (ผ่าน MCP) · เอดิเตอร์ใดก็ได้ที่รองรับ MCP
|
|
124
164
|
|
|
125
165
|
---
|
|
126
166
|
|
|
127
|
-
##
|
|
167
|
+
## สถาปัตยกรรม
|
|
128
168
|
|
|
129
|
-
|
|
169
|
+
MeMesh ทำงานเป็นเซิร์ฟเวอร์ MCP บนเครื่องควบคู่กับ Claude Code:
|
|
130
170
|
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
171
|
+
- **Knowledge Graph** — ที่เก็บ entity บน SQLite พร้อมการค้นหาข้อความเต็มรูปแบบ FTS5
|
|
172
|
+
- **Vector Embeddings** — ONNX runtime สำหรับความคล้ายคลึงเชิงความหมาย (ทำงานบนเครื่อง 100%)
|
|
173
|
+
- **Content Dedup** — แฮช SHA-256 ข้ามการคำนวณ embedding ที่ซ้ำซ้อน
|
|
174
|
+
- **Batch Processing** — การดำเนินการจำนวนมากอย่างมีประสิทธิภาพสำหรับฐานความรู้ขนาดใหญ่
|
|
175
|
+
- **Hook System** — เรียกคืนเชิงรุกเมื่อเริ่มเซสชัน เทสต์ล้มเหลว และเกิดข้อผิดพลาด
|
|
134
176
|
|
|
135
|
-
|
|
136
|
-
node --version
|
|
177
|
+
ทุกอย่างทำงานบนเครื่อง ไม่ใช้คลาวด์ ไม่เรียก API ข้อมูลของคุณไม่ออกจากเครื่องเด็ดขาด
|
|
137
178
|
|
|
138
|
-
|
|
139
|
-
memesh setup
|
|
140
|
-
```
|
|
179
|
+
---
|
|
141
180
|
|
|
142
|
-
|
|
181
|
+
## เอกสาร
|
|
143
182
|
|
|
144
|
-
|
|
183
|
+
| เอกสาร | คำอธิบาย |
|
|
184
|
+
|-----|-------------|
|
|
185
|
+
| [เริ่มต้นใช้งาน](docs/GETTING_STARTED.md) | คู่มือการตั้งค่าทีละขั้นตอน |
|
|
186
|
+
| [คู่มือผู้ใช้](docs/USER_GUIDE.md) | คู่มือการใช้งานฉบับเต็มพร้อมตัวอย่าง |
|
|
187
|
+
| [คำสั่ง](docs/COMMANDS.md) | รายการคำสั่งทั้งหมด |
|
|
188
|
+
| [สถาปัตยกรรม](docs/ARCHITECTURE.md) | รายละเอียดเชิงเทคนิคเชิงลึก |
|
|
189
|
+
| [ร่วมพัฒนา](CONTRIBUTING.md) | แนวทางการร่วมพัฒนา |
|
|
190
|
+
| [การพัฒนา](docs/DEVELOPMENT.md) | การตั้งค่าสำหรับผู้ร่วมพัฒนา |
|
|
145
191
|
|
|
146
192
|
---
|
|
147
193
|
|
|
148
|
-
##
|
|
194
|
+
## ร่วมพัฒนา
|
|
149
195
|
|
|
150
|
-
|
|
151
|
-
- **[คู่มือผู้ใช้](docs/USER_GUIDE.md)** — คู่มือฉบับเต็มพร้อมตัวอย่าง
|
|
152
|
-
- **[คำสั่ง](docs/COMMANDS.md)** — คำสั่งทั้งหมดที่ใช้ได้
|
|
153
|
-
- **[สถาปัตยกรรม](docs/ARCHITECTURE.md)** — วิธีทำงานเบื้องหลัง
|
|
154
|
-
- **[ร่วมพัฒนา](CONTRIBUTING.md)** — อยากช่วย? เริ่มที่นี่
|
|
155
|
-
- **[คู่มือพัฒนา](docs/DEVELOPMENT.md)** — สำหรับผู้ร่วมพัฒนา
|
|
196
|
+
เรายินดีต้อนรับการร่วมพัฒนา! ดู [CONTRIBUTING.md](CONTRIBUTING.md) เพื่อเริ่มต้น
|
|
156
197
|
|
|
157
198
|
---
|
|
158
199
|
|
|
@@ -164,8 +205,8 @@ MIT — ดู [LICENSE](LICENSE)
|
|
|
164
205
|
|
|
165
206
|
<div align="center">
|
|
166
207
|
|
|
167
|
-
|
|
208
|
+
**สร้างด้วย Claude Code เพื่อ Claude Code**
|
|
168
209
|
|
|
169
|
-
[รายงานบัก](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new?labels=bug&template=bug_report.yml)
|
|
210
|
+
[รายงานบัก](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new?labels=bug&template=bug_report.yml) · [ขอฟีเจอร์](https://github.com/PCIRCLE-AI/claude-code-buddy/discussions) · [ขอความช่วยเหลือ](https://github.com/PCIRCLE-AI/claude-code-buddy/issues/new)
|
|
170
211
|
|
|
171
212
|
</div>
|