@su-record/vibe 2.7.14 → 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 (229) 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 -258
  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 +18 -18
  74. package/dist/cli/llm/gemini-commands.js +16 -16
  75. package/dist/cli/llm/gpt-commands.js +19 -19
  76. package/dist/cli/llm/help.js +21 -21
  77. package/dist/cli/postinstall/cursor-agents.js +32 -32
  78. package/dist/cli/postinstall/cursor-rules.js +83 -83
  79. package/dist/cli/postinstall/cursor-skills.js +743 -743
  80. package/dist/cli/setup/Provisioner.js +42 -42
  81. package/dist/infra/lib/DeepInit.js +24 -24
  82. package/dist/infra/lib/IterationTracker.js +11 -11
  83. package/dist/infra/lib/PythonParser.js +108 -108
  84. package/dist/infra/lib/ReviewRace.js +96 -96
  85. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  86. package/dist/infra/lib/SkillQualityGate.js +9 -9
  87. package/dist/infra/lib/SkillRepository.js +159 -159
  88. package/dist/infra/lib/UltraQA.js +99 -99
  89. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  90. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  91. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  92. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  93. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  94. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  95. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  96. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  97. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  98. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  99. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  100. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  101. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  102. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  103. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  104. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  105. package/dist/infra/lib/gemini/orchestration.js +5 -5
  106. package/dist/infra/lib/gpt/orchestration.js +4 -4
  107. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  108. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  109. package/dist/infra/lib/memory/MemoryStorage.js +181 -181
  110. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  111. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  112. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  113. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  114. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  115. package/dist/infra/orchestrator/AgentManager.js +12 -12
  116. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  117. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  118. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  119. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  120. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  121. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  122. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  123. package/dist/tools/memory/getMemoryGraph.js +12 -12
  124. package/dist/tools/memory/getSessionContext.js +9 -9
  125. package/dist/tools/memory/linkMemories.js +14 -14
  126. package/dist/tools/memory/listMemories.js +4 -4
  127. package/dist/tools/memory/recallMemory.js +4 -4
  128. package/dist/tools/memory/saveMemory.js +4 -4
  129. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  130. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  131. package/dist/tools/semantic/astGrep.test.js +6 -6
  132. package/dist/tools/spec/prdParser.test.js +171 -171
  133. package/dist/tools/spec/specGenerator.js +169 -169
  134. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  135. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  136. package/hooks/gemini-hooks.json +73 -73
  137. package/hooks/hooks.json +137 -137
  138. package/hooks/scripts/code-check.js +77 -70
  139. package/hooks/scripts/context-save.js +212 -212
  140. package/hooks/scripts/hud-status.js +291 -291
  141. package/hooks/scripts/keyword-detector.js +214 -214
  142. package/hooks/scripts/llm-orchestrate.js +475 -475
  143. package/hooks/scripts/post-edit.js +32 -32
  144. package/hooks/scripts/pre-tool-guard.js +125 -125
  145. package/hooks/scripts/prompt-dispatcher.js +185 -185
  146. package/hooks/scripts/sentinel-guard.js +104 -104
  147. package/hooks/scripts/session-start.js +106 -106
  148. package/hooks/scripts/stop-notify.js +209 -209
  149. package/hooks/scripts/utils.js +100 -100
  150. package/languages/csharp-unity.md +515 -515
  151. package/languages/gdscript-godot.md +470 -470
  152. package/languages/ruby-rails.md +489 -489
  153. package/languages/typescript-angular.md +433 -433
  154. package/languages/typescript-astro.md +416 -416
  155. package/languages/typescript-electron.md +406 -406
  156. package/languages/typescript-nestjs.md +524 -524
  157. package/languages/typescript-svelte.md +407 -407
  158. package/languages/typescript-tauri.md +365 -365
  159. package/package.json +121 -121
  160. package/skills/agents-md/SKILL.md +120 -120
  161. package/skills/arch-guard/SKILL.md +180 -180
  162. package/skills/brand-assets/SKILL.md +146 -146
  163. package/skills/capability-loop/SKILL.md +167 -167
  164. package/skills/characterization-test/SKILL.md +206 -206
  165. package/skills/commerce-patterns/SKILL.md +59 -59
  166. package/skills/commit-push-pr/SKILL.md +75 -75
  167. package/skills/context7-usage/SKILL.md +105 -105
  168. package/skills/core-capabilities/SKILL.md +48 -48
  169. package/skills/e2e-commerce/SKILL.md +57 -57
  170. package/skills/exec-plan/SKILL.md +147 -147
  171. package/skills/frontend-design/SKILL.md +73 -73
  172. package/skills/git-worktree/SKILL.md +72 -72
  173. package/skills/handoff/SKILL.md +109 -109
  174. package/skills/parallel-research/SKILL.md +87 -87
  175. package/skills/priority-todos/SKILL.md +63 -63
  176. package/skills/seo-checklist/SKILL.md +57 -57
  177. package/skills/techdebt/SKILL.md +122 -122
  178. package/skills/tool-fallback/SKILL.md +103 -103
  179. package/skills/typescript-advanced-types/SKILL.md +66 -66
  180. package/skills/ui-ux-pro-max/SKILL.md +206 -206
  181. package/skills/vercel-react-best-practices/SKILL.md +59 -59
  182. package/skills/video-production/SKILL.md +51 -51
  183. package/vibe/config.json +29 -29
  184. package/vibe/constitution.md +227 -227
  185. package/vibe/rules/principles/communication-guide.md +98 -98
  186. package/vibe/rules/principles/development-philosophy.md +52 -52
  187. package/vibe/rules/principles/quick-start.md +102 -102
  188. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  189. package/vibe/rules/quality/checklist.md +276 -276
  190. package/vibe/rules/quality/performance.md +236 -236
  191. package/vibe/rules/quality/testing-strategy.md +440 -440
  192. package/vibe/rules/standards/anti-patterns.md +541 -541
  193. package/vibe/rules/standards/code-structure.md +291 -291
  194. package/vibe/rules/standards/complexity-metrics.md +313 -313
  195. package/vibe/rules/standards/git-workflow.md +237 -237
  196. package/vibe/rules/standards/naming-conventions.md +198 -198
  197. package/vibe/rules/standards/security.md +305 -305
  198. package/vibe/rules/writing/document-style.md +74 -74
  199. package/vibe/setup.sh +31 -31
  200. package/vibe/templates/constitution-template.md +252 -252
  201. package/vibe/templates/contract-backend-template.md +526 -526
  202. package/vibe/templates/contract-frontend-template.md +599 -599
  203. package/vibe/templates/feature-template.md +96 -96
  204. package/vibe/templates/spec-template.md +221 -221
  205. package/vibe/ui-ux-data/charts.csv +26 -26
  206. package/vibe/ui-ux-data/colors.csv +97 -97
  207. package/vibe/ui-ux-data/icons.csv +101 -101
  208. package/vibe/ui-ux-data/landing.csv +31 -31
  209. package/vibe/ui-ux-data/products.csv +96 -96
  210. package/vibe/ui-ux-data/react-performance.csv +45 -45
  211. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  212. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  213. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  214. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  215. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  216. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  217. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  218. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  219. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  220. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  221. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  222. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  223. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  224. package/vibe/ui-ux-data/styles.csv +68 -68
  225. package/vibe/ui-ux-data/typography.csv +57 -57
  226. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  227. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  228. package/vibe/ui-ux-data/version.json +31 -31
  229. 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();