@su-record/vibe 2.7.13 → 2.7.15

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 (232) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +134 -126
  3. package/LICENSE +21 -21
  4. package/README.md +449 -449
  5. package/agents/architect-low.md +41 -41
  6. package/agents/architect-medium.md +59 -59
  7. package/agents/architect.md +80 -80
  8. package/agents/build-error-resolver.md +115 -115
  9. package/agents/compounder.md +261 -261
  10. package/agents/diagrammer.md +178 -178
  11. package/agents/docs/api-documenter.md +99 -99
  12. package/agents/docs/changelog-writer.md +93 -93
  13. package/agents/e2e-tester.md +294 -294
  14. package/agents/explorer-low.md +42 -42
  15. package/agents/explorer-medium.md +59 -59
  16. package/agents/explorer.md +48 -48
  17. package/agents/implementer-low.md +43 -43
  18. package/agents/implementer-medium.md +52 -52
  19. package/agents/implementer.md +54 -54
  20. package/agents/junior-mentor.md +141 -141
  21. package/agents/planning/requirements-analyst.md +84 -84
  22. package/agents/planning/ux-advisor.md +83 -83
  23. package/agents/qa/acceptance-tester.md +86 -86
  24. package/agents/qa/edge-case-finder.md +93 -93
  25. package/agents/refactor-cleaner.md +143 -143
  26. package/agents/research/best-practices-agent.md +199 -199
  27. package/agents/research/codebase-patterns-agent.md +157 -157
  28. package/agents/research/framework-docs-agent.md +188 -188
  29. package/agents/research/security-advisory-agent.md +213 -213
  30. package/agents/review/architecture-reviewer.md +107 -107
  31. package/agents/review/complexity-reviewer.md +116 -116
  32. package/agents/review/data-integrity-reviewer.md +88 -88
  33. package/agents/review/git-history-reviewer.md +103 -103
  34. package/agents/review/performance-reviewer.md +86 -86
  35. package/agents/review/python-reviewer.md +150 -150
  36. package/agents/review/rails-reviewer.md +139 -139
  37. package/agents/review/react-reviewer.md +144 -144
  38. package/agents/review/security-reviewer.md +80 -80
  39. package/agents/review/simplicity-reviewer.md +140 -140
  40. package/agents/review/test-coverage-reviewer.md +116 -116
  41. package/agents/review/typescript-reviewer.md +127 -127
  42. package/agents/searcher.md +54 -54
  43. package/agents/simplifier.md +120 -120
  44. package/agents/tester.md +49 -49
  45. package/agents/ui/ui-a11y-auditor.md +93 -93
  46. package/agents/ui/ui-antipattern-detector.md +94 -94
  47. package/agents/ui/ui-dataviz-advisor.md +69 -69
  48. package/agents/ui/ui-design-system-gen.md +57 -57
  49. package/agents/ui/ui-industry-analyzer.md +49 -49
  50. package/agents/ui/ui-layout-architect.md +65 -65
  51. package/agents/ui/ui-stack-implementer.md +68 -68
  52. package/agents/ui/ux-compliance-reviewer.md +81 -81
  53. package/agents/ui-previewer.md +258 -260
  54. package/commands/vibe.analyze.md +11 -13
  55. package/commands/vibe.review.md +43 -1
  56. package/commands/vibe.run.md +2124 -2078
  57. package/commands/vibe.spec.md +9 -4
  58. package/commands/vibe.spec.review.md +569 -565
  59. package/commands/vibe.utils.md +413 -413
  60. package/commands/vibe.verify.md +33 -8
  61. package/dist/cli/collaborator.js +52 -52
  62. package/dist/cli/commands/evolution.js +12 -12
  63. package/dist/cli/commands/info.js +54 -54
  64. package/dist/cli/commands/init.js +5 -5
  65. package/dist/cli/commands/remove.js +14 -14
  66. package/dist/cli/commands/sentinel.js +27 -27
  67. package/dist/cli/commands/skills.js +5 -5
  68. package/dist/cli/commands/slack.js +10 -10
  69. package/dist/cli/commands/telegram.js +12 -12
  70. package/dist/cli/detect.js +32 -32
  71. package/dist/cli/index.js +51 -51
  72. package/dist/cli/llm/claude-commands.js +16 -16
  73. package/dist/cli/llm/config.js +19 -19
  74. package/dist/cli/llm/config.js.map +1 -1
  75. package/dist/cli/llm/gemini-commands.js +16 -16
  76. package/dist/cli/llm/gpt-commands.js +19 -19
  77. package/dist/cli/llm/help.js +21 -21
  78. package/dist/cli/postinstall/cursor-agents.js +32 -32
  79. package/dist/cli/postinstall/cursor-rules.js +83 -83
  80. package/dist/cli/postinstall/cursor-skills.js +743 -743
  81. package/dist/cli/setup/Provisioner.js +42 -42
  82. package/dist/cli/types.d.ts +0 -2
  83. package/dist/cli/types.d.ts.map +1 -1
  84. package/dist/infra/lib/DeepInit.js +24 -24
  85. package/dist/infra/lib/IterationTracker.js +11 -11
  86. package/dist/infra/lib/PythonParser.js +108 -108
  87. package/dist/infra/lib/ReviewRace.js +96 -96
  88. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  89. package/dist/infra/lib/SkillQualityGate.js +9 -9
  90. package/dist/infra/lib/SkillRepository.js +159 -159
  91. package/dist/infra/lib/UltraQA.js +99 -99
  92. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  93. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  94. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  95. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  96. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  97. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  98. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  99. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  100. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  101. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  102. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  103. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  104. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  105. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  106. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  107. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  108. package/dist/infra/lib/gemini/orchestration.js +5 -5
  109. package/dist/infra/lib/gpt/orchestration.js +4 -4
  110. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  111. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  112. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  113. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  114. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  115. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  116. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  117. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  118. package/dist/infra/orchestrator/AgentManager.js +12 -12
  119. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  120. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  121. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  122. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  123. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  124. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  125. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  126. package/dist/tools/memory/getMemoryGraph.js +12 -12
  127. package/dist/tools/memory/getSessionContext.js +9 -9
  128. package/dist/tools/memory/linkMemories.js +14 -14
  129. package/dist/tools/memory/listMemories.js +4 -4
  130. package/dist/tools/memory/recallMemory.js +4 -4
  131. package/dist/tools/memory/saveMemory.js +4 -4
  132. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  133. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  134. package/dist/tools/semantic/astGrep.test.js +6 -6
  135. package/dist/tools/spec/prdParser.test.js +171 -171
  136. package/dist/tools/spec/specGenerator.js +169 -169
  137. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  138. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  139. package/hooks/gemini-hooks.json +73 -73
  140. package/hooks/hooks.json +137 -137
  141. package/hooks/scripts/code-check.js +77 -70
  142. package/hooks/scripts/context-save.js +212 -212
  143. package/hooks/scripts/hud-status.js +291 -291
  144. package/hooks/scripts/keyword-detector.js +214 -214
  145. package/hooks/scripts/llm-orchestrate.js +475 -475
  146. package/hooks/scripts/post-edit.js +32 -32
  147. package/hooks/scripts/pre-tool-guard.js +125 -125
  148. package/hooks/scripts/prompt-dispatcher.js +185 -185
  149. package/hooks/scripts/sentinel-guard.js +104 -104
  150. package/hooks/scripts/session-start.js +106 -106
  151. package/hooks/scripts/stop-notify.js +209 -209
  152. package/hooks/scripts/utils.js +100 -100
  153. package/languages/csharp-unity.md +515 -515
  154. package/languages/gdscript-godot.md +470 -470
  155. package/languages/ruby-rails.md +489 -489
  156. package/languages/typescript-angular.md +433 -433
  157. package/languages/typescript-astro.md +416 -416
  158. package/languages/typescript-electron.md +406 -406
  159. package/languages/typescript-nestjs.md +524 -524
  160. package/languages/typescript-svelte.md +407 -407
  161. package/languages/typescript-tauri.md +365 -365
  162. package/package.json +121 -121
  163. package/skills/agents-md/SKILL.md +120 -120
  164. package/skills/arch-guard/SKILL.md +180 -180
  165. package/skills/brand-assets/SKILL.md +146 -146
  166. package/skills/capability-loop/SKILL.md +167 -167
  167. package/skills/characterization-test/SKILL.md +206 -206
  168. package/skills/commerce-patterns/SKILL.md +59 -59
  169. package/skills/commit-push-pr/SKILL.md +75 -75
  170. package/skills/context7-usage/SKILL.md +105 -105
  171. package/skills/core-capabilities/SKILL.md +48 -48
  172. package/skills/e2e-commerce/SKILL.md +57 -57
  173. package/skills/exec-plan/SKILL.md +147 -147
  174. package/skills/frontend-design/SKILL.md +73 -73
  175. package/skills/git-worktree/SKILL.md +72 -72
  176. package/skills/handoff/SKILL.md +109 -109
  177. package/skills/parallel-research/SKILL.md +87 -87
  178. package/skills/priority-todos/SKILL.md +63 -63
  179. package/skills/seo-checklist/SKILL.md +57 -57
  180. package/skills/techdebt/SKILL.md +122 -122
  181. package/skills/tool-fallback/SKILL.md +103 -103
  182. package/skills/typescript-advanced-types/SKILL.md +66 -65
  183. package/skills/ui-ux-pro-max/SKILL.md +206 -206
  184. package/skills/vercel-react-best-practices/SKILL.md +59 -59
  185. package/skills/video-production/SKILL.md +51 -51
  186. package/vibe/config.json +29 -29
  187. package/vibe/constitution.md +227 -227
  188. package/vibe/rules/principles/communication-guide.md +98 -98
  189. package/vibe/rules/principles/development-philosophy.md +52 -52
  190. package/vibe/rules/principles/quick-start.md +102 -102
  191. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  192. package/vibe/rules/quality/checklist.md +276 -276
  193. package/vibe/rules/quality/performance.md +236 -236
  194. package/vibe/rules/quality/testing-strategy.md +440 -440
  195. package/vibe/rules/standards/anti-patterns.md +541 -541
  196. package/vibe/rules/standards/code-structure.md +291 -291
  197. package/vibe/rules/standards/complexity-metrics.md +313 -313
  198. package/vibe/rules/standards/git-workflow.md +237 -237
  199. package/vibe/rules/standards/naming-conventions.md +198 -198
  200. package/vibe/rules/standards/security.md +305 -305
  201. package/vibe/rules/writing/document-style.md +74 -74
  202. package/vibe/setup.sh +31 -31
  203. package/vibe/templates/constitution-template.md +252 -252
  204. package/vibe/templates/contract-backend-template.md +526 -526
  205. package/vibe/templates/contract-frontend-template.md +599 -599
  206. package/vibe/templates/feature-template.md +96 -96
  207. package/vibe/templates/spec-template.md +221 -221
  208. package/vibe/ui-ux-data/charts.csv +26 -26
  209. package/vibe/ui-ux-data/colors.csv +97 -97
  210. package/vibe/ui-ux-data/icons.csv +101 -101
  211. package/vibe/ui-ux-data/landing.csv +31 -31
  212. package/vibe/ui-ux-data/products.csv +96 -96
  213. package/vibe/ui-ux-data/react-performance.csv +45 -45
  214. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  215. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  216. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  217. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  218. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  219. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  220. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  221. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  222. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  223. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  224. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  225. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  226. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  227. package/vibe/ui-ux-data/styles.csv +68 -68
  228. package/vibe/ui-ux-data/typography.csv +57 -57
  229. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  230. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  231. package/vibe/ui-ux-data/version.json +31 -31
  232. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -1,212 +1,212 @@
1
- /**
2
- * Notification Hook - 컨텍스트 자동 저장 (80/90/95%) + 세션 요약 + Reflection
3
- * Usage: node context-save.js <urgency>
4
- * urgency: medium | high | critical
5
- */
6
- import { getToolsBaseUrl, getLibBaseUrl, PROJECT_DIR } from './utils.js';
7
-
8
- const BASE_URL = getToolsBaseUrl();
9
- const LIB_URL = getLibBaseUrl();
10
-
11
- const urgency = process.argv[2] || 'medium';
12
- const summaryMap = {
13
- medium: 'Context at 80% - auto checkpoint',
14
- high: 'Context at 90% - save before overflow',
15
- critical: 'Context at 95% - CRITICAL save before session end',
16
- };
17
-
18
- // Debounce: track last reflection level per session to avoid duplicates
19
- let lastReflectionLevel = null;
20
-
21
- async function main() {
22
- try {
23
- const module = await import(`${BASE_URL}memory/index.js`);
24
- const result = await module.autoSaveContext({
25
- urgency,
26
- contextType: 'progress',
27
- summary: summaryMap[urgency] || summaryMap.medium,
28
- projectPath: PROJECT_DIR,
29
- });
30
- const percent = urgency === 'critical' ? '95' : urgency === 'high' ? '90' : '80';
31
- console.log(`[CONTEXT ${percent}%]`, result.content[0].text);
32
-
33
- // Sync TokenBudgetTracker with current context usage
34
- try {
35
- const { TokenBudgetTracker } = await import(`${LIB_URL}TokenBudgetTracker.js`);
36
- const tracker = TokenBudgetTracker.getInstance(PROJECT_DIR);
37
- const numPercent = Number(percent);
38
- if (!isNaN(numPercent)) {
39
- tracker.syncToPercent(numPercent);
40
- }
41
- } catch {
42
- // TokenBudgetTracker sync is non-critical
43
- }
44
- } catch {
45
- // 무시
46
- }
47
-
48
- // Minor Reflection (80% = medium): 컨텍스트 압력 시 자동 성찰
49
- if (urgency === 'medium' && lastReflectionLevel !== 'medium') {
50
- lastReflectionLevel = 'medium';
51
- // Fire-and-forget: 기존 context-save에 영향 없음
52
- setImmediate(() => {
53
- triggerMinorReflection().catch(e => {
54
- process.stderr.write(`[REFLECTION] minor reflection failed: ${e.message}\n`);
55
- });
56
- });
57
- }
58
-
59
- // Critical (95%): 세션 요약 자동 생성 + Major Reflection
60
- if (urgency === 'critical') {
61
- try {
62
- const { SessionSummarizer } = await import(`${LIB_URL}memory/SessionSummarizer.js`);
63
- const { MemoryStorage } = await import(`${LIB_URL}memory/MemoryStorage.js`);
64
-
65
- const storage = new MemoryStorage(PROJECT_DIR);
66
- const summarizer = new SessionSummarizer(storage);
67
-
68
- const sessionId = `session_${Date.now()}`;
69
- const summaryInput = summarizer.generateSummaryFromObservations(sessionId);
70
- if (summaryInput.learned || summaryInput.completed) {
71
- summarizer.saveSummary(summaryInput);
72
- console.log('[SESSION SUMMARY] Auto-generated from observations');
73
- }
74
- } catch {
75
- // 세션 요약 생성 실패해도 무시
76
- }
77
-
78
- // Major Reflection: 세션 종료 시 전체 성찰
79
- if (lastReflectionLevel !== 'critical') {
80
- lastReflectionLevel = 'critical';
81
- setImmediate(() => {
82
- triggerMajorReflection().catch(e => {
83
- process.stderr.write(`[REFLECTION] major reflection failed: ${e.message}\n`);
84
- });
85
- });
86
- }
87
- }
88
- }
89
-
90
- /**
91
- * Minor Reflection: 컨텍스트 압력 시 현재 세션 상태 저장 (< 200ms)
92
- */
93
- async function triggerMinorReflection() {
94
- try {
95
- const { MemoryManager } = await import(`${LIB_URL}MemoryManager.js`);
96
- const mm = MemoryManager.getInstance(PROJECT_DIR);
97
-
98
- // 현재 세션의 활성 컨텍스트 수집
99
- const activeCtx = mm.retrieveActiveContext();
100
- const insights = [];
101
- const decisions = [];
102
- const patterns = [];
103
-
104
- // 활성 Goals에서 insights 추출
105
- if (activeCtx.goals?.length > 0) {
106
- for (const goal of activeCtx.goals.slice(0, 5)) {
107
- insights.push(`Goal: ${goal.title} (${goal.progressPercent || 0}%)`);
108
- }
109
- }
110
-
111
- // 최근 Decisions에서 결정사항 추출
112
- if (activeCtx.decisions?.length > 0) {
113
- for (const decision of activeCtx.decisions.slice(0, 5)) {
114
- decisions.push(`${decision.title}${decision.rationale ? ': ' + decision.rationale : ''}`);
115
- }
116
- }
117
-
118
- // 최근 Constraints에서 패턴 추출
119
- if (activeCtx.constraints?.length > 0) {
120
- for (const constraint of activeCtx.constraints.slice(0, 3)) {
121
- patterns.push(`Constraint: ${constraint.title}`);
122
- }
123
- }
124
-
125
- if (insights.length === 0 && decisions.length === 0 && patterns.length === 0) {
126
- return; // 저장할 내용 없으면 스킵
127
- }
128
-
129
- const store = mm.getReflectionStore();
130
- store.save({
131
- type: 'minor',
132
- trigger: 'context_pressure',
133
- insights,
134
- decisions,
135
- patterns,
136
- score: 0.5,
137
- sessionId: `session_${Date.now()}`,
138
- });
139
- } catch {
140
- // Silent fail — 기존 context-save에 영향 없음
141
- }
142
- }
143
-
144
- /**
145
- * Major Reflection: 세션 종료 시 전체 성찰 (< 500ms)
146
- */
147
- async function triggerMajorReflection() {
148
- try {
149
- const { MemoryManager } = await import(`${LIB_URL}MemoryManager.js`);
150
- const mm = MemoryManager.getInstance(PROJECT_DIR);
151
-
152
- const activeCtx = mm.retrieveActiveContext();
153
- const recentObs = mm.getRecentObservations(10);
154
-
155
- const insights = [];
156
- const decisions = [];
157
- const patterns = [];
158
- const filesContext = [];
159
-
160
- // 완료된 목표
161
- if (activeCtx.goals?.length > 0) {
162
- const completed = activeCtx.goals.filter(g => g.status === 'completed');
163
- const inProgress = activeCtx.goals.filter(g => g.status === 'active' || g.status === 'in_progress');
164
- if (completed.length > 0) {
165
- insights.push(`Completed goals: ${completed.map(g => g.title).join(', ')}`);
166
- }
167
- if (inProgress.length > 0) {
168
- insights.push(`In-progress goals: ${inProgress.map(g => `${g.title} (${g.progressPercent || 0}%)`).join(', ')}`);
169
- }
170
- }
171
-
172
- // 결정사항
173
- if (activeCtx.decisions?.length > 0) {
174
- for (const d of activeCtx.decisions.slice(0, 5)) {
175
- decisions.push(d.title + (d.rationale ? ` — ${d.rationale}` : ''));
176
- }
177
- }
178
-
179
- // 관찰에서 패턴/파일 추출
180
- if (recentObs.length > 0) {
181
- for (const obs of recentObs) {
182
- if (obs.type === 'discovery' || obs.type === 'bugfix') {
183
- patterns.push(`[${obs.type}] ${obs.title}`);
184
- }
185
- if (obs.filesModified?.length > 0) {
186
- filesContext.push(...obs.filesModified);
187
- }
188
- }
189
- }
190
-
191
- // 중복 제거
192
- const uniqueFiles = [...new Set(filesContext)].slice(0, 20);
193
-
194
- const score = Math.min(1.0, 0.5 + (insights.length * 0.1) + (decisions.length * 0.05));
195
-
196
- const store = mm.getReflectionStore();
197
- store.save({
198
- type: 'major',
199
- trigger: 'session_end',
200
- insights,
201
- decisions,
202
- patterns,
203
- filesContext: uniqueFiles,
204
- score,
205
- sessionId: `session_${Date.now()}`,
206
- });
207
- } catch {
208
- // Silent fail
209
- }
210
- }
211
-
212
- main();
1
+ /**
2
+ * Notification Hook - 컨텍스트 자동 저장 (80/90/95%) + 세션 요약 + Reflection
3
+ * Usage: node context-save.js <urgency>
4
+ * urgency: medium | high | critical
5
+ */
6
+ import { getToolsBaseUrl, getLibBaseUrl, PROJECT_DIR } from './utils.js';
7
+
8
+ const BASE_URL = getToolsBaseUrl();
9
+ const LIB_URL = getLibBaseUrl();
10
+
11
+ const urgency = process.argv[2] || 'medium';
12
+ const summaryMap = {
13
+ medium: 'Context at 80% - auto checkpoint',
14
+ high: 'Context at 90% - save before overflow',
15
+ critical: 'Context at 95% - CRITICAL save before session end',
16
+ };
17
+
18
+ // Debounce: track last reflection level per session to avoid duplicates
19
+ let lastReflectionLevel = null;
20
+
21
+ async function main() {
22
+ try {
23
+ const module = await import(`${BASE_URL}memory/index.js`);
24
+ const result = await module.autoSaveContext({
25
+ urgency,
26
+ contextType: 'progress',
27
+ summary: summaryMap[urgency] || summaryMap.medium,
28
+ projectPath: PROJECT_DIR,
29
+ });
30
+ const percent = urgency === 'critical' ? '95' : urgency === 'high' ? '90' : '80';
31
+ console.log(`[CONTEXT ${percent}%]`, result.content[0].text);
32
+
33
+ // Sync TokenBudgetTracker with current context usage
34
+ try {
35
+ const { TokenBudgetTracker } = await import(`${LIB_URL}TokenBudgetTracker.js`);
36
+ const tracker = TokenBudgetTracker.getInstance(PROJECT_DIR);
37
+ const numPercent = Number(percent);
38
+ if (!isNaN(numPercent)) {
39
+ tracker.syncToPercent(numPercent);
40
+ }
41
+ } catch {
42
+ // TokenBudgetTracker sync is non-critical
43
+ }
44
+ } catch {
45
+ // 무시
46
+ }
47
+
48
+ // Minor Reflection (80% = medium): 컨텍스트 압력 시 자동 성찰
49
+ if (urgency === 'medium' && lastReflectionLevel !== 'medium') {
50
+ lastReflectionLevel = 'medium';
51
+ // Fire-and-forget: 기존 context-save에 영향 없음
52
+ setImmediate(() => {
53
+ triggerMinorReflection().catch(e => {
54
+ process.stderr.write(`[REFLECTION] minor reflection failed: ${e.message}\n`);
55
+ });
56
+ });
57
+ }
58
+
59
+ // Critical (95%): 세션 요약 자동 생성 + Major Reflection
60
+ if (urgency === 'critical') {
61
+ try {
62
+ const { SessionSummarizer } = await import(`${LIB_URL}memory/SessionSummarizer.js`);
63
+ const { MemoryStorage } = await import(`${LIB_URL}memory/MemoryStorage.js`);
64
+
65
+ const storage = new MemoryStorage(PROJECT_DIR);
66
+ const summarizer = new SessionSummarizer(storage);
67
+
68
+ const sessionId = `session_${Date.now()}`;
69
+ const summaryInput = summarizer.generateSummaryFromObservations(sessionId);
70
+ if (summaryInput.learned || summaryInput.completed) {
71
+ summarizer.saveSummary(summaryInput);
72
+ console.log('[SESSION SUMMARY] Auto-generated from observations');
73
+ }
74
+ } catch {
75
+ // 세션 요약 생성 실패해도 무시
76
+ }
77
+
78
+ // Major Reflection: 세션 종료 시 전체 성찰
79
+ if (lastReflectionLevel !== 'critical') {
80
+ lastReflectionLevel = 'critical';
81
+ setImmediate(() => {
82
+ triggerMajorReflection().catch(e => {
83
+ process.stderr.write(`[REFLECTION] major reflection failed: ${e.message}\n`);
84
+ });
85
+ });
86
+ }
87
+ }
88
+ }
89
+
90
+ /**
91
+ * Minor Reflection: 컨텍스트 압력 시 현재 세션 상태 저장 (< 200ms)
92
+ */
93
+ async function triggerMinorReflection() {
94
+ try {
95
+ const { MemoryManager } = await import(`${LIB_URL}MemoryManager.js`);
96
+ const mm = MemoryManager.getInstance(PROJECT_DIR);
97
+
98
+ // 현재 세션의 활성 컨텍스트 수집
99
+ const activeCtx = mm.retrieveActiveContext();
100
+ const insights = [];
101
+ const decisions = [];
102
+ const patterns = [];
103
+
104
+ // 활성 Goals에서 insights 추출
105
+ if (activeCtx.goals?.length > 0) {
106
+ for (const goal of activeCtx.goals.slice(0, 5)) {
107
+ insights.push(`Goal: ${goal.title} (${goal.progressPercent || 0}%)`);
108
+ }
109
+ }
110
+
111
+ // 최근 Decisions에서 결정사항 추출
112
+ if (activeCtx.decisions?.length > 0) {
113
+ for (const decision of activeCtx.decisions.slice(0, 5)) {
114
+ decisions.push(`${decision.title}${decision.rationale ? ': ' + decision.rationale : ''}`);
115
+ }
116
+ }
117
+
118
+ // 최근 Constraints에서 패턴 추출
119
+ if (activeCtx.constraints?.length > 0) {
120
+ for (const constraint of activeCtx.constraints.slice(0, 3)) {
121
+ patterns.push(`Constraint: ${constraint.title}`);
122
+ }
123
+ }
124
+
125
+ if (insights.length === 0 && decisions.length === 0 && patterns.length === 0) {
126
+ return; // 저장할 내용 없으면 스킵
127
+ }
128
+
129
+ const store = mm.getReflectionStore();
130
+ store.save({
131
+ type: 'minor',
132
+ trigger: 'context_pressure',
133
+ insights,
134
+ decisions,
135
+ patterns,
136
+ score: 0.5,
137
+ sessionId: `session_${Date.now()}`,
138
+ });
139
+ } catch {
140
+ // Silent fail — 기존 context-save에 영향 없음
141
+ }
142
+ }
143
+
144
+ /**
145
+ * Major Reflection: 세션 종료 시 전체 성찰 (< 500ms)
146
+ */
147
+ async function triggerMajorReflection() {
148
+ try {
149
+ const { MemoryManager } = await import(`${LIB_URL}MemoryManager.js`);
150
+ const mm = MemoryManager.getInstance(PROJECT_DIR);
151
+
152
+ const activeCtx = mm.retrieveActiveContext();
153
+ const recentObs = mm.getRecentObservations(10);
154
+
155
+ const insights = [];
156
+ const decisions = [];
157
+ const patterns = [];
158
+ const filesContext = [];
159
+
160
+ // 완료된 목표
161
+ if (activeCtx.goals?.length > 0) {
162
+ const completed = activeCtx.goals.filter(g => g.status === 'completed');
163
+ const inProgress = activeCtx.goals.filter(g => g.status === 'active' || g.status === 'in_progress');
164
+ if (completed.length > 0) {
165
+ insights.push(`Completed goals: ${completed.map(g => g.title).join(', ')}`);
166
+ }
167
+ if (inProgress.length > 0) {
168
+ insights.push(`In-progress goals: ${inProgress.map(g => `${g.title} (${g.progressPercent || 0}%)`).join(', ')}`);
169
+ }
170
+ }
171
+
172
+ // 결정사항
173
+ if (activeCtx.decisions?.length > 0) {
174
+ for (const d of activeCtx.decisions.slice(0, 5)) {
175
+ decisions.push(d.title + (d.rationale ? ` — ${d.rationale}` : ''));
176
+ }
177
+ }
178
+
179
+ // 관찰에서 패턴/파일 추출
180
+ if (recentObs.length > 0) {
181
+ for (const obs of recentObs) {
182
+ if (obs.type === 'discovery' || obs.type === 'bugfix') {
183
+ patterns.push(`[${obs.type}] ${obs.title}`);
184
+ }
185
+ if (obs.filesModified?.length > 0) {
186
+ filesContext.push(...obs.filesModified);
187
+ }
188
+ }
189
+ }
190
+
191
+ // 중복 제거
192
+ const uniqueFiles = [...new Set(filesContext)].slice(0, 20);
193
+
194
+ const score = Math.min(1.0, 0.5 + (insights.length * 0.1) + (decisions.length * 0.05));
195
+
196
+ const store = mm.getReflectionStore();
197
+ store.save({
198
+ type: 'major',
199
+ trigger: 'session_end',
200
+ insights,
201
+ decisions,
202
+ patterns,
203
+ filesContext: uniqueFiles,
204
+ score,
205
+ sessionId: `session_${Date.now()}`,
206
+ });
207
+ } catch {
208
+ // Silent fail
209
+ }
210
+ }
211
+
212
+ main();