mindlore 0.6.7 → 0.6.8

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.
Files changed (169) hide show
  1. package/README.md +259 -259
  2. package/SCHEMA.md +292 -292
  3. package/dist/scripts/cc-memory-bulk-sync.d.ts.map +1 -1
  4. package/dist/scripts/cc-memory-bulk-sync.js +47 -42
  5. package/dist/scripts/cc-memory-bulk-sync.js.map +1 -1
  6. package/dist/scripts/cc-session-sync.d.ts.map +1 -1
  7. package/dist/scripts/cc-session-sync.js +58 -48
  8. package/dist/scripts/cc-session-sync.js.map +1 -1
  9. package/dist/scripts/init.js +8 -8
  10. package/dist/scripts/init.js.map +1 -1
  11. package/dist/scripts/lib/all-migrations.d.ts.map +1 -1
  12. package/dist/scripts/lib/all-migrations.js +4 -1
  13. package/dist/scripts/lib/all-migrations.js.map +1 -1
  14. package/dist/scripts/lib/consolidation.d.ts +4 -3
  15. package/dist/scripts/lib/consolidation.d.ts.map +1 -1
  16. package/dist/scripts/lib/consolidation.js +10 -10
  17. package/dist/scripts/lib/consolidation.js.map +1 -1
  18. package/dist/scripts/lib/constants.d.ts +1 -7
  19. package/dist/scripts/lib/constants.d.ts.map +1 -1
  20. package/dist/scripts/lib/constants.js +2 -9
  21. package/dist/scripts/lib/constants.js.map +1 -1
  22. package/dist/scripts/lib/db-helpers.d.ts +0 -15
  23. package/dist/scripts/lib/db-helpers.d.ts.map +1 -1
  24. package/dist/scripts/lib/db-helpers.js +1 -51
  25. package/dist/scripts/lib/db-helpers.js.map +1 -1
  26. package/dist/scripts/lib/decay.d.ts.map +1 -1
  27. package/dist/scripts/lib/decay.js +9 -9
  28. package/dist/scripts/lib/decay.js.map +1 -1
  29. package/dist/scripts/lib/episodes.js +23 -23
  30. package/dist/scripts/lib/migrations-v061.js +21 -21
  31. package/dist/scripts/lib/migrations-v062.js +11 -11
  32. package/dist/scripts/lib/migrations-v063.js +14 -14
  33. package/dist/scripts/lib/migrations-v067.js +11 -11
  34. package/dist/scripts/lib/migrations-v068.d.ts +3 -0
  35. package/dist/scripts/lib/migrations-v068.d.ts.map +1 -0
  36. package/dist/scripts/lib/migrations-v068.js +37 -0
  37. package/dist/scripts/lib/migrations-v068.js.map +1 -0
  38. package/dist/scripts/lib/migrations.d.ts.map +1 -1
  39. package/dist/scripts/lib/migrations.js +0 -15
  40. package/dist/scripts/lib/migrations.js.map +1 -1
  41. package/dist/scripts/lib/schema-version.js +6 -6
  42. package/dist/scripts/lib/search-cache.js +11 -11
  43. package/dist/scripts/lib/session-payload.d.ts.map +1 -1
  44. package/dist/scripts/lib/session-payload.js +7 -7
  45. package/dist/scripts/lib/session-payload.js.map +1 -1
  46. package/dist/scripts/lib/triage.js +3 -3
  47. package/dist/scripts/mindlore-backup.js +9 -9
  48. package/dist/scripts/mindlore-fts5-index.d.ts +1 -2
  49. package/dist/scripts/mindlore-fts5-index.d.ts.map +1 -1
  50. package/dist/scripts/mindlore-fts5-index.js +12 -64
  51. package/dist/scripts/mindlore-fts5-index.js.map +1 -1
  52. package/dist/scripts/mindlore-health-check.d.ts.map +1 -1
  53. package/dist/scripts/mindlore-health-check.js +0 -11
  54. package/dist/scripts/mindlore-health-check.js.map +1 -1
  55. package/dist/tests/cc-memory-bulk-sync.test.js +23 -0
  56. package/dist/tests/cc-memory-bulk-sync.test.js.map +1 -1
  57. package/dist/tests/cc-session-sync.test.js +25 -0
  58. package/dist/tests/cc-session-sync.test.js.map +1 -1
  59. package/dist/tests/compaction-snapshot.test.js +2 -2
  60. package/dist/tests/consolidation.test.js +5 -5
  61. package/dist/tests/consolidation.test.js.map +1 -1
  62. package/dist/tests/decay.test.js +9 -9
  63. package/dist/tests/diary.test.js +4 -4
  64. package/dist/tests/episode-kind-constant.test.d.ts +2 -0
  65. package/dist/tests/episode-kind-constant.test.d.ts.map +1 -0
  66. package/dist/tests/episode-kind-constant.test.js +28 -0
  67. package/dist/tests/episode-kind-constant.test.js.map +1 -0
  68. package/dist/tests/episodes-inject.test.js +9 -9
  69. package/dist/tests/fts5.test.js +66 -125
  70. package/dist/tests/fts5.test.js.map +1 -1
  71. package/dist/tests/globalSetup.d.ts +2 -0
  72. package/dist/tests/globalSetup.d.ts.map +1 -0
  73. package/dist/tests/globalSetup.js +36 -0
  74. package/dist/tests/globalSetup.js.map +1 -0
  75. package/dist/tests/helpers/db.d.ts +13 -5
  76. package/dist/tests/helpers/db.d.ts.map +1 -1
  77. package/dist/tests/helpers/db.js +60 -33
  78. package/dist/tests/helpers/db.js.map +1 -1
  79. package/dist/tests/lesson-graduation.test.js +11 -11
  80. package/dist/tests/lesson-graduation.test.js.map +1 -1
  81. package/dist/tests/migrations-v053.test.js +16 -16
  82. package/dist/tests/migrations-v061.test.js +10 -10
  83. package/dist/tests/migrations-v063.test.js +2 -2
  84. package/dist/tests/migrations-v068.test.d.ts +2 -0
  85. package/dist/tests/migrations-v068.test.d.ts.map +1 -0
  86. package/dist/tests/migrations-v068.test.js +53 -0
  87. package/dist/tests/migrations-v068.test.js.map +1 -0
  88. package/dist/tests/nomination-counts.test.d.ts +2 -0
  89. package/dist/tests/nomination-counts.test.d.ts.map +1 -0
  90. package/dist/tests/nomination-counts.test.js +51 -0
  91. package/dist/tests/nomination-counts.test.js.map +1 -0
  92. package/dist/tests/recall-telemetry.test.js +8 -8
  93. package/dist/tests/schema-version.test.js +3 -7
  94. package/dist/tests/schema-version.test.js.map +1 -1
  95. package/dist/tests/search-hook.test.js +2 -2
  96. package/dist/tests/sec-regression.test.js +0 -50
  97. package/dist/tests/sec-regression.test.js.map +1 -1
  98. package/dist/tests/session-end-cleanup.test.js +3 -20
  99. package/dist/tests/session-end-cleanup.test.js.map +1 -1
  100. package/dist/tests/session-focus.test.js +7 -30
  101. package/dist/tests/session-focus.test.js.map +1 -1
  102. package/dist/tests/session-payload.test.js +1 -1
  103. package/dist/tests/session-summary.test.js +1 -1
  104. package/hooks/lib/constants.cjs +15 -0
  105. package/hooks/lib/mindlore-common.cjs +974 -1042
  106. package/hooks/mindlore-cwd-changed.cjs +57 -57
  107. package/hooks/mindlore-decision-detector.cjs +54 -54
  108. package/hooks/mindlore-dont-repeat.cjs +222 -222
  109. package/hooks/mindlore-fts5-sync.cjs +97 -88
  110. package/hooks/mindlore-index.cjs +229 -229
  111. package/hooks/mindlore-model-router.cjs +54 -54
  112. package/hooks/mindlore-post-compact.cjs +69 -69
  113. package/hooks/mindlore-post-read.cjs +106 -106
  114. package/hooks/mindlore-pre-compact.cjs +154 -154
  115. package/hooks/mindlore-read-guard.cjs +105 -105
  116. package/hooks/mindlore-research-guard.cjs +176 -176
  117. package/hooks/mindlore-search.cjs +200 -200
  118. package/hooks/mindlore-session-end.cjs +509 -526
  119. package/hooks/mindlore-session-focus.cjs +256 -259
  120. package/package.json +75 -78
  121. package/plugin.json +1 -1
  122. package/skills/mindlore-diary/SKILL.md +85 -85
  123. package/skills/mindlore-evolve/SKILL.md +126 -126
  124. package/skills/mindlore-explore/SKILL.md +109 -109
  125. package/skills/mindlore-ingest/SKILL.md +195 -195
  126. package/skills/mindlore-maintain/SKILL.md +125 -125
  127. package/skills/mindlore-query/SKILL.md +151 -151
  128. package/skills/mindlore-reflect/SKILL.md +141 -141
  129. package/skills/mindlore-stats/SKILL.md +106 -106
  130. package/templates/INDEX.md +14 -14
  131. package/templates/SCHEMA.md +292 -292
  132. package/templates/config.json +1 -1
  133. package/templates/extraction/article.md +15 -15
  134. package/templates/extraction/changelog.md +15 -15
  135. package/templates/extraction/default.md +15 -15
  136. package/templates/extraction/docs.md +15 -15
  137. package/templates/extraction/github-repo.md +17 -17
  138. package/dist/scripts/lib/daemon.d.ts +0 -16
  139. package/dist/scripts/lib/daemon.d.ts.map +0 -1
  140. package/dist/scripts/lib/daemon.js +0 -133
  141. package/dist/scripts/lib/daemon.js.map +0 -1
  142. package/dist/scripts/lib/embedding.d.ts +0 -5
  143. package/dist/scripts/lib/embedding.d.ts.map +0 -1
  144. package/dist/scripts/lib/embedding.js +0 -44
  145. package/dist/scripts/lib/embedding.js.map +0 -1
  146. package/dist/scripts/mindlore-daemon.d.ts +0 -2
  147. package/dist/scripts/mindlore-daemon.d.ts.map +0 -1
  148. package/dist/scripts/mindlore-daemon.js +0 -117
  149. package/dist/scripts/mindlore-daemon.js.map +0 -1
  150. package/dist/tests/daemon-integration.test.d.ts +0 -2
  151. package/dist/tests/daemon-integration.test.d.ts.map +0 -1
  152. package/dist/tests/daemon-integration.test.js +0 -37
  153. package/dist/tests/daemon-integration.test.js.map +0 -1
  154. package/dist/tests/daemon.test.d.ts +0 -2
  155. package/dist/tests/daemon.test.d.ts.map +0 -1
  156. package/dist/tests/daemon.test.js +0 -187
  157. package/dist/tests/daemon.test.js.map +0 -1
  158. package/dist/tests/embedding-hf-integration.test.d.ts +0 -2
  159. package/dist/tests/embedding-hf-integration.test.d.ts.map +0 -1
  160. package/dist/tests/embedding-hf-integration.test.js +0 -52
  161. package/dist/tests/embedding-hf-integration.test.js.map +0 -1
  162. package/dist/tests/embedding.test.d.ts +0 -6
  163. package/dist/tests/embedding.test.d.ts.map +0 -1
  164. package/dist/tests/embedding.test.js +0 -71
  165. package/dist/tests/embedding.test.js.map +0 -1
  166. package/dist/tests/sqlite-vec-v12.test.d.ts +0 -2
  167. package/dist/tests/sqlite-vec-v12.test.d.ts.map +0 -1
  168. package/dist/tests/sqlite-vec-v12.test.js +0 -72
  169. package/dist/tests/sqlite-vec-v12.test.js.map +0 -1
@@ -1,125 +1,125 @@
1
- ---
2
- name: mindlore-maintain
3
- description: KB maintenance — decay/archive, episode consolidation, contradiction detection
4
- effort: medium
5
- context: fork
6
- allowed-tools: [Read, Write, Edit, Bash, Grep, Glob]
7
- ---
8
-
9
- ## Script Resolution
10
-
11
- Resolve `MINDLORE_PKG` (package root) using one of these methods, in order:
12
- 1. If CC injected "Base directory for this skill: /path/to/skills/mindlore-maintain" → `MINDLORE_PKG = {base_directory}/../..`
13
- 2. Fallback: run `node -e "console.log(require('path').join(require('child_process').execSync('npm root -g',{encoding:'utf8'}).trim(),'mindlore')))"`
14
-
15
- Use: `node "$MINDLORE_PKG/dist/scripts/..."` for all script commands.
16
-
17
- # /mindlore-maintain
18
-
19
- KB bakım skill'i. Reflect düşünür, maintain temizler.
20
-
21
- ## Trigger
22
-
23
- - `/mindlore-maintain` — full rapor (decay + consolidation + contradiction)
24
- - `/mindlore-maintain decay` — stale doc listesi + archive flow
25
- - `/mindlore-maintain consolidate` — episode gruplama + dosyaya promote
26
- - `/mindlore-maintain contradictions` — çelişki analizi
27
- - `/mindlore-maintain triage` — unpromoted raw dosyaları listele + metadata göster
28
-
29
- ## Decay Mode
30
-
31
- 1. Stale documents listele:
32
- ```bash
33
- DECAY_MOD="$MINDLORE_PKG/dist/scripts/lib/decay.js"
34
- node -e "
35
- const { listStaleDocuments } = require(process.argv[1]);
36
- const Database = require('better-sqlite3');
37
- const path = require('path'), os = require('os');
38
- const dbPath = path.join(os.homedir(), '.mindlore', 'mindlore.db');
39
- const db = new Database(dbPath, {readonly: true});
40
- let decayConfig = {};
41
- try {
42
- const configPath = path.join(os.homedir(), '.mindlore', 'config.json');
43
- decayConfig = JSON.parse(require('fs').readFileSync(configPath, 'utf8')).decay || {};
44
- } catch (_err) { /* use defaults if config missing or malformed */ }
45
- const stale = listStaleDocuments(db, undefined, decayConfig);
46
- console.log(JSON.stringify(stale, null, 2));
47
- db.close();
48
- " "$DECAY_MOD"
49
- ```
50
-
51
- 2. Rapor sun:
52
- ```
53
- -- Decay Report --
54
- | # | File | Score | Last Access | Recalls | Action |
55
- |---|------|-------|-------------|---------|--------|
56
- | 1 | sources/old-api.md | 0.12 | 2025-11-01 | 0 | Archive? |
57
- ```
58
-
59
- 3. Kullanıcı onaylarsa:
60
- a. Git snapshot: `createPreEvictionTag`
61
- b. Arşivle: `archiveDocument(db, path)`
62
- c. Rapor: "Archived N docs. Git tag: pre-eviction-2026-04-18. Restore: `/mindlore-maintain restore <path>`"
63
-
64
- **Kurallar:**
65
- - Onay almadan ARŞİVLEME
66
- - Arşiv öncesi HER ZAMAN git snapshot
67
- - Score + last access + recall count göster
68
-
69
- ## Consolidation Mode
70
-
71
- 1. Raw episode sayısını kontrol et
72
- 2. Gruplama önerisi sun:
73
- ```
74
- -- Consolidation Önerisi --
75
- 3 learning episode → learnings/typescript-strict-patterns.md
76
- 2 discovery episode → insights/sqlite-vec-windows-gotchas.md
77
- ```
78
-
79
- 3. Kind→dizin mapping (deterministik):
80
- - learning → `learnings/`
81
- - discovery → `insights/`
82
- - friction → `analyses/`
83
- - decision → `decisions/`
84
- - preference → CC memory'de var mı kontrol et, varsa skip, yoksa `learnings/`
85
-
86
- 4. Kullanıcı onaylarsa:
87
- a. Hedef dosya yaz (frontmatter zorunlu: consolidated_from, consolidated_at, kind_source)
88
- b. Episode'ları işaretle: `markConsolidated(db, ids, targetFile)`
89
- c. Rapor: "N episode → M dosya promote edildi"
90
-
91
- **Kurallar:**
92
- - session/event episode'ları CONSOLİDATE EDİLMEZ
93
- - Onay almadan dosya YAZMA
94
- - `consolidated_from` frontmatter ZORUNLU (provenance)
95
-
96
- ## Contradiction Mode
97
-
98
- 1. Deterministic wiki-lint:
99
- ```bash
100
- node "$MINDLORE_PKG/dist/scripts/mindlore-health-check.js" ~/.mindlore 2>/dev/null | grep -A 5 'contradiction'
101
- ```
102
-
103
- 2. Semantic analiz (opsiyonel, token harcar)
104
-
105
- **Kurallar:**
106
- - Deterministic check HER ZAMAN çalışır
107
- - Çelişkileri OTOMATİK düzeltme — kullanıcıya sor
108
-
109
- ## Full Report Mode (flagsız)
110
-
111
- ```
112
- -- Maintain Report --
113
- Decay: 3 stale document (score < 0.3)
114
- Consolidation: 52 raw episode (learning: 15, discovery: 8, friction: 4)
115
- Contradictions: 1 found
116
-
117
- Aksiyon için:
118
- /mindlore-maintain decay
119
- /mindlore-maintain consolidate
120
- /mindlore-maintain contradictions
121
- ```
122
-
123
- ## Restore Mode
124
-
125
- `/mindlore-maintain restore <path>` — arşivlenmiş dokümanı geri yükler.
1
+ ---
2
+ name: mindlore-maintain
3
+ description: KB maintenance — decay/archive, episode consolidation, contradiction detection
4
+ effort: medium
5
+ context: fork
6
+ allowed-tools: [Read, Write, Edit, Bash, Grep, Glob]
7
+ ---
8
+
9
+ ## Script Resolution
10
+
11
+ Resolve `MINDLORE_PKG` (package root) using one of these methods, in order:
12
+ 1. If CC injected "Base directory for this skill: /path/to/skills/mindlore-maintain" → `MINDLORE_PKG = {base_directory}/../..`
13
+ 2. Fallback: run `node -e "console.log(require('path').join(require('child_process').execSync('npm root -g',{encoding:'utf8'}).trim(),'mindlore')))"`
14
+
15
+ Use: `node "$MINDLORE_PKG/dist/scripts/..."` for all script commands.
16
+
17
+ # /mindlore-maintain
18
+
19
+ KB bakım skill'i. Reflect düşünür, maintain temizler.
20
+
21
+ ## Trigger
22
+
23
+ - `/mindlore-maintain` — full rapor (decay + consolidation + contradiction)
24
+ - `/mindlore-maintain decay` — stale doc listesi + archive flow
25
+ - `/mindlore-maintain consolidate` — episode gruplama + dosyaya promote
26
+ - `/mindlore-maintain contradictions` — çelişki analizi
27
+ - `/mindlore-maintain triage` — unpromoted raw dosyaları listele + metadata göster
28
+
29
+ ## Decay Mode
30
+
31
+ 1. Stale documents listele:
32
+ ```bash
33
+ DECAY_MOD="$MINDLORE_PKG/dist/scripts/lib/decay.js"
34
+ node -e "
35
+ const { listStaleDocuments } = require(process.argv[1]);
36
+ const Database = require('better-sqlite3');
37
+ const path = require('path'), os = require('os');
38
+ const dbPath = path.join(os.homedir(), '.mindlore', 'mindlore.db');
39
+ const db = new Database(dbPath, {readonly: true});
40
+ let decayConfig = {};
41
+ try {
42
+ const configPath = path.join(os.homedir(), '.mindlore', 'config.json');
43
+ decayConfig = JSON.parse(require('fs').readFileSync(configPath, 'utf8')).decay || {};
44
+ } catch (_err) { /* use defaults if config missing or malformed */ }
45
+ const stale = listStaleDocuments(db, undefined, decayConfig);
46
+ console.log(JSON.stringify(stale, null, 2));
47
+ db.close();
48
+ " "$DECAY_MOD"
49
+ ```
50
+
51
+ 2. Rapor sun:
52
+ ```
53
+ -- Decay Report --
54
+ | # | File | Score | Last Access | Recalls | Action |
55
+ |---|------|-------|-------------|---------|--------|
56
+ | 1 | sources/old-api.md | 0.12 | 2025-11-01 | 0 | Archive? |
57
+ ```
58
+
59
+ 3. Kullanıcı onaylarsa:
60
+ a. Git snapshot: `createPreEvictionTag`
61
+ b. Arşivle: `archiveDocument(db, path)`
62
+ c. Rapor: "Archived N docs. Git tag: pre-eviction-2026-04-18. Restore: `/mindlore-maintain restore <path>`"
63
+
64
+ **Kurallar:**
65
+ - Onay almadan ARŞİVLEME
66
+ - Arşiv öncesi HER ZAMAN git snapshot
67
+ - Score + last access + recall count göster
68
+
69
+ ## Consolidation Mode
70
+
71
+ 1. Raw episode sayısını kontrol et
72
+ 2. Gruplama önerisi sun:
73
+ ```
74
+ -- Consolidation Önerisi --
75
+ 3 learning episode → learnings/typescript-strict-patterns.md
76
+ 2 discovery episode → insights/sqlite-vec-windows-gotchas.md
77
+ ```
78
+
79
+ 3. Kind→dizin mapping (deterministik):
80
+ - learning → `learnings/`
81
+ - discovery → `insights/`
82
+ - friction → `analyses/`
83
+ - decision → `decisions/`
84
+ - preference → CC memory'de var mı kontrol et, varsa skip, yoksa `learnings/`
85
+
86
+ 4. Kullanıcı onaylarsa:
87
+ a. Hedef dosya yaz (frontmatter zorunlu: consolidated_from, consolidated_at, kind_source)
88
+ b. Episode'ları işaretle: `markConsolidated(db, ids, targetFile)`
89
+ c. Rapor: "N episode → M dosya promote edildi"
90
+
91
+ **Kurallar:**
92
+ - session/event episode'ları CONSOLİDATE EDİLMEZ
93
+ - Onay almadan dosya YAZMA
94
+ - `consolidated_from` frontmatter ZORUNLU (provenance)
95
+
96
+ ## Contradiction Mode
97
+
98
+ 1. Deterministic wiki-lint:
99
+ ```bash
100
+ node "$MINDLORE_PKG/dist/scripts/mindlore-health-check.js" ~/.mindlore 2>/dev/null | grep -A 5 'contradiction'
101
+ ```
102
+
103
+ 2. Semantic analiz (opsiyonel, token harcar)
104
+
105
+ **Kurallar:**
106
+ - Deterministic check HER ZAMAN çalışır
107
+ - Çelişkileri OTOMATİK düzeltme — kullanıcıya sor
108
+
109
+ ## Full Report Mode (flagsız)
110
+
111
+ ```
112
+ -- Maintain Report --
113
+ Decay: 3 stale document (score < 0.3)
114
+ Consolidation: 52 raw episode (learning: 15, discovery: 8, friction: 4)
115
+ Contradictions: 1 found
116
+
117
+ Aksiyon için:
118
+ /mindlore-maintain decay
119
+ /mindlore-maintain consolidate
120
+ /mindlore-maintain contradictions
121
+ ```
122
+
123
+ ## Restore Mode
124
+
125
+ `/mindlore-maintain restore <path>` — arşivlenmiş dokümanı geri yükler.
@@ -1,151 +1,151 @@
1
- ---
2
- name: mindlore-query
3
- description: Search, ask, stats, brief — compounding pipeline
4
- context: fork
5
- allowed-tools: [Bash, Read, Grep, Glob]
6
- ---
7
-
8
- # Skill: Mindlore Query
9
-
10
- Search, ask, analyze, and retrieve knowledge from `.mindlore/`.
11
-
12
- ## Script Resolution
13
-
14
- Resolve `MINDLORE_PKG` (package root) using one of these methods, in order:
15
- 1. If CC injected "Base directory for this skill: /path/to/skills/mindlore-query" → `MINDLORE_PKG = {base_directory}/../..`
16
- 2. Fallback: run `node -e "console.log(require('path').join(require('child_process').execSync('npm root -g',{encoding:'utf8'}).trim(),'mindlore')))"`
17
-
18
- Use: `node "$MINDLORE_PKG/dist/scripts/..."` for all script commands.
19
-
20
- ## Scope
21
-
22
- Determine search scope using `getActiveMindloreDir()` / `getAllDbs()` logic:
23
- - Default (no flag): search project `.mindlore/` DB, fall back to global
24
- - `--global`: search only `~/.mindlore/` DB
25
- - `--all`: search both project + global DBs, project results first
26
- - Never hardcode `.mindlore/` path — always resolve dynamically
27
-
28
- ## Trigger
29
-
30
- `/mindlore-query <mode> [query]` where mode is `search`, `ask`, `stats`, or `brief`.
31
-
32
- ## Modes
33
-
34
- ### search
35
-
36
- FTS5 keyword search + episodes recall with unified results.
37
-
38
- **Flow:**
39
- 1. Parse user query into keywords (strip stop words)
40
- 2. Run FTS5 MATCH on `mindlore_fts` table (knowledge: "ne biliyorum")
41
- 3. Run LIKE search on `episodes` table (memory: "ne oldu, ne karar aldım")
42
- 4. Merge results: FTS5 results first, then matching episodes
43
- 5. Return top 5 knowledge results + top 3 episode results
44
- 6. Display knowledge as table with snippet preview, episodes as timeline
45
- 7. If `--tags <tag>` flag provided: `WHERE tags MATCH '<tag>'` filter (FTS5 only)
46
- 8. If `--episodes-only` flag: skip FTS5, show only episode matches
47
-
48
- **Output format:**
49
- ```
50
- | # | Category | Title | Description | Score |
51
- |---|----------|-------|-------------|-------|
52
- | 1 | sources | React Hooks | useEffect cleanup patterns | -2.34 |
53
- ```
54
-
55
- ### ask
56
-
57
- Compounding query pipeline — knowledge grows with each answer.
58
-
59
- **Flow:**
60
- 1. Parse user question
61
- 2. FTS5 search → find relevant files (sources + domains + analyses + insights — previous answers INCLUDED)
62
- 3. Read top 3-5 relevant files using ctx_execute_file if context-mode available, else Read
63
- 4. Synthesize answer from found knowledge
64
- 5. Cite sources: `[kaynak: sources/x.md]` format
65
- 6. Ask user: "Bu cevabı kaydetmemi ister misin?"
66
- 7. If yes → determine target:
67
- - Short answer (<200 lines, 1-2 sources) → `insights/{slug}.md`
68
- - Large synthesis (200+ lines, 3+ sources) → `analyses/{slug}.md`
69
- 8. Write with frontmatter:
70
-
71
- ```yaml
72
- ---
73
- slug: react-hooks-cleanup-comparison
74
- type: insight
75
- title: React Hooks Cleanup Comparison
76
- tags: [react, hooks, useEffect]
77
- confidence: high
78
- sources_used: [react-hooks, typescript-generics]
79
- description: Comparison of cleanup patterns in useEffect vs useLayoutEffect
80
- ---
81
- ```
82
-
83
- 9. FTS5 auto-indexes via FileChanged hook → next query finds this answer
84
- 10. Update relevant domain page (max 1) with backlink if applicable
85
- 11. Append to `log.md`: `| {date} | query-ask | {slug}.md |`
86
-
87
- **Compounding effect:** Step 2 searches ALL of `.mindlore/` including previous `insights/` and `analyses/`. Each saved answer enriches the next query.
88
-
89
- **Error compounding prevention:**
90
- - `confidence` field is REQUIRED on writebacks (high/medium/low)
91
- - `sources_used` lists exact slugs — traceability
92
- - Health check flags conflicting analyses on same topic (different confidence)
93
- - User approval is the quality gate — low-quality answers are not saved
94
-
95
- ### stats
96
-
97
- Knowledge base statistics.
98
-
99
- **Flow:**
100
- 1. Count files per directory (9 directories)
101
- 2. Count FTS5 entries and file_hashes entries
102
- 3. Find most recent ingest (latest file by modified date per directory)
103
- 4. Count tags frequency (parse all frontmatter, aggregate tags)
104
- 5. Display summary:
105
-
106
- ```
107
- Mindlore Stats
108
- ─────────────
109
- Total files: 47 (FTS5: 47 indexed)
110
- - sources: 18
111
- - domains: 5
112
- - analyses: 6
113
- - insights: 3
114
- - connections: 2
115
- - learnings: 4
116
- - diary: 8
117
- - decisions: 1
118
- - raw: 0
119
-
120
- Top tags: security (12), hooks (8), fts5 (6), testing (5)
121
- Last ingest: 2026-04-11 (sources/react-hooks.md)
122
- DB size: 1.2 MB
123
- ```
124
-
125
- ### brief
126
-
127
- Quick context on a topic — token-efficient (~50 tokens output).
128
-
129
- **Flow:**
130
- 1. FTS5 search for topic
131
- 2. If domain page exists → read first 3 lines of body (after frontmatter)
132
- 3. If no domain → read description field from top FTS5 match
133
- 4. Return: title + description + "Read full: {path}" pointer
134
- 5. Do NOT read full file — this mode is for quick "do I need to open this?" decisions
135
-
136
- **Output format:**
137
- ```
138
- [Mindlore Brief: Security]
139
- SSH hardening, firewall rules, audit checks. 5 sources, 2 analyses linked.
140
- → Read full: .mindlore/domains/security.md
141
- ```
142
-
143
- ## Rules
144
-
145
- - All modes respect the SCHEMA.md writeback rules (Section 6: Wiki vs Diary)
146
- - search and brief are read-only — no writes
147
- - ask writes only with user approval
148
- - stats is read-only
149
- - Token strategy: prefer ctx_execute_file (if context-mode installed), fallback to Read
150
- - Tags filter: `--tags security` works in search and ask modes
151
- - Max results: search=5, ask=3-5 (for synthesis), brief=1
1
+ ---
2
+ name: mindlore-query
3
+ description: Search, ask, stats, brief — compounding pipeline
4
+ context: fork
5
+ allowed-tools: [Bash, Read, Grep, Glob]
6
+ ---
7
+
8
+ # Skill: Mindlore Query
9
+
10
+ Search, ask, analyze, and retrieve knowledge from `.mindlore/`.
11
+
12
+ ## Script Resolution
13
+
14
+ Resolve `MINDLORE_PKG` (package root) using one of these methods, in order:
15
+ 1. If CC injected "Base directory for this skill: /path/to/skills/mindlore-query" → `MINDLORE_PKG = {base_directory}/../..`
16
+ 2. Fallback: run `node -e "console.log(require('path').join(require('child_process').execSync('npm root -g',{encoding:'utf8'}).trim(),'mindlore')))"`
17
+
18
+ Use: `node "$MINDLORE_PKG/dist/scripts/..."` for all script commands.
19
+
20
+ ## Scope
21
+
22
+ Determine search scope using `getActiveMindloreDir()` / `getAllDbs()` logic:
23
+ - Default (no flag): search project `.mindlore/` DB, fall back to global
24
+ - `--global`: search only `~/.mindlore/` DB
25
+ - `--all`: search both project + global DBs, project results first
26
+ - Never hardcode `.mindlore/` path — always resolve dynamically
27
+
28
+ ## Trigger
29
+
30
+ `/mindlore-query <mode> [query]` where mode is `search`, `ask`, `stats`, or `brief`.
31
+
32
+ ## Modes
33
+
34
+ ### search
35
+
36
+ FTS5 keyword search + episodes recall with unified results.
37
+
38
+ **Flow:**
39
+ 1. Parse user query into keywords (strip stop words)
40
+ 2. Run FTS5 MATCH on `mindlore_fts` table (knowledge: "ne biliyorum")
41
+ 3. Run LIKE search on `episodes` table (memory: "ne oldu, ne karar aldım")
42
+ 4. Merge results: FTS5 results first, then matching episodes
43
+ 5. Return top 5 knowledge results + top 3 episode results
44
+ 6. Display knowledge as table with snippet preview, episodes as timeline
45
+ 7. If `--tags <tag>` flag provided: `WHERE tags MATCH '<tag>'` filter (FTS5 only)
46
+ 8. If `--episodes-only` flag: skip FTS5, show only episode matches
47
+
48
+ **Output format:**
49
+ ```
50
+ | # | Category | Title | Description | Score |
51
+ |---|----------|-------|-------------|-------|
52
+ | 1 | sources | React Hooks | useEffect cleanup patterns | -2.34 |
53
+ ```
54
+
55
+ ### ask
56
+
57
+ Compounding query pipeline — knowledge grows with each answer.
58
+
59
+ **Flow:**
60
+ 1. Parse user question
61
+ 2. FTS5 search → find relevant files (sources + domains + analyses + insights — previous answers INCLUDED)
62
+ 3. Read top 3-5 relevant files
63
+ 4. Synthesize answer from found knowledge
64
+ 5. Cite sources: `[kaynak: sources/x.md]` format
65
+ 6. Ask user: "Bu cevabı kaydetmemi ister misin?"
66
+ 7. If yes → determine target:
67
+ - Short answer (<200 lines, 1-2 sources) → `insights/{slug}.md`
68
+ - Large synthesis (200+ lines, 3+ sources) → `analyses/{slug}.md`
69
+ 8. Write with frontmatter:
70
+
71
+ ```yaml
72
+ ---
73
+ slug: react-hooks-cleanup-comparison
74
+ type: insight
75
+ title: React Hooks Cleanup Comparison
76
+ tags: [react, hooks, useEffect]
77
+ confidence: high
78
+ sources_used: [react-hooks, typescript-generics]
79
+ description: Comparison of cleanup patterns in useEffect vs useLayoutEffect
80
+ ---
81
+ ```
82
+
83
+ 9. FTS5 auto-indexes via FileChanged hook → next query finds this answer
84
+ 10. Update relevant domain page (max 1) with backlink if applicable
85
+ 11. Append to `log.md`: `| {date} | query-ask | {slug}.md |`
86
+
87
+ **Compounding effect:** Step 2 searches ALL of `.mindlore/` including previous `insights/` and `analyses/`. Each saved answer enriches the next query.
88
+
89
+ **Error compounding prevention:**
90
+ - `confidence` field is REQUIRED on writebacks (high/medium/low)
91
+ - `sources_used` lists exact slugs — traceability
92
+ - Health check flags conflicting analyses on same topic (different confidence)
93
+ - User approval is the quality gate — low-quality answers are not saved
94
+
95
+ ### stats
96
+
97
+ Knowledge base statistics.
98
+
99
+ **Flow:**
100
+ 1. Count files per directory (9 directories)
101
+ 2. Count FTS5 entries and file_hashes entries
102
+ 3. Find most recent ingest (latest file by modified date per directory)
103
+ 4. Count tags frequency (parse all frontmatter, aggregate tags)
104
+ 5. Display summary:
105
+
106
+ ```
107
+ Mindlore Stats
108
+ ─────────────
109
+ Total files: 47 (FTS5: 47 indexed)
110
+ - sources: 18
111
+ - domains: 5
112
+ - analyses: 6
113
+ - insights: 3
114
+ - connections: 2
115
+ - learnings: 4
116
+ - diary: 8
117
+ - decisions: 1
118
+ - raw: 0
119
+
120
+ Top tags: security (12), hooks (8), fts5 (6), testing (5)
121
+ Last ingest: 2026-04-11 (sources/react-hooks.md)
122
+ DB size: 1.2 MB
123
+ ```
124
+
125
+ ### brief
126
+
127
+ Quick context on a topic — token-efficient (~50 tokens output).
128
+
129
+ **Flow:**
130
+ 1. FTS5 search for topic
131
+ 2. If domain page exists → read first 3 lines of body (after frontmatter)
132
+ 3. If no domain → read description field from top FTS5 match
133
+ 4. Return: title + description + "Read full: {path}" pointer
134
+ 5. Do NOT read full file — this mode is for quick "do I need to open this?" decisions
135
+
136
+ **Output format:**
137
+ ```
138
+ [Mindlore Brief: Security]
139
+ SSH hardening, firewall rules, audit checks. 5 sources, 2 analyses linked.
140
+ → Read full: .mindlore/domains/security.md
141
+ ```
142
+
143
+ ## Rules
144
+
145
+ - All modes respect the SCHEMA.md writeback rules (Section 6: Wiki vs Diary)
146
+ - search and brief are read-only — no writes
147
+ - ask writes only with user approval
148
+ - stats is read-only
149
+ - Token strategy: Read relevant files directly
150
+ - Tags filter: `--tags security` works in search and ask modes
151
+ - Max results: search=5, ask=3-5 (for synthesis), brief=1