@su-record/vibe 2.9.25 → 2.9.32

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 (527) hide show
  1. package/.env.example +37 -37
  2. package/CLAUDE.md +109 -106
  3. package/LICENSE +21 -21
  4. package/README.en.md +220 -220
  5. package/README.md +171 -171
  6. package/agents/architect-low.md +41 -41
  7. package/agents/architect-medium.md +59 -59
  8. package/agents/architect.md +80 -80
  9. package/agents/build-error-resolver.md +115 -115
  10. package/agents/compounder.md +261 -261
  11. package/agents/diagrammer.md +178 -178
  12. package/agents/docs/api-documenter.md +99 -99
  13. package/agents/docs/changelog-writer.md +93 -93
  14. package/agents/e2e-tester.md +294 -294
  15. package/agents/event/event-comms.md +78 -78
  16. package/agents/event/event-content.md +68 -68
  17. package/agents/event/event-image.md +95 -95
  18. package/agents/event/event-ops.md +84 -84
  19. package/agents/event/event-scheduler.md +69 -69
  20. package/agents/event/event-speaker.md +86 -86
  21. package/agents/explorer-low.md +42 -42
  22. package/agents/explorer-medium.md +59 -59
  23. package/agents/explorer.md +48 -48
  24. package/agents/implementer-low.md +43 -43
  25. package/agents/implementer-medium.md +52 -52
  26. package/agents/implementer.md +54 -54
  27. package/agents/junior-mentor.md +141 -141
  28. package/agents/planning/requirements-analyst.md +84 -84
  29. package/agents/planning/ux-advisor.md +83 -83
  30. package/agents/qa/acceptance-tester.md +86 -86
  31. package/agents/qa/edge-case-finder.md +93 -93
  32. package/agents/qa/qa-coordinator.md +131 -131
  33. package/agents/refactor-cleaner.md +143 -143
  34. package/agents/research/best-practices-agent.md +199 -199
  35. package/agents/research/codebase-patterns-agent.md +157 -157
  36. package/agents/research/framework-docs-agent.md +188 -188
  37. package/agents/research/security-advisory-agent.md +213 -213
  38. package/agents/review/architecture-reviewer.md +107 -107
  39. package/agents/review/complexity-reviewer.md +116 -116
  40. package/agents/review/data-integrity-reviewer.md +88 -88
  41. package/agents/review/git-history-reviewer.md +103 -103
  42. package/agents/review/performance-reviewer.md +86 -86
  43. package/agents/review/python-reviewer.md +150 -150
  44. package/agents/review/rails-reviewer.md +139 -139
  45. package/agents/review/react-reviewer.md +144 -144
  46. package/agents/review/security-reviewer.md +80 -80
  47. package/agents/review/simplicity-reviewer.md +140 -140
  48. package/agents/review/test-coverage-reviewer.md +116 -116
  49. package/agents/review/typescript-reviewer.md +127 -127
  50. package/agents/searcher.md +54 -54
  51. package/agents/simplifier.md +120 -120
  52. package/agents/teams/debug-team.md +70 -70
  53. package/agents/teams/dev-team.md +88 -88
  54. package/agents/teams/docs-team.md +80 -80
  55. package/agents/teams/figma/figma-analyst.md +52 -52
  56. package/agents/teams/figma/figma-architect.md +112 -112
  57. package/agents/teams/figma/figma-auditor.md +82 -82
  58. package/agents/teams/figma/figma-builder.md +100 -100
  59. package/agents/teams/figma-team.md +85 -85
  60. package/agents/teams/fullstack-team.md +83 -83
  61. package/agents/teams/lite-team.md +69 -69
  62. package/agents/teams/migration-team.md +78 -78
  63. package/agents/teams/refactor-team.md +94 -94
  64. package/agents/teams/research-team.md +86 -86
  65. package/agents/teams/review-debate-team.md +125 -125
  66. package/agents/teams/security-team.md +81 -81
  67. package/agents/tester.md +49 -49
  68. package/agents/ui/ui-a11y-auditor.md +93 -93
  69. package/agents/ui/ui-antipattern-detector.md +102 -102
  70. package/agents/ui/ui-dataviz-advisor.md +69 -69
  71. package/agents/ui/ui-design-system-gen.md +57 -57
  72. package/agents/ui/ui-industry-analyzer.md +49 -49
  73. package/agents/ui/ui-layout-architect.md +65 -65
  74. package/agents/ui/ui-stack-implementer.md +68 -68
  75. package/agents/ui/ux-compliance-reviewer.md +81 -81
  76. package/agents/ui-previewer.md +258 -258
  77. package/commands/vibe.analyze.md +533 -533
  78. package/commands/vibe.contract.md +105 -105
  79. package/commands/vibe.docs.md +33 -33
  80. package/commands/vibe.event.md +163 -163
  81. package/commands/vibe.figma.md +600 -584
  82. package/commands/vibe.harness.md +177 -177
  83. package/commands/vibe.regress.md +73 -73
  84. package/commands/vibe.review.md +624 -624
  85. package/commands/vibe.run.md +1946 -1940
  86. package/commands/vibe.scaffold.md +195 -195
  87. package/commands/vibe.spec.md +577 -577
  88. package/commands/vibe.test.md +49 -49
  89. package/commands/vibe.trace.md +276 -276
  90. package/commands/vibe.utils.md +413 -413
  91. package/commands/vibe.verify.md +572 -550
  92. package/dist/cli/auth.d.ts +7 -1
  93. package/dist/cli/auth.d.ts.map +1 -1
  94. package/dist/cli/auth.js +51 -11
  95. package/dist/cli/auth.js.map +1 -1
  96. package/dist/cli/collaborator.d.ts +5 -1
  97. package/dist/cli/collaborator.d.ts.map +1 -1
  98. package/dist/cli/collaborator.js +60 -55
  99. package/dist/cli/collaborator.js.map +1 -1
  100. package/dist/cli/commands/codex-proxy.js +15 -15
  101. package/dist/cli/commands/config.js +9 -9
  102. package/dist/cli/commands/evolution.js +12 -12
  103. package/dist/cli/commands/figma.js +20 -20
  104. package/dist/cli/commands/info.d.ts.map +1 -1
  105. package/dist/cli/commands/info.js +47 -63
  106. package/dist/cli/commands/info.js.map +1 -1
  107. package/dist/cli/commands/init.d.ts +13 -5
  108. package/dist/cli/commands/init.d.ts.map +1 -1
  109. package/dist/cli/commands/init.js +71 -35
  110. package/dist/cli/commands/init.js.map +1 -1
  111. package/dist/cli/commands/remove.d.ts.map +1 -1
  112. package/dist/cli/commands/remove.js +35 -22
  113. package/dist/cli/commands/remove.js.map +1 -1
  114. package/dist/cli/commands/sentinel.js +27 -27
  115. package/dist/cli/commands/skills.js +5 -5
  116. package/dist/cli/commands/slack.js +10 -10
  117. package/dist/cli/commands/stats.js +6 -6
  118. package/dist/cli/commands/telegram.js +12 -12
  119. package/dist/cli/commands/update.d.ts.map +1 -1
  120. package/dist/cli/commands/update.js +10 -6
  121. package/dist/cli/commands/update.js.map +1 -1
  122. package/dist/cli/detect.js +32 -32
  123. package/dist/cli/index.js +37 -35
  124. package/dist/cli/index.js.map +1 -1
  125. package/dist/cli/llm/claude-commands.js +16 -16
  126. package/dist/cli/llm/config.js +18 -18
  127. package/dist/cli/llm/gemini-commands.js +16 -16
  128. package/dist/cli/llm/gpt-commands.js +19 -19
  129. package/dist/cli/llm/help.js +21 -21
  130. package/dist/cli/postinstall/cursor-agents.js +32 -32
  131. package/dist/cli/postinstall/cursor-rules.js +83 -83
  132. package/dist/cli/postinstall/cursor-skills.js +743 -743
  133. package/dist/cli/postinstall/global-config.d.ts.map +1 -1
  134. package/dist/cli/postinstall/global-config.js +8 -4
  135. package/dist/cli/postinstall/global-config.js.map +1 -1
  136. package/dist/cli/setup/LegacyMigration.d.ts +14 -0
  137. package/dist/cli/setup/LegacyMigration.d.ts.map +1 -1
  138. package/dist/cli/setup/LegacyMigration.js +61 -0
  139. package/dist/cli/setup/LegacyMigration.js.map +1 -1
  140. package/dist/cli/setup/ProjectSetup.d.ts +9 -3
  141. package/dist/cli/setup/ProjectSetup.d.ts.map +1 -1
  142. package/dist/cli/setup/ProjectSetup.js +60 -36
  143. package/dist/cli/setup/ProjectSetup.js.map +1 -1
  144. package/dist/cli/setup/Provisioner.js +44 -44
  145. package/dist/cli/setup/Provisioner.js.map +1 -1
  146. package/dist/cli/setup.d.ts +1 -1
  147. package/dist/cli/setup.d.ts.map +1 -1
  148. package/dist/cli/setup.js +1 -1
  149. package/dist/cli/setup.js.map +1 -1
  150. package/dist/cli/utils/cli-detector.d.ts +9 -6
  151. package/dist/cli/utils/cli-detector.d.ts.map +1 -1
  152. package/dist/cli/utils/cli-detector.js +127 -8
  153. package/dist/cli/utils/cli-detector.js.map +1 -1
  154. package/dist/infra/lib/DeepInit.js +24 -24
  155. package/dist/infra/lib/IterationTracker.js +11 -11
  156. package/dist/infra/lib/PythonParser.js +108 -108
  157. package/dist/infra/lib/ReviewRace.js +96 -96
  158. package/dist/infra/lib/SkillFrontmatter.js +28 -28
  159. package/dist/infra/lib/SkillQualityGate.js +9 -9
  160. package/dist/infra/lib/SkillRepository.js +159 -159
  161. package/dist/infra/lib/UltraQA.js +99 -99
  162. package/dist/infra/lib/autonomy/AuditStore.js +41 -41
  163. package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
  164. package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
  165. package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
  166. package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
  167. package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
  168. package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
  169. package/dist/infra/lib/browser/compare.d.ts +27 -0
  170. package/dist/infra/lib/browser/compare.d.ts.map +1 -1
  171. package/dist/infra/lib/browser/compare.js +55 -0
  172. package/dist/infra/lib/browser/compare.js.map +1 -1
  173. package/dist/infra/lib/browser/index.d.ts +2 -1
  174. package/dist/infra/lib/browser/index.d.ts.map +1 -1
  175. package/dist/infra/lib/browser/index.js +1 -1
  176. package/dist/infra/lib/browser/index.js.map +1 -1
  177. package/dist/infra/lib/embedding/VectorStore.js +22 -22
  178. package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
  179. package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
  180. package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
  181. package/dist/infra/lib/evolution/InsightStore.js +90 -90
  182. package/dist/infra/lib/evolution/ParityTester.js +57 -57
  183. package/dist/infra/lib/evolution/RollbackManager.js +5 -5
  184. package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
  185. package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
  186. package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
  187. package/dist/infra/lib/evolution/UsageTracker.js +28 -28
  188. package/dist/infra/lib/figma/audit.d.ts +37 -0
  189. package/dist/infra/lib/figma/audit.d.ts.map +1 -0
  190. package/dist/infra/lib/figma/audit.js +130 -0
  191. package/dist/infra/lib/figma/audit.js.map +1 -0
  192. package/dist/infra/lib/figma/extract.d.ts +21 -1
  193. package/dist/infra/lib/figma/extract.d.ts.map +1 -1
  194. package/dist/infra/lib/figma/extract.js +84 -12
  195. package/dist/infra/lib/figma/extract.js.map +1 -1
  196. package/dist/infra/lib/figma/index.d.ts +4 -2
  197. package/dist/infra/lib/figma/index.d.ts.map +1 -1
  198. package/dist/infra/lib/figma/index.js +2 -1
  199. package/dist/infra/lib/figma/index.js.map +1 -1
  200. package/dist/infra/lib/figma/types.d.ts +31 -0
  201. package/dist/infra/lib/figma/types.d.ts.map +1 -1
  202. package/dist/infra/lib/gemini/orchestration.js +5 -5
  203. package/dist/infra/lib/gpt/orchestration.js +4 -4
  204. package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
  205. package/dist/infra/lib/memory/MemorySearch.js +57 -57
  206. package/dist/infra/lib/memory/MemoryStorage.d.ts +5 -0
  207. package/dist/infra/lib/memory/MemoryStorage.d.ts.map +1 -1
  208. package/dist/infra/lib/memory/MemoryStorage.js +202 -183
  209. package/dist/infra/lib/memory/MemoryStorage.js.map +1 -1
  210. package/dist/infra/lib/memory/ObservationStore.js +28 -28
  211. package/dist/infra/lib/memory/ReflectionStore.js +30 -30
  212. package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
  213. package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
  214. package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
  215. package/dist/infra/orchestrator/AgentManager.js +12 -12
  216. package/dist/infra/orchestrator/AgentRegistry.js +65 -65
  217. package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
  218. package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
  219. package/dist/infra/orchestrator/parallelResearch.js +24 -24
  220. package/dist/tools/convention/analyzeComplexity.test.js +115 -115
  221. package/dist/tools/convention/validateCodeQuality.test.js +104 -104
  222. package/dist/tools/memory/createMemoryTimeline.js +10 -10
  223. package/dist/tools/memory/getMemoryGraph.js +12 -12
  224. package/dist/tools/memory/getSessionContext.js +9 -9
  225. package/dist/tools/memory/linkMemories.js +14 -14
  226. package/dist/tools/memory/listMemories.js +4 -4
  227. package/dist/tools/memory/recallMemory.js +4 -4
  228. package/dist/tools/memory/saveMemory.js +4 -4
  229. package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
  230. package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
  231. package/dist/tools/semantic/astGrep.test.js +6 -6
  232. package/dist/tools/spec/prdParser.test.js +171 -171
  233. package/dist/tools/spec/specGenerator.js +169 -169
  234. package/dist/tools/spec/traceabilityMatrix.js +64 -64
  235. package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
  236. package/hooks/gemini-hooks.json +73 -73
  237. package/hooks/hooks.json +134 -126
  238. package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
  239. package/hooks/scripts/__tests__/pre-tool-guard.test.js +409 -409
  240. package/hooks/scripts/__tests__/sentinel-guard.test.js +208 -208
  241. package/hooks/scripts/auto-commit.js +97 -97
  242. package/hooks/scripts/auto-format.js +64 -64
  243. package/hooks/scripts/auto-test.js +81 -81
  244. package/hooks/scripts/code-check.js +271 -271
  245. package/hooks/scripts/codex-detect.js +46 -46
  246. package/hooks/scripts/codex-review-gate.js +80 -80
  247. package/hooks/scripts/command-log.js +32 -32
  248. package/hooks/scripts/context-save.js +353 -353
  249. package/hooks/scripts/evolution-engine.js +91 -91
  250. package/hooks/scripts/figma-extract.js +768 -635
  251. package/hooks/scripts/figma-guard.js +219 -219
  252. package/hooks/scripts/figma-refine.js +315 -315
  253. package/hooks/scripts/figma-to-scss.js +394 -394
  254. package/hooks/scripts/figma-validate.js +353 -353
  255. package/hooks/scripts/hud-status.js +321 -321
  256. package/hooks/scripts/keyword-detector.js +214 -214
  257. package/hooks/scripts/lib/dispatcher.js +87 -83
  258. package/hooks/scripts/lib/scope-from-spec.js +276 -261
  259. package/hooks/scripts/llm-orchestrate.js +645 -645
  260. package/hooks/scripts/post-edit.js +35 -35
  261. package/hooks/scripts/pr-test-gate.js +52 -52
  262. package/hooks/scripts/pre-tool-guard.js +259 -259
  263. package/hooks/scripts/prompt-dispatcher.js +192 -190
  264. package/hooks/scripts/scope-guard.js +145 -145
  265. package/hooks/scripts/sentinel-guard.js +130 -130
  266. package/hooks/scripts/session-start.js +186 -186
  267. package/hooks/scripts/skill-injector.js +83 -83
  268. package/hooks/scripts/step-counter.js +45 -0
  269. package/hooks/scripts/stop-notify.js +209 -209
  270. package/hooks/scripts/utils.js +315 -257
  271. package/languages/csharp-unity.md +515 -515
  272. package/languages/gdscript-godot.md +470 -470
  273. package/languages/ruby-rails.md +489 -489
  274. package/languages/typescript-angular.md +433 -433
  275. package/languages/typescript-astro.md +416 -416
  276. package/languages/typescript-electron.md +406 -406
  277. package/languages/typescript-nestjs.md +524 -524
  278. package/languages/typescript-svelte.md +407 -407
  279. package/languages/typescript-tauri.md +365 -365
  280. package/package.json +106 -106
  281. package/skills/agents-md/SKILL.md +121 -121
  282. package/skills/agents-md/rubrics/what-to-keep.md +49 -49
  283. package/skills/agents-md/templates/agents-md.md +36 -36
  284. package/skills/arch-guard/SKILL.md +181 -181
  285. package/skills/arch-guard/agents/detector.md +48 -48
  286. package/skills/arch-guard/agents/reporter.md +48 -48
  287. package/skills/arch-guard/agents/rule-generator.md +49 -49
  288. package/skills/arch-guard/agents/violation-checker.md +51 -51
  289. package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
  290. package/skills/arch-guard/frameworks/solid.md +102 -102
  291. package/skills/arch-guard/scripts/check-boundaries.js +90 -90
  292. package/skills/arch-guard/templates/arch-rules.json +47 -47
  293. package/skills/arch-guard/templates/violation-report.md +53 -53
  294. package/skills/brand-assets/SKILL.md +147 -147
  295. package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
  296. package/skills/brand-assets/templates/brand-guide.md +161 -161
  297. package/skills/capability-loop/SKILL.md +272 -272
  298. package/skills/capability-loop/agents/capability-designer.md +61 -61
  299. package/skills/capability-loop/agents/failure-analyst.md +55 -55
  300. package/skills/capability-loop/agents/implementer.md +50 -50
  301. package/skills/capability-loop/agents/tester.md +53 -53
  302. package/skills/capability-loop/templates/capability-spec.md +118 -118
  303. package/skills/capability-loop/templates/failure-analysis.md +118 -118
  304. package/skills/characterization-test/SKILL.md +207 -207
  305. package/skills/characterization-test/agents/behavior-capturer.md +50 -50
  306. package/skills/characterization-test/agents/coverage-checker.md +54 -54
  307. package/skills/characterization-test/agents/reporter.md +50 -50
  308. package/skills/characterization-test/agents/test-writer.md +49 -49
  309. package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
  310. package/skills/characterization-test/templates/test-template.ts +101 -101
  311. package/skills/chub-usage/SKILL.md +139 -139
  312. package/skills/claude-md-guide/SKILL.md +351 -351
  313. package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
  314. package/skills/claude-md-guide/templates/claude-md.md +54 -54
  315. package/skills/commerce-patterns/SKILL.md +64 -64
  316. package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
  317. package/skills/commerce-patterns/templates/product-schema.md +85 -85
  318. package/skills/commit-push-pr/SKILL.md +77 -77
  319. package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
  320. package/skills/commit-push-pr/agents/message-writer.md +50 -50
  321. package/skills/commit-push-pr/agents/pr-writer.md +58 -58
  322. package/skills/commit-push-pr/agents/reviewer.md +52 -52
  323. package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
  324. package/skills/commit-push-pr/templates/pr-body.md +63 -63
  325. package/skills/context7-usage/SKILL.md +106 -106
  326. package/skills/context7-usage/rubrics/when-to-use.md +50 -50
  327. package/skills/create-prd/SKILL.md +90 -90
  328. package/skills/create-prd/agents/edge-case-finder.md +48 -48
  329. package/skills/create-prd/agents/prioritizer.md +60 -60
  330. package/skills/create-prd/agents/requirements-writer.md +48 -48
  331. package/skills/create-prd/agents/researcher.md +55 -55
  332. package/skills/create-prd/agents/reviewer.md +54 -54
  333. package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
  334. package/skills/create-prd/frameworks/rice-scoring.md +97 -97
  335. package/skills/create-prd/orchestrator.md +70 -70
  336. package/skills/create-prd/rubrics/completeness.md +58 -58
  337. package/skills/create-prd/templates/prd.md +139 -139
  338. package/skills/design-audit/SKILL.md +152 -152
  339. package/skills/design-audit/agents/a11y-auditor.md +43 -43
  340. package/skills/design-audit/agents/performance-auditor.md +46 -46
  341. package/skills/design-audit/agents/responsive-auditor.md +46 -46
  342. package/skills/design-audit/agents/scorer.md +47 -47
  343. package/skills/design-audit/agents/slop-detector.md +47 -47
  344. package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
  345. package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
  346. package/skills/design-audit/orchestrator.md +64 -64
  347. package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
  348. package/skills/design-audit/rubrics/scoring.md +63 -63
  349. package/skills/design-audit/templates/report.md +88 -88
  350. package/skills/design-critique/SKILL.md +139 -139
  351. package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
  352. package/skills/design-critique/templates/critique-report.md +86 -86
  353. package/skills/design-distill/SKILL.md +130 -130
  354. package/skills/design-distill/templates/design-system.md +132 -132
  355. package/skills/design-normalize/SKILL.md +133 -133
  356. package/skills/design-normalize/rubrics/token-naming.md +117 -117
  357. package/skills/design-normalize/templates/token-audit.md +89 -89
  358. package/skills/design-polish/SKILL.md +131 -131
  359. package/skills/design-polish/rubrics/polish-checklist.md +68 -68
  360. package/skills/design-polish/templates/polish-report.md +64 -64
  361. package/skills/design-teach/SKILL.md +182 -182
  362. package/skills/design-teach/rubrics/brand-personality.md +73 -73
  363. package/skills/design-teach/templates/design-context.json +36 -36
  364. package/skills/devlog/SKILL.md +143 -143
  365. package/skills/e2e-commerce/SKILL.md +62 -62
  366. package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
  367. package/skills/event-comms/SKILL.md +172 -172
  368. package/skills/event-comms/templates/email-invite.md +99 -99
  369. package/skills/event-comms/templates/sns-post.md +133 -133
  370. package/skills/event-ops/SKILL.md +207 -207
  371. package/skills/event-ops/rubrics/contingency.md +85 -85
  372. package/skills/event-ops/templates/d-day-checklist.md +65 -65
  373. package/skills/event-planning/SKILL.md +144 -144
  374. package/skills/event-planning/rubrics/timeline.md +70 -70
  375. package/skills/event-planning/templates/event-plan.md +91 -91
  376. package/skills/exec-plan/SKILL.md +149 -149
  377. package/skills/exec-plan/agents/decomposer.md +47 -47
  378. package/skills/exec-plan/agents/dependency-mapper.md +44 -44
  379. package/skills/exec-plan/agents/estimator.md +43 -43
  380. package/skills/exec-plan/agents/validator.md +55 -55
  381. package/skills/exec-plan/orchestrator.md +70 -70
  382. package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
  383. package/skills/exec-plan/templates/plan.md +147 -147
  384. package/skills/git-worktree/SKILL.md +73 -73
  385. package/skills/git-worktree/rubrics/when-to-use.md +55 -55
  386. package/skills/handoff/SKILL.md +110 -110
  387. package/skills/handoff/agents/context-summarizer.md +51 -51
  388. package/skills/handoff/agents/document-writer.md +63 -63
  389. package/skills/handoff/agents/state-collector.md +53 -53
  390. package/skills/handoff/agents/verifier.md +48 -48
  391. package/skills/handoff/rubrics/completeness.md +62 -62
  392. package/skills/handoff/templates/handoff.md +107 -107
  393. package/skills/parallel-research/SKILL.md +104 -104
  394. package/skills/parallel-research/agents/best-practices.md +43 -43
  395. package/skills/parallel-research/agents/codebase-patterns.md +46 -46
  396. package/skills/parallel-research/agents/framework-docs.md +45 -45
  397. package/skills/parallel-research/agents/security-advisory.md +46 -46
  398. package/skills/parallel-research/agents/synthesizer.md +57 -57
  399. package/skills/parallel-research/experts/best-practices.md +50 -50
  400. package/skills/parallel-research/experts/codebase-patterns.md +70 -70
  401. package/skills/parallel-research/experts/framework-docs.md +65 -65
  402. package/skills/parallel-research/experts/security-advisory.md +69 -69
  403. package/skills/parallel-research/orchestrator.md +79 -79
  404. package/skills/parallel-research/templates/awesome-list.md +32 -32
  405. package/skills/parallel-research/templates/paper.md +88 -88
  406. package/skills/parallel-research/templates/synthesis.md +101 -101
  407. package/skills/prioritization-frameworks/SKILL.md +87 -87
  408. package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
  409. package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
  410. package/skills/priority-todos/SKILL.md +64 -64
  411. package/skills/priority-todos/rubrics/prioritization.md +70 -70
  412. package/skills/priority-todos/templates/todo-board.md +59 -59
  413. package/skills/seo-checklist/SKILL.md +58 -58
  414. package/skills/seo-checklist/frameworks/structured-data.md +153 -153
  415. package/skills/seo-checklist/rubrics/content-seo.md +42 -42
  416. package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
  417. package/skills/techdebt/SKILL.md +124 -124
  418. package/skills/techdebt/agents/analyzer.md +50 -50
  419. package/skills/techdebt/agents/fixer.md +41 -41
  420. package/skills/techdebt/agents/reviewer.md +47 -47
  421. package/skills/techdebt/agents/scanner.md +44 -44
  422. package/skills/techdebt/orchestrator.md +70 -70
  423. package/skills/techdebt/rubrics/severity.md +51 -51
  424. package/skills/techdebt/scripts/scan.js +90 -90
  425. package/skills/techdebt/templates/report.md +86 -86
  426. package/skills/tool-fallback/SKILL.md +104 -104
  427. package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
  428. package/skills/typescript-advanced-types/SKILL.md +67 -67
  429. package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
  430. package/skills/ui-ux-pro-max/SKILL.md +236 -236
  431. package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
  432. package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
  433. package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
  434. package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
  435. package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
  436. package/skills/ui-ux-pro-max/reference/typography.md +455 -455
  437. package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
  438. package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
  439. package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
  440. package/skills/user-personas/SKILL.md +75 -75
  441. package/skills/user-personas/rubrics/research-methods.md +56 -56
  442. package/skills/user-personas/templates/persona.md +89 -89
  443. package/skills/vercel-react-best-practices/SKILL.md +60 -60
  444. package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
  445. package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
  446. package/skills/vibe-contract/SKILL.md +166 -166
  447. package/skills/vibe-docs/templates/architecture.md +80 -80
  448. package/skills/vibe-docs/templates/readme.md +84 -84
  449. package/skills/vibe-docs/templates/release-notes.md +74 -74
  450. package/skills/vibe-figma/SKILL.md +363 -363
  451. package/skills/vibe-figma/rubrics/extraction-checklist.md +51 -51
  452. package/skills/vibe-figma/templates/component-index.md +126 -126
  453. package/skills/vibe-figma/templates/component-spec.md +168 -168
  454. package/skills/vibe-figma/templates/figma-handoff.md +100 -100
  455. package/skills/vibe-figma/templates/remapped-tree.md +277 -277
  456. package/skills/vibe-figma-convert/SKILL.md +235 -235
  457. package/skills/vibe-figma-convert/rubrics/conversion-rules.md +141 -141
  458. package/skills/vibe-figma-convert/templates/component.md +140 -140
  459. package/skills/vibe-figma-extract/SKILL.md +241 -219
  460. package/skills/vibe-figma-extract/rubrics/image-rules.md +157 -157
  461. package/skills/vibe-interview/SKILL.md +358 -358
  462. package/skills/vibe-interview/checklists/api.md +101 -101
  463. package/skills/vibe-interview/checklists/feature.md +88 -88
  464. package/skills/vibe-interview/checklists/library.md +95 -95
  465. package/skills/vibe-interview/checklists/mobile.md +89 -89
  466. package/skills/vibe-interview/checklists/webapp.md +97 -97
  467. package/skills/vibe-interview/checklists/website.md +99 -99
  468. package/skills/vibe-plan/SKILL.md +254 -254
  469. package/skills/vibe-regress/SKILL.md +174 -174
  470. package/skills/vibe-regress/templates/bug.md +44 -44
  471. package/skills/vibe-regress/templates/test-jest.md +29 -29
  472. package/skills/vibe-regress/templates/test-vitest.md +30 -30
  473. package/skills/vibe-spec/SKILL.md +1195 -1195
  474. package/skills/vibe-spec-review/SKILL.md +726 -726
  475. package/skills/vibe-test/SKILL.md +140 -140
  476. package/skills/video-production/SKILL.md +52 -52
  477. package/skills/video-production/rubrics/quality-checklist.md +58 -58
  478. package/skills/video-production/templates/production-plan.md +104 -104
  479. package/vibe/config.json +29 -29
  480. package/vibe/constitution.md +227 -227
  481. package/vibe/rules/principles/communication-guide.md +98 -98
  482. package/vibe/rules/principles/development-philosophy.md +52 -52
  483. package/vibe/rules/principles/quick-start.md +102 -102
  484. package/vibe/rules/quality/bdd-contract-testing.md +393 -393
  485. package/vibe/rules/quality/checklist.md +276 -276
  486. package/vibe/rules/quality/performance.md +236 -236
  487. package/vibe/rules/quality/testing-strategy.md +440 -440
  488. package/vibe/rules/standards/anti-patterns.md +541 -541
  489. package/vibe/rules/standards/code-structure.md +291 -291
  490. package/vibe/rules/standards/complexity-metrics.md +313 -313
  491. package/vibe/rules/standards/git-workflow.md +237 -237
  492. package/vibe/rules/standards/naming-conventions.md +198 -198
  493. package/vibe/rules/standards/security.md +305 -305
  494. package/vibe/rules/writing/document-style.md +74 -74
  495. package/vibe/setup.sh +31 -31
  496. package/vibe/templates/claudemd-template.md +74 -74
  497. package/vibe/templates/constitution-template.md +267 -267
  498. package/vibe/templates/contract-backend-template.md +526 -526
  499. package/vibe/templates/contract-frontend-template.md +599 -599
  500. package/vibe/templates/feature-template.md +96 -96
  501. package/vibe/templates/plan-template.md +194 -194
  502. package/vibe/templates/spec-template.md +221 -221
  503. package/vibe/ui-ux-data/charts.csv +26 -26
  504. package/vibe/ui-ux-data/colors.csv +97 -97
  505. package/vibe/ui-ux-data/icons.csv +101 -101
  506. package/vibe/ui-ux-data/landing.csv +31 -31
  507. package/vibe/ui-ux-data/products.csv +96 -96
  508. package/vibe/ui-ux-data/react-performance.csv +45 -45
  509. package/vibe/ui-ux-data/stacks/astro.csv +54 -54
  510. package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
  511. package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
  512. package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
  513. package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
  514. package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
  515. package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
  516. package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
  517. package/vibe/ui-ux-data/stacks/react.csv +54 -54
  518. package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
  519. package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
  520. package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
  521. package/vibe/ui-ux-data/stacks/vue.csv +50 -50
  522. package/vibe/ui-ux-data/styles.csv +68 -68
  523. package/vibe/ui-ux-data/typography.csv +57 -57
  524. package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
  525. package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
  526. package/vibe/ui-ux-data/version.json +31 -31
  527. package/vibe/ui-ux-data/web-interface.csv +31 -31
@@ -1,140 +1,140 @@
1
- ---
2
- name: vibe-test
3
- tier: core
4
- description: "Self-test vibe by probing every command/skill/hook/agent in a target harness install dir (~/.claude or ~/.coco) and writing a pass/fail report to ~/.vibe/test-reports/. Takes an optional harness argument (cc|coco); empty = current harness. Must use this skill when user runs /vibe.test, when verifying a vibe install before release, or when the user says 'self-test', 'harness 점검', 'vibe 건강'."
5
- triggers: [test, self-test, "vibe 건강", "harness 점검", "자가검진"]
6
- priority: 70
7
- chain-next: []
8
- ---
9
-
10
- # vibe-test — Self-Test
11
-
12
- Probe every shipped vibe surface in one install dir and emit a pass/fail report.
13
-
14
- ## Why this exists
15
-
16
- When vibe ships new commands, skills, hooks, or agents, one side (CC or coco) can end up out of sync with the other, frontmatter can drift, and hook tests can silently break. `/vibe.test` is the single mechanical check: does every surface in the target install actually load and pass its own tests?
17
-
18
- ## Target harness
19
-
20
- The argument selects which install dir to probe:
21
-
22
- | Arg | Probed dir |
23
- |---|---|
24
- | (empty) | current harness — CC: `~/.claude/`, coco: `~/.coco/` |
25
- | `cc` | `~/.claude/` |
26
- | `coco` | `~/.coco/` |
27
-
28
- If the target dir does not exist, print a clear message and exit with guidance (not an error). Example:
29
-
30
- ```
31
- ~/.coco/ not found — coco isn't installed on this machine.
32
- To install: pnpm add -g @su-record/vibe-coco
33
- ```
34
-
35
- ## Probes
36
-
37
- All probes are **structural or test-based** — no interactive command is ever actually invoked, and no LLM is called.
38
-
39
- | Category | Source | Check |
40
- |---|---|---|
41
- | commands | `<install>/commands/*.md` | file readable · frontmatter parses · `description` present · body references a skill (`Load skill \`...\``) if it delegates |
42
- | skills | `<install>/skills/*/SKILL.md` | frontmatter parses · required fields (`name`, `description`) · `triggers` array non-empty · body non-empty |
43
- | hooks | repo `hooks/scripts/*.js` | for each script with a matching `__tests__/<name>.test.js`, run `npx vitest run <test> --reporter=json` and parse pass/fail counts |
44
- | agents | `<install>/agents/*.md` | file readable · frontmatter parses · required fields (`name`, `description`) |
45
-
46
- A probe's failure is captured in its `error` field; the overall run never halts because of one failure.
47
-
48
- ## Report template
49
-
50
- Written to `~/.vibe/test-reports/<YYYYMMDD-HHmm>-<harness>.{json,md}`. Exact schema:
51
-
52
- ### JSON
53
-
54
- ```json
55
- {
56
- "harness": "cc",
57
- "timestamp": "2026-04-16T18:30:00+09:00",
58
- "vibe_version": "2.9.24",
59
- "install_dir": "/Users/grove/.claude",
60
- "summary": {
61
- "total": 42,
62
- "passed": 40,
63
- "failed": 2
64
- },
65
- "probes": {
66
- "commands": [
67
- { "name": "vibe.spec", "status": "pass" },
68
- { "name": "vibe.test", "status": "pass" }
69
- ],
70
- "skills": [
71
- { "name": "vibe-test", "status": "pass" },
72
- { "name": "vibe-spec", "status": "fail", "error": "frontmatter: triggers array is empty" }
73
- ],
74
- "hooks": [
75
- { "name": "pre-tool-guard", "status": "pass", "tests": "38/38" },
76
- { "name": "keyword-detector", "status": "pass", "tests": "12/12" }
77
- ],
78
- "agents": [
79
- { "name": "explorer", "status": "pass" }
80
- ]
81
- },
82
- "failed": [
83
- {
84
- "category": "skills",
85
- "name": "vibe-spec",
86
- "error": "frontmatter: triggers array is empty"
87
- }
88
- ]
89
- }
90
- ```
91
-
92
- - `status`: `"pass"` | `"fail"`
93
- - `error`: required when `status === "fail"`, omitted otherwise
94
- - `tests` (hooks only): short `passed/total` string from the vitest JSON reporter
95
- - `failed[]`: flat list of every failure for quick scanning — mirrors entries found across `probes.*`
96
-
97
- ### Markdown
98
-
99
- ```markdown
100
- # vibe self-test · cc · 2026-04-16 18:30
101
-
102
- **Version**: 2.9.24 **Install**: /Users/grove/.claude
103
-
104
- | Category | Pass | Fail |
105
- |---|---:|---:|
106
- | commands | 15 | 0 |
107
- | skills | 17 | 1 |
108
- | hooks | 6 | 0 |
109
- | agents | 3 | 1 |
110
- | **total**| **41** | **2** |
111
-
112
- ## Failures
113
-
114
- - **skills / vibe-spec** — frontmatter: triggers array is empty
115
- - **agents / explorer** — agent file not found
116
- ```
117
-
118
- If `failed` is empty, replace the Failures section with `_All probes passed._`.
119
-
120
- ## Steps
121
-
122
- 1. **Resolve target**: argument (`cc` / `coco` / empty). Empty → detect current harness (`$CLAUDE_PROJECT_DIR` set → `cc`; else fall back to `cc`).
123
- 2. **Resolve install dir**: `cc` → `~/.claude`, `coco` → `~/.coco`. If missing → print guidance + exit.
124
- 3. **Read `vibe_version`** from `package.json` in the current repo.
125
- 4. **Walk each category**, run its check, append `{ name, status, error? }` to `probes.<category>`.
126
- 5. **Compute** `summary` counts and the flat `failed[]` list.
127
- 6. **Ensure** `~/.vibe/test-reports/` exists (`mkdir -p`, dir mode `0o700` — consistent with `~/.vibe/config.json`).
128
- 7. **Write** `<ts>-<harness>.json` and `<ts>-<harness>.md`.
129
- 8. **Print** the Markdown summary to the console.
130
- 9. **If `summary.failed > 0`**, load skill `vibe-regress` with `subcommand: register --from-test` and pass the failed entries. P1 = any probe with `status: fail`.
131
-
132
- ## Done Criteria
133
-
134
- - [ ] No external LLM call — file reads + vitest runs only
135
- - [ ] One probe failing never halts the overall run
136
- - [ ] Target install dir missing → clean exit with guidance (not an error)
137
- - [ ] JSON report matches the template above exactly (fields, types, naming)
138
- - [ ] Markdown summary printed to console after the run
139
- - [ ] Reports land in `~/.vibe/test-reports/`, never in project-local `.claude/vibe/`
140
- - [ ] `failed.length > 0` → auto-invokes `/vibe.regress register --from-test`
1
+ ---
2
+ name: vibe-test
3
+ tier: core
4
+ description: "Self-test vibe by probing every command/skill/hook/agent in a target harness install dir (~/.claude or ~/.coco) and writing a pass/fail report to ~/.vibe/test-reports/. Takes an optional harness argument (cc|coco); empty = current harness. Must use this skill when user runs /vibe.test, when verifying a vibe install before release, or when the user says 'self-test', 'harness 점검', 'vibe 건강'."
5
+ triggers: [test, self-test, "vibe 건강", "harness 점검", "자가검진"]
6
+ priority: 70
7
+ chain-next: []
8
+ ---
9
+
10
+ # vibe-test — Self-Test
11
+
12
+ Probe every shipped vibe surface in one install dir and emit a pass/fail report.
13
+
14
+ ## Why this exists
15
+
16
+ When vibe ships new commands, skills, hooks, or agents, one side (CC or coco) can end up out of sync with the other, frontmatter can drift, and hook tests can silently break. `/vibe.test` is the single mechanical check: does every surface in the target install actually load and pass its own tests?
17
+
18
+ ## Target harness
19
+
20
+ The argument selects which install dir to probe:
21
+
22
+ | Arg | Probed dir |
23
+ |---|---|
24
+ | (empty) | current harness — CC: `~/.claude/`, coco: `~/.coco/` |
25
+ | `cc` | `~/.claude/` |
26
+ | `coco` | `~/.coco/` |
27
+
28
+ If the target dir does not exist, print a clear message and exit with guidance (not an error). Example:
29
+
30
+ ```
31
+ ~/.coco/ not found — coco isn't installed on this machine.
32
+ To install: pnpm add -g @su-record/vibe-coco
33
+ ```
34
+
35
+ ## Probes
36
+
37
+ All probes are **structural or test-based** — no interactive command is ever actually invoked, and no LLM is called.
38
+
39
+ | Category | Source | Check |
40
+ |---|---|---|
41
+ | commands | `<install>/commands/*.md` | file readable · frontmatter parses · `description` present · body references a skill (`Load skill \`...\``) if it delegates |
42
+ | skills | `<install>/skills/*/SKILL.md` | frontmatter parses · required fields (`name`, `description`) · `triggers` array non-empty · body non-empty |
43
+ | hooks | repo `hooks/scripts/*.js` | for each script with a matching `__tests__/<name>.test.js`, run `npx vitest run <test> --reporter=json` and parse pass/fail counts |
44
+ | agents | `<install>/agents/*.md` | file readable · frontmatter parses · required fields (`name`, `description`) |
45
+
46
+ A probe's failure is captured in its `error` field; the overall run never halts because of one failure.
47
+
48
+ ## Report template
49
+
50
+ Written to `~/.vibe/test-reports/<YYYYMMDD-HHmm>-<harness>.{json,md}`. Exact schema:
51
+
52
+ ### JSON
53
+
54
+ ```json
55
+ {
56
+ "harness": "cc",
57
+ "timestamp": "2026-04-16T18:30:00+09:00",
58
+ "vibe_version": "2.9.24",
59
+ "install_dir": "/Users/grove/.claude",
60
+ "summary": {
61
+ "total": 42,
62
+ "passed": 40,
63
+ "failed": 2
64
+ },
65
+ "probes": {
66
+ "commands": [
67
+ { "name": "vibe.spec", "status": "pass" },
68
+ { "name": "vibe.test", "status": "pass" }
69
+ ],
70
+ "skills": [
71
+ { "name": "vibe-test", "status": "pass" },
72
+ { "name": "vibe-spec", "status": "fail", "error": "frontmatter: triggers array is empty" }
73
+ ],
74
+ "hooks": [
75
+ { "name": "pre-tool-guard", "status": "pass", "tests": "38/38" },
76
+ { "name": "keyword-detector", "status": "pass", "tests": "12/12" }
77
+ ],
78
+ "agents": [
79
+ { "name": "explorer", "status": "pass" }
80
+ ]
81
+ },
82
+ "failed": [
83
+ {
84
+ "category": "skills",
85
+ "name": "vibe-spec",
86
+ "error": "frontmatter: triggers array is empty"
87
+ }
88
+ ]
89
+ }
90
+ ```
91
+
92
+ - `status`: `"pass"` | `"fail"`
93
+ - `error`: required when `status === "fail"`, omitted otherwise
94
+ - `tests` (hooks only): short `passed/total` string from the vitest JSON reporter
95
+ - `failed[]`: flat list of every failure for quick scanning — mirrors entries found across `probes.*`
96
+
97
+ ### Markdown
98
+
99
+ ```markdown
100
+ # vibe self-test · cc · 2026-04-16 18:30
101
+
102
+ **Version**: 2.9.24 **Install**: /Users/grove/.claude
103
+
104
+ | Category | Pass | Fail |
105
+ |---|---:|---:|
106
+ | commands | 15 | 0 |
107
+ | skills | 17 | 1 |
108
+ | hooks | 6 | 0 |
109
+ | agents | 3 | 1 |
110
+ | **total**| **41** | **2** |
111
+
112
+ ## Failures
113
+
114
+ - **skills / vibe-spec** — frontmatter: triggers array is empty
115
+ - **agents / explorer** — agent file not found
116
+ ```
117
+
118
+ If `failed` is empty, replace the Failures section with `_All probes passed._`.
119
+
120
+ ## Steps
121
+
122
+ 1. **Resolve target**: argument (`cc` / `coco` / empty). Empty → detect current harness (`$CLAUDE_PROJECT_DIR` set → `cc`; else fall back to `cc`).
123
+ 2. **Resolve install dir**: `cc` → `~/.claude`, `coco` → `~/.coco`. If missing → print guidance + exit.
124
+ 3. **Read `vibe_version`** from `package.json` in the current repo.
125
+ 4. **Walk each category**, run its check, append `{ name, status, error? }` to `probes.<category>`.
126
+ 5. **Compute** `summary` counts and the flat `failed[]` list.
127
+ 6. **Ensure** `~/.vibe/test-reports/` exists (`mkdir -p`, dir mode `0o700` — consistent with `~/.vibe/config.json`).
128
+ 7. **Write** `<ts>-<harness>.json` and `<ts>-<harness>.md`.
129
+ 8. **Print** the Markdown summary to the console.
130
+ 9. **If `summary.failed > 0`**, load skill `vibe-regress` with `subcommand: register --from-test` and pass the failed entries. P1 = any probe with `status: fail`.
131
+
132
+ ## Done Criteria
133
+
134
+ - [ ] No external LLM call — file reads + vitest runs only
135
+ - [ ] One probe failing never halts the overall run
136
+ - [ ] Target install dir missing → clean exit with guidance (not an error)
137
+ - [ ] JSON report matches the template above exactly (fields, types, naming)
138
+ - [ ] Markdown summary printed to console after the run
139
+ - [ ] Reports land in `~/.vibe/test-reports/`, never in project-local `.claude/vibe/`
140
+ - [ ] `failed.length > 0` → auto-invokes `/vibe.regress register --from-test`
@@ -1,52 +1,52 @@
1
- ---
2
- name: video-production
3
- tier: standard
4
- description: "Video processing gotchas — FFmpeg commands, transcoding pipelines, HLS/DASH streaming setup, subtitle embedding (SRT/VTT), and thumbnail extraction. Use when the project involves any video manipulation, media processing, or streaming infrastructure. Covers codec selection, bitrate optimization, and common FFmpeg pitfalls. Must use this skill when user works with video files, mentions FFmpeg, or needs media processing — even for simple tasks like 'generate a thumbnail'."
5
- triggers: [video, ffmpeg, transcode, encode, stream, media, subtitle, thumbnail, hls, dash]
6
- priority: 60
7
- ---
8
-
9
- # Video Production
10
-
11
- ## Pre-check (K1)
12
-
13
- > Are you processing video files programmatically? If just embedding a YouTube/Vimeo player, this skill is not needed.
14
-
15
- ## Gotchas
16
-
17
- | Gotcha | Consequence | Prevention |
18
- |--------|-------------|------------|
19
- | Direct CLI string concatenation | Command injection risk | Always use wrapper library (fluent-ffmpeg for TS, ffmpeg-python for Python) |
20
- | No input validation | Crash on corrupted files | Always `ffprobe` input before processing — check codec, resolution, duration |
21
- | No temp file cleanup | Disk fills up silently | `try/finally` or cleanup handler — never leave partial outputs |
22
- | No progress callback | Long encoding appears frozen | Implement progress events for any operation >10s |
23
- | Memory loading large files | OOM on 4K+ video | Use streaming I/O, never read entire file into memory |
24
- | Assuming codec availability | Fails on different FFmpeg builds | Check `ffmpeg -codecs` at runtime before encoding |
25
- | Fixed bitrate encoding | Inconsistent quality | Use CRF-based quality (18-28 for H.264) instead |
26
- | No timeout | Encoding hangs forever | Set timeout + kill process on expiry |
27
-
28
- ## Codec Quick Reference
29
-
30
- | Use Case | Codec | Note |
31
- |----------|-------|------|
32
- | Maximum compatibility | H.264 (libx264) | CRF 23 default |
33
- | Smaller files | H.265 (libx265) | 50% smaller, slower, licensing issues |
34
- | Open source | VP9 (libvpx-vp9) | Good for WebM |
35
- | Best compression | AV1 (libaom-av1) | Very slow encoding |
36
-
37
- ## Resolution Presets
38
-
39
- | Preset | Resolution | Bitrate (H.264) |
40
- |--------|-----------|-----------------|
41
- | 360p | 640x360 | 800 kbps |
42
- | 720p | 1280x720 | 3 Mbps |
43
- | 1080p | 1920x1080 | 6 Mbps |
44
- | 4K | 3840x2160 | 15 Mbps |
45
-
46
- ## Done Criteria (K4)
47
-
48
- - [ ] All FFmpeg calls go through wrapper library (no raw CLI strings)
49
- - [ ] Input files validated with ffprobe before processing
50
- - [ ] Temp files cleaned up in all paths (success + error)
51
- - [ ] Progress reporting for long operations
52
- - [ ] Codec availability checked at runtime
1
+ ---
2
+ name: video-production
3
+ tier: standard
4
+ description: "Video processing gotchas — FFmpeg commands, transcoding pipelines, HLS/DASH streaming setup, subtitle embedding (SRT/VTT), and thumbnail extraction. Use when the project involves any video manipulation, media processing, or streaming infrastructure. Covers codec selection, bitrate optimization, and common FFmpeg pitfalls. Must use this skill when user works with video files, mentions FFmpeg, or needs media processing — even for simple tasks like 'generate a thumbnail'."
5
+ triggers: [video, ffmpeg, transcode, encode, stream, media, subtitle, thumbnail, hls, dash]
6
+ priority: 60
7
+ ---
8
+
9
+ # Video Production
10
+
11
+ ## Pre-check (K1)
12
+
13
+ > Are you processing video files programmatically? If just embedding a YouTube/Vimeo player, this skill is not needed.
14
+
15
+ ## Gotchas
16
+
17
+ | Gotcha | Consequence | Prevention |
18
+ |--------|-------------|------------|
19
+ | Direct CLI string concatenation | Command injection risk | Always use wrapper library (fluent-ffmpeg for TS, ffmpeg-python for Python) |
20
+ | No input validation | Crash on corrupted files | Always `ffprobe` input before processing — check codec, resolution, duration |
21
+ | No temp file cleanup | Disk fills up silently | `try/finally` or cleanup handler — never leave partial outputs |
22
+ | No progress callback | Long encoding appears frozen | Implement progress events for any operation >10s |
23
+ | Memory loading large files | OOM on 4K+ video | Use streaming I/O, never read entire file into memory |
24
+ | Assuming codec availability | Fails on different FFmpeg builds | Check `ffmpeg -codecs` at runtime before encoding |
25
+ | Fixed bitrate encoding | Inconsistent quality | Use CRF-based quality (18-28 for H.264) instead |
26
+ | No timeout | Encoding hangs forever | Set timeout + kill process on expiry |
27
+
28
+ ## Codec Quick Reference
29
+
30
+ | Use Case | Codec | Note |
31
+ |----------|-------|------|
32
+ | Maximum compatibility | H.264 (libx264) | CRF 23 default |
33
+ | Smaller files | H.265 (libx265) | 50% smaller, slower, licensing issues |
34
+ | Open source | VP9 (libvpx-vp9) | Good for WebM |
35
+ | Best compression | AV1 (libaom-av1) | Very slow encoding |
36
+
37
+ ## Resolution Presets
38
+
39
+ | Preset | Resolution | Bitrate (H.264) |
40
+ |--------|-----------|-----------------|
41
+ | 360p | 640x360 | 800 kbps |
42
+ | 720p | 1280x720 | 3 Mbps |
43
+ | 1080p | 1920x1080 | 6 Mbps |
44
+ | 4K | 3840x2160 | 15 Mbps |
45
+
46
+ ## Done Criteria (K4)
47
+
48
+ - [ ] All FFmpeg calls go through wrapper library (no raw CLI strings)
49
+ - [ ] Input files validated with ffprobe before processing
50
+ - [ ] Temp files cleaned up in all paths (success + error)
51
+ - [ ] Progress reporting for long operations
52
+ - [ ] Codec availability checked at runtime
@@ -1,58 +1,58 @@
1
- # Video Quality Checklist
2
-
3
- ## Pre-Processing
4
-
5
- - [ ] Input file exists and is readable before pipeline starts
6
- - [ ] `ffprobe` run on input — codec, resolution, duration, bitrate logged
7
- - [ ] Corrupted/truncated files rejected with clear error (not crash)
8
- - [ ] Input resolution within supported range (min 360p, max 4K)
9
- - [ ] Audio stream present — handle gracefully if missing
10
-
11
- ## Encoding
12
-
13
- - [ ] CRF-based encoding used (not fixed bitrate) for consistent visual quality
14
- - [ ] Target codec available in current FFmpeg build (`ffmpeg -codecs` check)
15
- - [ ] Encoding runs through wrapper library — no raw CLI string concatenation
16
- - [ ] `-movflags +faststart` set for MP4 (enables streaming before full download)
17
- - [ ] Audio normalized: loudness target -16 LUFS (streaming standard)
18
- - [ ] Aspect ratio preserved — no unintended stretching
19
-
20
- ## Progress & Monitoring
21
-
22
- - [ ] Progress events emitted for any operation exceeding 10 seconds
23
- - [ ] Encoding timeout configured — process killed on expiry
24
- - [ ] Estimated time remaining shown in progress (based on bitrate processed)
25
-
26
- ## Output Validation
27
-
28
- - [ ] Output file exists after encoding completes
29
- - [ ] Output duration verified: within ±2 seconds of input
30
- - [ ] Output codec matches requested codec (re-run ffprobe on output)
31
- - [ ] Output file size within acceptable range (flag if >3x input size)
32
- - [ ] Thumbnail: correct dimensions, not blank/corrupted
33
-
34
- ## Subtitles (if applicable)
35
-
36
- - [ ] Subtitle file encoding is UTF-8 (convert if needed)
37
- - [ ] Subtitle timing verified — first/last cue in range of video duration
38
- - [ ] Burn-in subtitles visually tested on dark and light scenes
39
-
40
- ## HLS / DASH Streaming (if applicable)
41
-
42
- - [ ] `.m3u8` manifest references correct segment file names
43
- - [ ] All segment files present in output directory
44
- - [ ] Segment duration consistent (target ±1 second of configured value)
45
- - [ ] CORS headers configured on media server
46
-
47
- ## Storage & Cleanup
48
-
49
- - [ ] Temp directory cleaned in `finally` block — both success and error paths
50
- - [ ] No partial output files left on disk after failure
51
- - [ ] Output written to separate directory from temp files
52
- - [ ] Disk space checked before processing large files (minimum 3x input size free)
53
-
54
- ## Security
55
-
56
- - [ ] Input file path sanitized — no directory traversal (`../`)
57
- - [ ] FFmpeg invoked via array arguments (not shell string) to prevent injection
58
- - [ ] Max file size limit enforced before processing begins
1
+ # Video Quality Checklist
2
+
3
+ ## Pre-Processing
4
+
5
+ - [ ] Input file exists and is readable before pipeline starts
6
+ - [ ] `ffprobe` run on input — codec, resolution, duration, bitrate logged
7
+ - [ ] Corrupted/truncated files rejected with clear error (not crash)
8
+ - [ ] Input resolution within supported range (min 360p, max 4K)
9
+ - [ ] Audio stream present — handle gracefully if missing
10
+
11
+ ## Encoding
12
+
13
+ - [ ] CRF-based encoding used (not fixed bitrate) for consistent visual quality
14
+ - [ ] Target codec available in current FFmpeg build (`ffmpeg -codecs` check)
15
+ - [ ] Encoding runs through wrapper library — no raw CLI string concatenation
16
+ - [ ] `-movflags +faststart` set for MP4 (enables streaming before full download)
17
+ - [ ] Audio normalized: loudness target -16 LUFS (streaming standard)
18
+ - [ ] Aspect ratio preserved — no unintended stretching
19
+
20
+ ## Progress & Monitoring
21
+
22
+ - [ ] Progress events emitted for any operation exceeding 10 seconds
23
+ - [ ] Encoding timeout configured — process killed on expiry
24
+ - [ ] Estimated time remaining shown in progress (based on bitrate processed)
25
+
26
+ ## Output Validation
27
+
28
+ - [ ] Output file exists after encoding completes
29
+ - [ ] Output duration verified: within ±2 seconds of input
30
+ - [ ] Output codec matches requested codec (re-run ffprobe on output)
31
+ - [ ] Output file size within acceptable range (flag if >3x input size)
32
+ - [ ] Thumbnail: correct dimensions, not blank/corrupted
33
+
34
+ ## Subtitles (if applicable)
35
+
36
+ - [ ] Subtitle file encoding is UTF-8 (convert if needed)
37
+ - [ ] Subtitle timing verified — first/last cue in range of video duration
38
+ - [ ] Burn-in subtitles visually tested on dark and light scenes
39
+
40
+ ## HLS / DASH Streaming (if applicable)
41
+
42
+ - [ ] `.m3u8` manifest references correct segment file names
43
+ - [ ] All segment files present in output directory
44
+ - [ ] Segment duration consistent (target ±1 second of configured value)
45
+ - [ ] CORS headers configured on media server
46
+
47
+ ## Storage & Cleanup
48
+
49
+ - [ ] Temp directory cleaned in `finally` block — both success and error paths
50
+ - [ ] No partial output files left on disk after failure
51
+ - [ ] Output written to separate directory from temp files
52
+ - [ ] Disk space checked before processing large files (minimum 3x input size free)
53
+
54
+ ## Security
55
+
56
+ - [ ] Input file path sanitized — no directory traversal (`../`)
57
+ - [ ] FFmpeg invoked via array arguments (not shell string) to prevent injection
58
+ - [ ] Max file size limit enforced before processing begins