@su-record/vibe 2.6.28 → 2.6.30
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/CLAUDE.md +235 -202
- package/LICENSE +21 -21
- package/README.md +276 -267
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +266 -266
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/tester.md +49 -49
- package/agents/ui-previewer.md +268 -268
- package/commands/vibe.analyze.md +356 -356
- package/commands/vibe.reason.md +329 -329
- package/commands/vibe.review.md +423 -423
- package/commands/vibe.run.md +1423 -1313
- package/commands/vibe.spec.md +1054 -1054
- package/commands/vibe.spec.review.md +412 -412
- package/commands/vibe.trace.md +161 -161
- package/commands/vibe.utils.md +376 -376
- package/commands/vibe.verify.md +375 -375
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/detect.js +32 -32
- package/dist/cli/hud.js +20 -20
- package/dist/cli/index.js +112 -112
- package/dist/cli/llm.js +144 -144
- package/dist/cli/postinstall.js +858 -858
- package/dist/lib/DeepInit.js +24 -24
- package/dist/lib/IterationTracker.js +11 -11
- package/dist/lib/PythonParser.js +108 -108
- package/dist/lib/ReviewRace.js +96 -96
- package/dist/lib/SkillFrontmatter.js +28 -28
- package/dist/lib/SkillQualityGate.js +9 -9
- package/dist/lib/SkillRepository.js +159 -159
- package/dist/lib/UltraQA.js +77 -77
- package/dist/lib/gemini-api.js +5 -5
- package/dist/lib/gpt-api.js +4 -4
- package/dist/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/lib/memory/MemorySearch.js +43 -43
- package/dist/lib/memory/MemoryStorage.js +130 -130
- package/dist/lib/memory/ObservationStore.js +28 -28
- package/dist/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/lib/memory/SessionRAGStore.js +216 -216
- package/dist/lib/memory/SessionSummarizer.js +9 -9
- package/dist/orchestrator/AgentManager.js +12 -12
- package/dist/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/orchestrator/SmartRouter.js +11 -11
- package/dist/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/hooks.json +115 -115
- package/hooks/scripts/code-check.js +70 -70
- package/hooks/scripts/code-review.js +22 -22
- package/hooks/scripts/complexity.js +22 -22
- package/hooks/scripts/compound.js +23 -23
- package/hooks/scripts/context-save.js +53 -53
- package/hooks/scripts/gemini-ui-gen.js +281 -281
- package/hooks/scripts/generate-brand-assets.js +474 -474
- package/hooks/scripts/hud-multiline.js +262 -262
- package/hooks/scripts/hud-status.js +291 -291
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +328 -171
- package/hooks/scripts/post-edit.js +97 -97
- package/hooks/scripts/post-tool-verify.js +210 -210
- package/hooks/scripts/pre-tool-guard.js +125 -125
- package/hooks/scripts/prompt-dispatcher.js +161 -161
- package/hooks/scripts/recall.js +22 -22
- package/hooks/scripts/session-start.js +30 -30
- package/hooks/scripts/skill-injector.js +191 -191
- package/hooks/scripts/utils.js +97 -97
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +84 -84
- package/skills/brand-assets.md +141 -141
- package/skills/commerce-patterns.md +361 -361
- package/skills/context7-usage.md +102 -102
- package/skills/e2e-commerce.md +304 -304
- package/skills/frontend-design.md +92 -92
- package/skills/git-worktree.md +181 -181
- package/skills/parallel-research.md +77 -77
- package/skills/priority-todos.md +239 -239
- package/skills/seo-checklist.md +244 -244
- package/skills/tool-fallback.md +190 -190
- package/skills/vibe-capabilities.md +161 -161
- package/vibe/constitution.md +227 -227
- package/vibe/rules/core/communication-guide.md +98 -98
- package/vibe/rules/core/development-philosophy.md +52 -52
- package/vibe/rules/core/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/setup.sh +31 -31
- package/vibe/templates/constitution-template.md +252 -252
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/spec-template.md +221 -221
- package/dist/cli/mcp.d.ts +0 -49
- package/dist/cli/mcp.d.ts.map +0 -1
- package/dist/cli/mcp.js +0 -169
- package/dist/cli/mcp.js.map +0 -1
- package/dist/lib/gemini-mcp.d.ts +0 -10
- package/dist/lib/gemini-mcp.d.ts.map +0 -1
- package/dist/lib/gemini-mcp.js +0 -353
- package/dist/lib/gemini-mcp.js.map +0 -1
- package/dist/lib/gpt-mcp.d.ts +0 -10
- package/dist/lib/gpt-mcp.d.ts.map +0 -1
- package/dist/lib/gpt-mcp.js +0 -352
- package/dist/lib/gpt-mcp.js.map +0 -1
- package/dist/tools/analytics/getUsageAnalytics.d.ts +0 -10
- package/dist/tools/analytics/getUsageAnalytics.d.ts.map +0 -1
- package/dist/tools/analytics/getUsageAnalytics.js +0 -246
- package/dist/tools/analytics/getUsageAnalytics.js.map +0 -1
- package/dist/tools/analytics/index.d.ts +0 -5
- package/dist/tools/analytics/index.d.ts.map +0 -1
- package/dist/tools/analytics/index.js +0 -5
- package/dist/tools/analytics/index.js.map +0 -1
- package/dist/tools/convention/getCodingGuide.d.ts +0 -7
- package/dist/tools/convention/getCodingGuide.d.ts.map +0 -1
- package/dist/tools/convention/getCodingGuide.js +0 -69
- package/dist/tools/convention/getCodingGuide.js.map +0 -1
- package/dist/tools/planning/analyzeRequirements.d.ts +0 -9
- package/dist/tools/planning/analyzeRequirements.d.ts.map +0 -1
- package/dist/tools/planning/analyzeRequirements.js +0 -171
- package/dist/tools/planning/analyzeRequirements.js.map +0 -1
- package/dist/tools/planning/createUserStories.d.ts +0 -9
- package/dist/tools/planning/createUserStories.d.ts.map +0 -1
- package/dist/tools/planning/createUserStories.js +0 -124
- package/dist/tools/planning/createUserStories.js.map +0 -1
- package/dist/tools/planning/featureRoadmap.d.ts +0 -10
- package/dist/tools/planning/featureRoadmap.d.ts.map +0 -1
- package/dist/tools/planning/featureRoadmap.js +0 -207
- package/dist/tools/planning/featureRoadmap.js.map +0 -1
- package/dist/tools/planning/generatePrd.d.ts +0 -11
- package/dist/tools/planning/generatePrd.d.ts.map +0 -1
- package/dist/tools/planning/generatePrd.js +0 -161
- package/dist/tools/planning/generatePrd.js.map +0 -1
- package/dist/tools/planning/index.d.ts +0 -8
- package/dist/tools/planning/index.d.ts.map +0 -1
- package/dist/tools/planning/index.js +0 -8
- package/dist/tools/planning/index.js.map +0 -1
- package/dist/tools/prompt/analyzePrompt.d.ts +0 -7
- package/dist/tools/prompt/analyzePrompt.d.ts.map +0 -1
- package/dist/tools/prompt/analyzePrompt.js +0 -150
- package/dist/tools/prompt/analyzePrompt.js.map +0 -1
- package/dist/tools/prompt/enhancePrompt.d.ts +0 -8
- package/dist/tools/prompt/enhancePrompt.d.ts.map +0 -1
- package/dist/tools/prompt/enhancePrompt.js +0 -110
- package/dist/tools/prompt/enhancePrompt.js.map +0 -1
- package/dist/tools/prompt/enhancePromptGemini.d.ts +0 -8
- package/dist/tools/prompt/enhancePromptGemini.d.ts.map +0 -1
- package/dist/tools/prompt/enhancePromptGemini.js +0 -332
- package/dist/tools/prompt/enhancePromptGemini.js.map +0 -1
- package/dist/tools/prompt/index.d.ts +0 -7
- package/dist/tools/prompt/index.d.ts.map +0 -1
- package/dist/tools/prompt/index.js +0 -7
- package/dist/tools/prompt/index.js.map +0 -1
- package/dist/tools/reasoning/applyReasoningFramework.d.ts +0 -8
- package/dist/tools/reasoning/applyReasoningFramework.d.ts.map +0 -1
- package/dist/tools/reasoning/applyReasoningFramework.js +0 -266
- package/dist/tools/reasoning/applyReasoningFramework.js.map +0 -1
- package/dist/tools/reasoning/index.d.ts +0 -5
- package/dist/tools/reasoning/index.d.ts.map +0 -1
- package/dist/tools/reasoning/index.js +0 -5
- package/dist/tools/reasoning/index.js.map +0 -1
- package/dist/tools/thinking/analyzeProblem.d.ts +0 -7
- package/dist/tools/thinking/analyzeProblem.d.ts.map +0 -1
- package/dist/tools/thinking/analyzeProblem.js +0 -55
- package/dist/tools/thinking/analyzeProblem.js.map +0 -1
- package/dist/tools/thinking/breakDownProblem.d.ts +0 -8
- package/dist/tools/thinking/breakDownProblem.d.ts.map +0 -1
- package/dist/tools/thinking/breakDownProblem.js +0 -145
- package/dist/tools/thinking/breakDownProblem.js.map +0 -1
- package/dist/tools/thinking/createThinkingChain.d.ts +0 -7
- package/dist/tools/thinking/createThinkingChain.d.ts.map +0 -1
- package/dist/tools/thinking/createThinkingChain.js +0 -44
- package/dist/tools/thinking/createThinkingChain.js.map +0 -1
- package/dist/tools/thinking/formatAsPlan.d.ts +0 -9
- package/dist/tools/thinking/formatAsPlan.d.ts.map +0 -1
- package/dist/tools/thinking/formatAsPlan.js +0 -78
- package/dist/tools/thinking/formatAsPlan.js.map +0 -1
- package/dist/tools/thinking/index.d.ts +0 -10
- package/dist/tools/thinking/index.d.ts.map +0 -1
- package/dist/tools/thinking/index.js +0 -10
- package/dist/tools/thinking/index.js.map +0 -1
- package/dist/tools/thinking/stepByStepAnalysis.d.ts +0 -8
- package/dist/tools/thinking/stepByStepAnalysis.d.ts.map +0 -1
- package/dist/tools/thinking/stepByStepAnalysis.js +0 -63
- package/dist/tools/thinking/stepByStepAnalysis.js.map +0 -1
- package/dist/tools/thinking/thinkAloudProcess.d.ts +0 -8
- package/dist/tools/thinking/thinkAloudProcess.d.ts.map +0 -1
- package/dist/tools/thinking/thinkAloudProcess.js +0 -80
- package/dist/tools/thinking/thinkAloudProcess.js.map +0 -1
package/hooks/hooks.json
CHANGED
|
@@ -1,115 +1,115 @@
|
|
|
1
|
-
{
|
|
2
|
-
"permissions": {
|
|
3
|
-
"allow": [],
|
|
4
|
-
"deny": [],
|
|
5
|
-
"ask": []
|
|
6
|
-
},
|
|
7
|
-
"hooks": {
|
|
8
|
-
"SessionStart": [
|
|
9
|
-
{
|
|
10
|
-
"hooks": [
|
|
11
|
-
{
|
|
12
|
-
"type": "command",
|
|
13
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/session-start.js"
|
|
14
|
-
}
|
|
15
|
-
]
|
|
16
|
-
}
|
|
17
|
-
],
|
|
18
|
-
"PreToolUse": [
|
|
19
|
-
{
|
|
20
|
-
"matcher": "Bash",
|
|
21
|
-
"hooks": [
|
|
22
|
-
{
|
|
23
|
-
"type": "command",
|
|
24
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Bash"
|
|
25
|
-
}
|
|
26
|
-
]
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
"matcher": "Edit",
|
|
30
|
-
"hooks": [
|
|
31
|
-
{
|
|
32
|
-
"type": "command",
|
|
33
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Edit"
|
|
34
|
-
}
|
|
35
|
-
]
|
|
36
|
-
},
|
|
37
|
-
{
|
|
38
|
-
"matcher": "Write",
|
|
39
|
-
"hooks": [
|
|
40
|
-
{
|
|
41
|
-
"type": "command",
|
|
42
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Write"
|
|
43
|
-
}
|
|
44
|
-
]
|
|
45
|
-
}
|
|
46
|
-
],
|
|
47
|
-
"PostToolUse": [
|
|
48
|
-
{
|
|
49
|
-
"matcher": "Write|Edit",
|
|
50
|
-
"hooks": [
|
|
51
|
-
{
|
|
52
|
-
"type": "command",
|
|
53
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/code-check.js"
|
|
54
|
-
}
|
|
55
|
-
]
|
|
56
|
-
},
|
|
57
|
-
{
|
|
58
|
-
"matcher": "Edit",
|
|
59
|
-
"hooks": [
|
|
60
|
-
{
|
|
61
|
-
"type": "command",
|
|
62
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/post-edit.js"
|
|
63
|
-
}
|
|
64
|
-
]
|
|
65
|
-
}
|
|
66
|
-
],
|
|
67
|
-
"UserPromptSubmit": [
|
|
68
|
-
{
|
|
69
|
-
"hooks": [
|
|
70
|
-
{
|
|
71
|
-
"type": "command",
|
|
72
|
-
"command": "echo '[INTERRUPT RULE] If this message follows a user interrupt (Ctrl+C/Escape), the previous task is CANCELLED. Do NOT resume interrupted work. Respond ONLY to this new message.'"
|
|
73
|
-
}
|
|
74
|
-
]
|
|
75
|
-
},
|
|
76
|
-
{
|
|
77
|
-
"hooks": [
|
|
78
|
-
{
|
|
79
|
-
"type": "command",
|
|
80
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/prompt-dispatcher.js"
|
|
81
|
-
}
|
|
82
|
-
]
|
|
83
|
-
}
|
|
84
|
-
],
|
|
85
|
-
"Notification": [
|
|
86
|
-
{
|
|
87
|
-
"matcher": "context_window_80",
|
|
88
|
-
"hooks": [
|
|
89
|
-
{
|
|
90
|
-
"type": "command",
|
|
91
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js medium"
|
|
92
|
-
}
|
|
93
|
-
]
|
|
94
|
-
},
|
|
95
|
-
{
|
|
96
|
-
"matcher": "context_window_90",
|
|
97
|
-
"hooks": [
|
|
98
|
-
{
|
|
99
|
-
"type": "command",
|
|
100
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js high"
|
|
101
|
-
}
|
|
102
|
-
]
|
|
103
|
-
},
|
|
104
|
-
{
|
|
105
|
-
"matcher": "context_window_95",
|
|
106
|
-
"hooks": [
|
|
107
|
-
{
|
|
108
|
-
"type": "command",
|
|
109
|
-
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js critical"
|
|
110
|
-
}
|
|
111
|
-
]
|
|
112
|
-
}
|
|
113
|
-
]
|
|
114
|
-
}
|
|
115
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"permissions": {
|
|
3
|
+
"allow": [],
|
|
4
|
+
"deny": [],
|
|
5
|
+
"ask": []
|
|
6
|
+
},
|
|
7
|
+
"hooks": {
|
|
8
|
+
"SessionStart": [
|
|
9
|
+
{
|
|
10
|
+
"hooks": [
|
|
11
|
+
{
|
|
12
|
+
"type": "command",
|
|
13
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/session-start.js"
|
|
14
|
+
}
|
|
15
|
+
]
|
|
16
|
+
}
|
|
17
|
+
],
|
|
18
|
+
"PreToolUse": [
|
|
19
|
+
{
|
|
20
|
+
"matcher": "Bash",
|
|
21
|
+
"hooks": [
|
|
22
|
+
{
|
|
23
|
+
"type": "command",
|
|
24
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Bash"
|
|
25
|
+
}
|
|
26
|
+
]
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
"matcher": "Edit",
|
|
30
|
+
"hooks": [
|
|
31
|
+
{
|
|
32
|
+
"type": "command",
|
|
33
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Edit"
|
|
34
|
+
}
|
|
35
|
+
]
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
"matcher": "Write",
|
|
39
|
+
"hooks": [
|
|
40
|
+
{
|
|
41
|
+
"type": "command",
|
|
42
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/pre-tool-guard.js Write"
|
|
43
|
+
}
|
|
44
|
+
]
|
|
45
|
+
}
|
|
46
|
+
],
|
|
47
|
+
"PostToolUse": [
|
|
48
|
+
{
|
|
49
|
+
"matcher": "Write|Edit",
|
|
50
|
+
"hooks": [
|
|
51
|
+
{
|
|
52
|
+
"type": "command",
|
|
53
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/code-check.js"
|
|
54
|
+
}
|
|
55
|
+
]
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
"matcher": "Edit",
|
|
59
|
+
"hooks": [
|
|
60
|
+
{
|
|
61
|
+
"type": "command",
|
|
62
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/post-edit.js"
|
|
63
|
+
}
|
|
64
|
+
]
|
|
65
|
+
}
|
|
66
|
+
],
|
|
67
|
+
"UserPromptSubmit": [
|
|
68
|
+
{
|
|
69
|
+
"hooks": [
|
|
70
|
+
{
|
|
71
|
+
"type": "command",
|
|
72
|
+
"command": "echo '[INTERRUPT RULE] If this message follows a user interrupt (Ctrl+C/Escape), the previous task is CANCELLED. Do NOT resume interrupted work. Respond ONLY to this new message.'"
|
|
73
|
+
}
|
|
74
|
+
]
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
"hooks": [
|
|
78
|
+
{
|
|
79
|
+
"type": "command",
|
|
80
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/prompt-dispatcher.js"
|
|
81
|
+
}
|
|
82
|
+
]
|
|
83
|
+
}
|
|
84
|
+
],
|
|
85
|
+
"Notification": [
|
|
86
|
+
{
|
|
87
|
+
"matcher": "context_window_80",
|
|
88
|
+
"hooks": [
|
|
89
|
+
{
|
|
90
|
+
"type": "command",
|
|
91
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js medium"
|
|
92
|
+
}
|
|
93
|
+
]
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
"matcher": "context_window_90",
|
|
97
|
+
"hooks": [
|
|
98
|
+
{
|
|
99
|
+
"type": "command",
|
|
100
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js high"
|
|
101
|
+
}
|
|
102
|
+
]
|
|
103
|
+
},
|
|
104
|
+
{
|
|
105
|
+
"matcher": "context_window_95",
|
|
106
|
+
"hooks": [
|
|
107
|
+
{
|
|
108
|
+
"type": "command",
|
|
109
|
+
"command": "node {{VIBE_PATH}}/hooks/scripts/context-save.js critical"
|
|
110
|
+
}
|
|
111
|
+
]
|
|
112
|
+
}
|
|
113
|
+
]
|
|
114
|
+
}
|
|
115
|
+
}
|
|
@@ -1,70 +1,70 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* PostToolUse Hook - Write/Edit 후 코드 품질 검사 + 관찰 자동 캡처
|
|
3
|
-
*/
|
|
4
|
-
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
-
|
|
6
|
-
const BASE_URL = getToolsBaseUrl();
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* stdin에서 hook input JSON을 읽어 파일 경로 추출
|
|
10
|
-
*/
|
|
11
|
-
function getModifiedFiles() {
|
|
12
|
-
try {
|
|
13
|
-
const input = process.env.HOOK_INPUT;
|
|
14
|
-
if (input) {
|
|
15
|
-
const parsed = JSON.parse(input);
|
|
16
|
-
const filePath = parsed.tool_input?.file_path || parsed.tool_input?.path;
|
|
17
|
-
return filePath ? [filePath] : [];
|
|
18
|
-
}
|
|
19
|
-
} catch {
|
|
20
|
-
// ignore
|
|
21
|
-
}
|
|
22
|
-
return [];
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* 파일 확장자/경로로 관찰 타입 분류
|
|
27
|
-
*/
|
|
28
|
-
function classifyObservation(files) {
|
|
29
|
-
const hasTest = files.some(f => /\.(test|spec)\.[jt]sx?$/.test(f) || /\/__tests__\//.test(f));
|
|
30
|
-
const hasConfig = files.some(f => /\.(json|ya?ml|toml|env|config)/.test(f));
|
|
31
|
-
|
|
32
|
-
if (hasTest) return { type: 'feature', title: 'Test file updated' };
|
|
33
|
-
if (hasConfig) return { type: 'refactor', title: 'Configuration updated' };
|
|
34
|
-
return { type: 'feature', title: 'Code modified' };
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
async function main() {
|
|
38
|
-
// 1. 코드 품질 검사 (기존)
|
|
39
|
-
try {
|
|
40
|
-
const module = await import(`${BASE_URL}convention/index.js`);
|
|
41
|
-
const result = await module.validateCodeQuality({
|
|
42
|
-
targetPath: '.',
|
|
43
|
-
projectPath: PROJECT_DIR,
|
|
44
|
-
});
|
|
45
|
-
const lines = result.content[0].text.split('\n').slice(0, 3).join(' | ');
|
|
46
|
-
console.log('[CODE CHECK]', lines);
|
|
47
|
-
} catch {
|
|
48
|
-
console.log('[AUTO-CONTINUE] Code written. Continue.');
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// 2. 관찰 자동 캡처
|
|
52
|
-
try {
|
|
53
|
-
const files = getModifiedFiles();
|
|
54
|
-
if (files.length === 0) return;
|
|
55
|
-
|
|
56
|
-
const memModule = await import(`${BASE_URL}memory/index.js`);
|
|
57
|
-
const { type, title } = classifyObservation(files);
|
|
58
|
-
|
|
59
|
-
await memModule.addObservation({
|
|
60
|
-
type,
|
|
61
|
-
title: `${title}: ${files.map(f => f.split(/[\\/]/).pop()).join(', ')}`,
|
|
62
|
-
filesModified: files,
|
|
63
|
-
projectPath: PROJECT_DIR,
|
|
64
|
-
});
|
|
65
|
-
} catch {
|
|
66
|
-
// 관찰 캡처 실패해도 무시 (non-critical)
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
main();
|
|
1
|
+
/**
|
|
2
|
+
* PostToolUse Hook - Write/Edit 후 코드 품질 검사 + 관찰 자동 캡처
|
|
3
|
+
*/
|
|
4
|
+
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
+
|
|
6
|
+
const BASE_URL = getToolsBaseUrl();
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* stdin에서 hook input JSON을 읽어 파일 경로 추출
|
|
10
|
+
*/
|
|
11
|
+
function getModifiedFiles() {
|
|
12
|
+
try {
|
|
13
|
+
const input = process.env.HOOK_INPUT;
|
|
14
|
+
if (input) {
|
|
15
|
+
const parsed = JSON.parse(input);
|
|
16
|
+
const filePath = parsed.tool_input?.file_path || parsed.tool_input?.path;
|
|
17
|
+
return filePath ? [filePath] : [];
|
|
18
|
+
}
|
|
19
|
+
} catch {
|
|
20
|
+
// ignore
|
|
21
|
+
}
|
|
22
|
+
return [];
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* 파일 확장자/경로로 관찰 타입 분류
|
|
27
|
+
*/
|
|
28
|
+
function classifyObservation(files) {
|
|
29
|
+
const hasTest = files.some(f => /\.(test|spec)\.[jt]sx?$/.test(f) || /\/__tests__\//.test(f));
|
|
30
|
+
const hasConfig = files.some(f => /\.(json|ya?ml|toml|env|config)/.test(f));
|
|
31
|
+
|
|
32
|
+
if (hasTest) return { type: 'feature', title: 'Test file updated' };
|
|
33
|
+
if (hasConfig) return { type: 'refactor', title: 'Configuration updated' };
|
|
34
|
+
return { type: 'feature', title: 'Code modified' };
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
async function main() {
|
|
38
|
+
// 1. 코드 품질 검사 (기존)
|
|
39
|
+
try {
|
|
40
|
+
const module = await import(`${BASE_URL}convention/index.js`);
|
|
41
|
+
const result = await module.validateCodeQuality({
|
|
42
|
+
targetPath: '.',
|
|
43
|
+
projectPath: PROJECT_DIR,
|
|
44
|
+
});
|
|
45
|
+
const lines = result.content[0].text.split('\n').slice(0, 3).join(' | ');
|
|
46
|
+
console.log('[CODE CHECK]', lines);
|
|
47
|
+
} catch {
|
|
48
|
+
console.log('[AUTO-CONTINUE] Code written. Continue.');
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// 2. 관찰 자동 캡처
|
|
52
|
+
try {
|
|
53
|
+
const files = getModifiedFiles();
|
|
54
|
+
if (files.length === 0) return;
|
|
55
|
+
|
|
56
|
+
const memModule = await import(`${BASE_URL}memory/index.js`);
|
|
57
|
+
const { type, title } = classifyObservation(files);
|
|
58
|
+
|
|
59
|
+
await memModule.addObservation({
|
|
60
|
+
type,
|
|
61
|
+
title: `${title}: ${files.map(f => f.split(/[\\/]/).pop()).join(', ')}`,
|
|
62
|
+
filesModified: files,
|
|
63
|
+
projectPath: PROJECT_DIR,
|
|
64
|
+
});
|
|
65
|
+
} catch {
|
|
66
|
+
// 관찰 캡처 실패해도 무시 (non-critical)
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
main();
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* UserPromptSubmit Hook - 코드 리뷰 요청 시 품질 검사
|
|
3
|
-
*/
|
|
4
|
-
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
-
|
|
6
|
-
const BASE_URL = getToolsBaseUrl();
|
|
7
|
-
|
|
8
|
-
async function main() {
|
|
9
|
-
try {
|
|
10
|
-
const module = await import(`${BASE_URL}convention/index.js`);
|
|
11
|
-
const result = await module.validateCodeQuality({
|
|
12
|
-
targetPath: '.',
|
|
13
|
-
projectPath: PROJECT_DIR,
|
|
14
|
-
});
|
|
15
|
-
const lines = result.content[0].text.split('\n').slice(0, 5).join(' | ');
|
|
16
|
-
console.log('[CODE REVIEW]', lines);
|
|
17
|
-
} catch (e) {
|
|
18
|
-
console.log('[CODE REVIEW] Error:', e.message);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
main();
|
|
1
|
+
/**
|
|
2
|
+
* UserPromptSubmit Hook - 코드 리뷰 요청 시 품질 검사
|
|
3
|
+
*/
|
|
4
|
+
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
+
|
|
6
|
+
const BASE_URL = getToolsBaseUrl();
|
|
7
|
+
|
|
8
|
+
async function main() {
|
|
9
|
+
try {
|
|
10
|
+
const module = await import(`${BASE_URL}convention/index.js`);
|
|
11
|
+
const result = await module.validateCodeQuality({
|
|
12
|
+
targetPath: '.',
|
|
13
|
+
projectPath: PROJECT_DIR,
|
|
14
|
+
});
|
|
15
|
+
const lines = result.content[0].text.split('\n').slice(0, 5).join(' | ');
|
|
16
|
+
console.log('[CODE REVIEW]', lines);
|
|
17
|
+
} catch (e) {
|
|
18
|
+
console.log('[CODE REVIEW] Error:', e.message);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
main();
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* UserPromptSubmit Hook - 복잡도 분석
|
|
3
|
-
*/
|
|
4
|
-
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
-
|
|
6
|
-
const BASE_URL = getToolsBaseUrl();
|
|
7
|
-
|
|
8
|
-
async function main() {
|
|
9
|
-
try {
|
|
10
|
-
const module = await import(`${BASE_URL}convention/index.js`);
|
|
11
|
-
const result = await module.analyzeComplexity({
|
|
12
|
-
targetPath: '.',
|
|
13
|
-
projectPath: PROJECT_DIR,
|
|
14
|
-
});
|
|
15
|
-
const lines = result.content[0].text.split('\n').slice(0, 5).join(' | ');
|
|
16
|
-
console.log('[COMPLEXITY]', lines);
|
|
17
|
-
} catch (e) {
|
|
18
|
-
console.log('[COMPLEXITY] Error:', e.message);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
main();
|
|
1
|
+
/**
|
|
2
|
+
* UserPromptSubmit Hook - 복잡도 분석
|
|
3
|
+
*/
|
|
4
|
+
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
+
|
|
6
|
+
const BASE_URL = getToolsBaseUrl();
|
|
7
|
+
|
|
8
|
+
async function main() {
|
|
9
|
+
try {
|
|
10
|
+
const module = await import(`${BASE_URL}convention/index.js`);
|
|
11
|
+
const result = await module.analyzeComplexity({
|
|
12
|
+
targetPath: '.',
|
|
13
|
+
projectPath: PROJECT_DIR,
|
|
14
|
+
});
|
|
15
|
+
const lines = result.content[0].text.split('\n').slice(0, 5).join(' | ');
|
|
16
|
+
console.log('[COMPLEXITY]', lines);
|
|
17
|
+
} catch (e) {
|
|
18
|
+
console.log('[COMPLEXITY] Error:', e.message);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
main();
|
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* UserPromptSubmit Hook - 버그 해결/PR 머지 시 솔루션 저장
|
|
3
|
-
*/
|
|
4
|
-
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
-
|
|
6
|
-
const BASE_URL = getToolsBaseUrl();
|
|
7
|
-
|
|
8
|
-
async function main() {
|
|
9
|
-
try {
|
|
10
|
-
const module = await import(`${BASE_URL}memory/index.js`);
|
|
11
|
-
const result = await module.saveMemory({
|
|
12
|
-
key: `solution-${Date.now()}`,
|
|
13
|
-
value: `Solution documented at ${new Date().toISOString()}`,
|
|
14
|
-
category: 'solution',
|
|
15
|
-
projectPath: PROJECT_DIR,
|
|
16
|
-
});
|
|
17
|
-
console.log('[COMPOUND]', result.content[0].text);
|
|
18
|
-
} catch (e) {
|
|
19
|
-
console.log('[COMPOUND] ✗ Error:', e.message);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
main();
|
|
1
|
+
/**
|
|
2
|
+
* UserPromptSubmit Hook - 버그 해결/PR 머지 시 솔루션 저장
|
|
3
|
+
*/
|
|
4
|
+
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
5
|
+
|
|
6
|
+
const BASE_URL = getToolsBaseUrl();
|
|
7
|
+
|
|
8
|
+
async function main() {
|
|
9
|
+
try {
|
|
10
|
+
const module = await import(`${BASE_URL}memory/index.js`);
|
|
11
|
+
const result = await module.saveMemory({
|
|
12
|
+
key: `solution-${Date.now()}`,
|
|
13
|
+
value: `Solution documented at ${new Date().toISOString()}`,
|
|
14
|
+
category: 'solution',
|
|
15
|
+
projectPath: PROJECT_DIR,
|
|
16
|
+
});
|
|
17
|
+
console.log('[COMPOUND]', result.content[0].text);
|
|
18
|
+
} catch (e) {
|
|
19
|
+
console.log('[COMPOUND] ✗ Error:', e.message);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
main();
|
|
@@ -1,53 +1,53 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Notification Hook - 컨텍스트 자동 저장 (80/90/95%) + 세션 요약
|
|
3
|
-
* Usage: node context-save.js <urgency>
|
|
4
|
-
* urgency: medium | high | critical
|
|
5
|
-
*/
|
|
6
|
-
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
7
|
-
|
|
8
|
-
const BASE_URL = getToolsBaseUrl();
|
|
9
|
-
|
|
10
|
-
const urgency = process.argv[2] || 'medium';
|
|
11
|
-
const summaryMap = {
|
|
12
|
-
medium: 'Context at 80% - auto checkpoint',
|
|
13
|
-
high: 'Context at 90% - save before overflow',
|
|
14
|
-
critical: 'Context at 95% - CRITICAL save before session end',
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
async function main() {
|
|
18
|
-
try {
|
|
19
|
-
const module = await import(`${BASE_URL}memory/index.js`);
|
|
20
|
-
const result = await module.autoSaveContext({
|
|
21
|
-
urgency,
|
|
22
|
-
contextType: 'progress',
|
|
23
|
-
summary: summaryMap[urgency] || summaryMap.medium,
|
|
24
|
-
projectPath: PROJECT_DIR,
|
|
25
|
-
});
|
|
26
|
-
const percent = urgency === 'critical' ? '95' : urgency === 'high' ? '90' : '80';
|
|
27
|
-
console.log(`[CONTEXT ${percent}%]`, result.content[0].text);
|
|
28
|
-
} catch {
|
|
29
|
-
// 무시
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// Critical (95%): 세션 요약 자동 생성
|
|
33
|
-
if (urgency === 'critical') {
|
|
34
|
-
try {
|
|
35
|
-
const { SessionSummarizer } = await import(`${BASE_URL}../lib/memory/SessionSummarizer.js`);
|
|
36
|
-
const { MemoryStorage } = await import(`${BASE_URL}../lib/memory/MemoryStorage.js`);
|
|
37
|
-
|
|
38
|
-
const storage = new MemoryStorage(PROJECT_DIR);
|
|
39
|
-
const summarizer = new SessionSummarizer(storage);
|
|
40
|
-
|
|
41
|
-
const sessionId = `session_${Date.now()}`;
|
|
42
|
-
const summaryInput = summarizer.generateSummaryFromObservations(sessionId);
|
|
43
|
-
if (summaryInput.learned || summaryInput.completed) {
|
|
44
|
-
summarizer.saveSummary(summaryInput);
|
|
45
|
-
console.log('[SESSION SUMMARY] Auto-generated from observations');
|
|
46
|
-
}
|
|
47
|
-
} catch {
|
|
48
|
-
// 세션 요약 생성 실패해도 무시
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
main();
|
|
1
|
+
/**
|
|
2
|
+
* Notification Hook - 컨텍스트 자동 저장 (80/90/95%) + 세션 요약
|
|
3
|
+
* Usage: node context-save.js <urgency>
|
|
4
|
+
* urgency: medium | high | critical
|
|
5
|
+
*/
|
|
6
|
+
import { getToolsBaseUrl, PROJECT_DIR } from './utils.js';
|
|
7
|
+
|
|
8
|
+
const BASE_URL = getToolsBaseUrl();
|
|
9
|
+
|
|
10
|
+
const urgency = process.argv[2] || 'medium';
|
|
11
|
+
const summaryMap = {
|
|
12
|
+
medium: 'Context at 80% - auto checkpoint',
|
|
13
|
+
high: 'Context at 90% - save before overflow',
|
|
14
|
+
critical: 'Context at 95% - CRITICAL save before session end',
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
async function main() {
|
|
18
|
+
try {
|
|
19
|
+
const module = await import(`${BASE_URL}memory/index.js`);
|
|
20
|
+
const result = await module.autoSaveContext({
|
|
21
|
+
urgency,
|
|
22
|
+
contextType: 'progress',
|
|
23
|
+
summary: summaryMap[urgency] || summaryMap.medium,
|
|
24
|
+
projectPath: PROJECT_DIR,
|
|
25
|
+
});
|
|
26
|
+
const percent = urgency === 'critical' ? '95' : urgency === 'high' ? '90' : '80';
|
|
27
|
+
console.log(`[CONTEXT ${percent}%]`, result.content[0].text);
|
|
28
|
+
} catch {
|
|
29
|
+
// 무시
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// Critical (95%): 세션 요약 자동 생성
|
|
33
|
+
if (urgency === 'critical') {
|
|
34
|
+
try {
|
|
35
|
+
const { SessionSummarizer } = await import(`${BASE_URL}../lib/memory/SessionSummarizer.js`);
|
|
36
|
+
const { MemoryStorage } = await import(`${BASE_URL}../lib/memory/MemoryStorage.js`);
|
|
37
|
+
|
|
38
|
+
const storage = new MemoryStorage(PROJECT_DIR);
|
|
39
|
+
const summarizer = new SessionSummarizer(storage);
|
|
40
|
+
|
|
41
|
+
const sessionId = `session_${Date.now()}`;
|
|
42
|
+
const summaryInput = summarizer.generateSummaryFromObservations(sessionId);
|
|
43
|
+
if (summaryInput.learned || summaryInput.completed) {
|
|
44
|
+
summarizer.saveSummary(summaryInput);
|
|
45
|
+
console.log('[SESSION SUMMARY] Auto-generated from observations');
|
|
46
|
+
}
|
|
47
|
+
} catch {
|
|
48
|
+
// 세션 요약 생성 실패해도 무시
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
main();
|