@heytherevibin/skillforge 0.2.1

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 (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,163 @@
1
+ ---
2
+ name: cisco-ios-patterns
3
+ description: Cisco IOS and IOS-XE review patterns for show commands, config hierarchy, wildcard masks, ACL placement, interface hygiene, and safe change-window verification.
4
+ origin: community
5
+ ---
6
+
7
+ # Cisco IOS Patterns
8
+
9
+ Use this skill when reviewing Cisco IOS or IOS-XE snippets, building a
10
+ change-window checklist, or explaining how to collect evidence from a router or
11
+ switch without making the incident worse.
12
+
13
+ ## When to Use
14
+
15
+ - Reviewing IOS or IOS-XE configuration before a planned change.
16
+ - Choosing read-only `show` commands for troubleshooting.
17
+ - Checking ACL wildcard masks and interface direction.
18
+ - Explaining global, interface, routing process, and line configuration modes.
19
+ - Verifying that a change landed in running config and was saved intentionally.
20
+
21
+ ## Operating Rules
22
+
23
+ Treat IOS examples as patterns, not paste-ready production changes. Confirm the
24
+ platform, interface names, current config, rollback path, and out-of-band access
25
+ before making changes on a real device.
26
+
27
+ Prefer this workflow:
28
+
29
+ 1. Capture current state with read-only commands.
30
+ 2. Review the exact candidate config.
31
+ 3. Confirm management access cannot be locked out.
32
+ 4. Apply the smallest change in a maintenance window.
33
+ 5. Re-read state, compare to the baseline, then save only after validation.
34
+
35
+ ## Mode Reference
36
+
37
+ ```text
38
+ Router> enable
39
+ Router# show running-config
40
+ Router# configure terminal
41
+ Router(config)# interface GigabitEthernet0/1
42
+ Router(config-if)# description UPLINK-TO-CORE
43
+ Router(config-if)# no shutdown
44
+ Router(config-if)# exit
45
+ Router(config)# end
46
+ Router# show running-config interface GigabitEthernet0/1
47
+ ```
48
+
49
+ `running-config` is active memory. `startup-config` is what survives reload.
50
+ Do not save a change just because a command was accepted; validate behavior
51
+ first, then use `copy running-config startup-config` if the change is approved.
52
+
53
+ ## Read-Only Collection
54
+
55
+ ```text
56
+ show version
57
+ show inventory
58
+ show processes cpu sorted
59
+ show memory statistics
60
+ show logging
61
+ show running-config | section line vty
62
+ show running-config | section interface
63
+ show running-config | section router bgp
64
+ show ip interface brief
65
+ show interfaces
66
+ show interfaces status
67
+ show vlan brief
68
+ show mac address-table
69
+ show spanning-tree
70
+ show ip route
71
+ show ip protocols
72
+ show ip access-lists
73
+ show route-map
74
+ show ip prefix-list
75
+ ```
76
+
77
+ Collect the specific section you need instead of dumping full config into a
78
+ ticket when the config may contain secrets, customer names, or private topology.
79
+
80
+ ## Wildcard Masks
81
+
82
+ IOS ACL and many routing statements use wildcard masks, not subnet masks.
83
+
84
+ ```text
85
+ Subnet mask Wildcard mask
86
+ 255.255.255.255 0.0.0.0
87
+ 255.255.255.252 0.0.0.3
88
+ 255.255.255.0 0.0.0.255
89
+ 255.255.0.0 0.0.255.255
90
+ ```
91
+
92
+ Review wildcard masks before deployment. A subnet mask accidentally used as a
93
+ wildcard can match far more traffic than intended.
94
+
95
+ ```text
96
+ ip access-list extended WEB-IN
97
+ 10 permit tcp 192.0.2.0 0.0.0.255 any eq 443
98
+ 999 deny ip any any log
99
+ ```
100
+
101
+ Every ACL has an implicit deny at the end. Add an explicit logged deny when the
102
+ operational goal includes observing misses, and confirm logging volume is safe.
103
+
104
+ ## ACL Placement Review
105
+
106
+ Before applying an ACL to an interface, answer these questions:
107
+
108
+ - Which traffic direction is being filtered, `in` or `out`?
109
+ - Is management traffic sourced from a known jump host or management subnet?
110
+ - Is there an explicit permit for required routing, DNS, NTP, monitoring, or
111
+ application traffic?
112
+ - Are hit counters available from a safe test source?
113
+ - Is there a rollback command and an active console or out-of-band path?
114
+
115
+ Do not test reachability by removing firewall or ACL protections. Read counters,
116
+ logs, and route state first.
117
+
118
+ ## Interface Hygiene
119
+
120
+ ```text
121
+ interface GigabitEthernet0/1
122
+ description UPLINK-TO-CORE
123
+ switchport mode trunk
124
+ switchport trunk allowed vlan 10,20,30
125
+ switchport trunk native vlan 999
126
+ no shutdown
127
+ ```
128
+
129
+ Use clear descriptions, explicit switchport mode, and documented native VLANs.
130
+ On routed interfaces, confirm the mask, peer addressing, and routing process
131
+ before assuming link state means forwarding is correct.
132
+
133
+ ## Change-Window Verification
134
+
135
+ Use before/after checks that match the actual change.
136
+
137
+ ```text
138
+ show running-config | section interface GigabitEthernet0/1
139
+ show interfaces GigabitEthernet0/1
140
+ show logging | include GigabitEthernet0/1|changed state|line protocol
141
+ show ip route <prefix>
142
+ show ip access-lists <name>
143
+ ```
144
+
145
+ For routing changes, also capture neighbor state and route tables before and
146
+ after the change. For ACL changes, compare hit counters from a planned test
147
+ source rather than relying on a generic ping.
148
+
149
+ ## Anti-Patterns
150
+
151
+ - Applying a generated config without a device-specific diff.
152
+ - Saving configuration before post-change checks pass.
153
+ - Using a subnet mask where IOS expects a wildcard mask.
154
+ - Applying an ACL to the wrong interface direction.
155
+ - Troubleshooting by disabling ACLs, route policies, or authentication.
156
+ - Pasting full configs into public tools without sanitizing secrets and topology.
157
+
158
+ ## See Also
159
+
160
+ - Agent: `network-config-reviewer`
161
+ - Agent: `network-troubleshooter`
162
+ - Skill: `network-config-validation`
163
+ - Skill: `network-interface-health`
@@ -0,0 +1,147 @@
1
+ ---
2
+ name: ck
3
+ description: Persistent per-project memory for Claude Code. Auto-loads project context on session start, tracks sessions with git activity, and writes to native memory. Commands run deterministic Node.js scripts — behavior is consistent across model versions.
4
+ origin: community
5
+ version: 2.0.0
6
+ author: sreedhargs89
7
+ repo: https://github.com/sreedhargs89/context-keeper
8
+ ---
9
+
10
+ # ck — Context Keeper
11
+
12
+ You are the **Context Keeper** assistant. When the user invokes any `/ck:*` command,
13
+ run the corresponding Node.js script and present its stdout to the user verbatim.
14
+ Scripts live at: `~/.claude/skills/ck/commands/` (expand `~` with `$HOME`).
15
+
16
+ ---
17
+
18
+ ## Data Layout
19
+
20
+ ```
21
+ ~/.claude/ck/
22
+ ├── projects.json ← path → {name, contextDir, lastUpdated}
23
+ └── contexts/<name>/
24
+ ├── context.json ← SOURCE OF TRUTH (structured JSON, v2)
25
+ └── CONTEXT.md ← generated view — do not hand-edit
26
+ ```
27
+
28
+ ---
29
+
30
+ ## Commands
31
+
32
+ ### `/ck:init` — Register a Project
33
+ ```bash
34
+ node "$HOME/.claude/skills/ck/commands/init.mjs"
35
+ ```
36
+ The script outputs JSON with auto-detected info. Present it as a confirmation draft:
37
+ ```
38
+ Here's what I found — confirm or edit anything:
39
+ Project: <name>
40
+ Description: <description>
41
+ Stack: <stack>
42
+ Goal: <goal>
43
+ Do-nots: <constraints or "None">
44
+ Repo: <repo or "none">
45
+ ```
46
+ Wait for user approval. Apply any edits. Then pipe confirmed JSON to save.mjs --init:
47
+ ```bash
48
+ echo '<confirmed-json>' | node "$HOME/.claude/skills/ck/commands/save.mjs" --init
49
+ ```
50
+ Confirmed JSON schema: `{"name":"...","path":"...","description":"...","stack":["..."],"goal":"...","constraints":["..."],"repo":"..." }`
51
+
52
+ ---
53
+
54
+ ### `/ck:save` — Save Session State
55
+ **This is the only command requiring LLM analysis.** Analyze the current conversation:
56
+ - `summary`: one sentence, max 10 words, what was accomplished
57
+ - `leftOff`: what was actively being worked on (specific file/feature/bug)
58
+ - `nextSteps`: ordered array of concrete next steps
59
+ - `decisions`: array of `{what, why}` for decisions made this session
60
+ - `blockers`: array of current blockers (empty array if none)
61
+ - `goal`: updated goal string **only if it changed this session**, else omit
62
+
63
+ Show a draft summary to the user: `"Session: '<summary>' — save this? (yes / edit)"`
64
+ Wait for confirmation. Then pipe to save.mjs:
65
+ ```bash
66
+ echo '<json>' | node "$HOME/.claude/skills/ck/commands/save.mjs"
67
+ ```
68
+ JSON schema (exact): `{"summary":"...","leftOff":"...","nextSteps":["..."],"decisions":[{"what":"...","why":"..."}],"blockers":["..."]}`
69
+ Display the script's stdout confirmation verbatim.
70
+
71
+ ---
72
+
73
+ ### `/ck:resume [name|number]` — Full Briefing
74
+ ```bash
75
+ node "$HOME/.claude/skills/ck/commands/resume.mjs" [arg]
76
+ ```
77
+ Display output verbatim. Then ask: "Continue from here? Or has anything changed?"
78
+ If user reports changes → run `/ck:save` immediately.
79
+
80
+ ---
81
+
82
+ ### `/ck:info [name|number]` — Quick Snapshot
83
+ ```bash
84
+ node "$HOME/.claude/skills/ck/commands/info.mjs" [arg]
85
+ ```
86
+ Display output verbatim. No follow-up question.
87
+
88
+ ---
89
+
90
+ ### `/ck:list` — Portfolio View
91
+ ```bash
92
+ node "$HOME/.claude/skills/ck/commands/list.mjs"
93
+ ```
94
+ Display output verbatim. If user replies with a number or name → run `/ck:resume`.
95
+
96
+ ---
97
+
98
+ ### `/ck:forget [name|number]` — Remove a Project
99
+ First resolve the project name (run `/ck:list` if needed).
100
+ Ask: `"This will permanently delete context for '<name>'. Are you sure? (yes/no)"`
101
+ If yes:
102
+ ```bash
103
+ node "$HOME/.claude/skills/ck/commands/forget.mjs" [name]
104
+ ```
105
+ Display confirmation verbatim.
106
+
107
+ ---
108
+
109
+ ### `/ck:migrate` — Convert v1 Data to v2
110
+ ```bash
111
+ node "$HOME/.claude/skills/ck/commands/migrate.mjs"
112
+ ```
113
+ For a dry run first:
114
+ ```bash
115
+ node "$HOME/.claude/skills/ck/commands/migrate.mjs" --dry-run
116
+ ```
117
+ Display output verbatim. Migrates all v1 CONTEXT.md + meta.json files to v2 context.json.
118
+ Originals are backed up as `meta.json.v1-backup` — nothing is deleted.
119
+
120
+ ---
121
+
122
+ ## SessionStart Hook
123
+
124
+ The hook at `~/.claude/skills/ck/hooks/session-start.mjs` must be registered in
125
+ `~/.claude/settings.json` to auto-load project context on session start:
126
+
127
+ ```json
128
+ {
129
+ "hooks": {
130
+ "SessionStart": [
131
+ { "hooks": [{ "type": "command", "command": "node \"~/.claude/skills/ck/hooks/session-start.mjs\"" }] }
132
+ ]
133
+ }
134
+ }
135
+ ```
136
+
137
+ The hook injects ~100 tokens per session (compact 5-line summary). It also detects
138
+ unsaved sessions, git activity since last save, and goal mismatches vs CLAUDE.md.
139
+
140
+ ---
141
+
142
+ ## Rules
143
+ - Always expand `~` as `$HOME` in Bash calls.
144
+ - Commands are case-insensitive: `/CK:SAVE`, `/ck:save`, `/Ck:Save` all work.
145
+ - If a script exits with code 1, display its stdout as an error message.
146
+ - Never edit `context.json` or `CONTEXT.md` directly — always use the scripts.
147
+ - If `projects.json` is malformed, tell the user and offer to reset it to `{}`.
@@ -0,0 +1,44 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ck — Context Keeper v2
4
+ * forget.mjs — remove a project's context and registry entry
5
+ *
6
+ * Usage: node forget.mjs [name|number]
7
+ * stdout: confirmation or error
8
+ * exit 0: success exit 1: not found
9
+ *
10
+ * Note: SKILL.md instructs Claude to ask "Are you sure?" before calling this script.
11
+ * This script is the "do it" step — no confirmation prompt here.
12
+ */
13
+
14
+ import { rmSync } from 'fs';
15
+ import { resolve } from 'path';
16
+ import { resolveContext, readProjects, writeProjects, CONTEXTS_DIR } from './shared.mjs';
17
+
18
+ const arg = process.argv[2];
19
+ const cwd = process.env.PWD || process.cwd();
20
+
21
+ const resolved = resolveContext(arg, cwd);
22
+ if (!resolved) {
23
+ const hint = arg ? `No project matching "${arg}".` : 'This directory is not registered.';
24
+ console.log(`${hint}`);
25
+ process.exit(1);
26
+ }
27
+
28
+ const { name, contextDir, projectPath } = resolved;
29
+
30
+ // Remove context directory
31
+ const contextDirPath = resolve(CONTEXTS_DIR, contextDir);
32
+ try {
33
+ rmSync(contextDirPath, { recursive: true, force: true });
34
+ } catch (e) {
35
+ console.log(`ck: could not remove context directory — ${e.message}`);
36
+ process.exit(1);
37
+ }
38
+
39
+ // Remove from projects.json
40
+ const projects = readProjects();
41
+ delete projects[projectPath];
42
+ writeProjects(projects);
43
+
44
+ console.log(`✓ Context for '${name}' removed.`);
@@ -0,0 +1,24 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ck — Context Keeper v2
4
+ * info.mjs — quick read-only context snapshot
5
+ *
6
+ * Usage: node info.mjs [name|number]
7
+ * stdout: compact info block
8
+ * exit 0: success exit 1: not found
9
+ */
10
+
11
+ import { resolveContext, renderInfoBlock } from './shared.mjs';
12
+
13
+ const arg = process.argv[2];
14
+ const cwd = process.env.PWD || process.cwd();
15
+
16
+ const resolved = resolveContext(arg, cwd);
17
+ if (!resolved) {
18
+ const hint = arg ? `No project matching "${arg}".` : 'This directory is not registered.';
19
+ console.log(`${hint} Run /ck:init to register it.`);
20
+ process.exit(1);
21
+ }
22
+
23
+ console.log('');
24
+ console.log(renderInfoBlock(resolved.context));
@@ -0,0 +1,143 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ck — Context Keeper v2
4
+ * init.mjs — auto-detect project info and output JSON for Claude to confirm
5
+ *
6
+ * Usage: node init.mjs
7
+ * stdout: JSON with auto-detected project info
8
+ * exit 0: success exit 1: error
9
+ */
10
+
11
+ import { readFileSync, existsSync } from 'fs';
12
+ import { resolve, basename } from 'path';
13
+ import { readProjects } from './shared.mjs';
14
+
15
+ const cwd = process.env.PWD || process.cwd();
16
+ const projects = readProjects();
17
+
18
+ const output = {
19
+ path: cwd,
20
+ name: null,
21
+ description: null,
22
+ stack: [],
23
+ goal: null,
24
+ constraints: [],
25
+ repo: null,
26
+ alreadyRegistered: !!projects[cwd],
27
+ };
28
+
29
+ function readFile(filename) {
30
+ const p = resolve(cwd, filename);
31
+ if (!existsSync(p)) return null;
32
+ try { return readFileSync(p, 'utf8'); } catch { return null; }
33
+ }
34
+
35
+ function extractSection(md, heading) {
36
+ const re = new RegExp(`## ${heading}\\n([\\s\\S]*?)(?=\\n## |$)`);
37
+ const m = md.match(re);
38
+ return m ? m[1].trim() : null;
39
+ }
40
+
41
+ // ── package.json ──────────────────────────────────────────────────────────────
42
+ const pkg = readFile('package.json');
43
+ if (pkg) {
44
+ try {
45
+ const parsed = JSON.parse(pkg);
46
+ if (parsed.name && !output.name) output.name = parsed.name;
47
+ if (parsed.description && !output.description) output.description = parsed.description;
48
+
49
+ // Detect stack from dependencies
50
+ const deps = Object.keys({ ...(parsed.dependencies || {}), ...(parsed.devDependencies || {}) });
51
+ const stackMap = {
52
+ next: 'Next.js', react: 'React', vue: 'Vue', svelte: 'Svelte', astro: 'Astro',
53
+ express: 'Express', fastify: 'Fastify', hono: 'Hono', nestjs: 'NestJS',
54
+ typescript: 'TypeScript', prisma: 'Prisma', drizzle: 'Drizzle',
55
+ '@neondatabase/serverless': 'Neon', '@upstash/redis': 'Upstash Redis',
56
+ '@clerk/nextjs': 'Clerk', stripe: 'Stripe', tailwindcss: 'Tailwind CSS',
57
+ };
58
+ for (const [dep, label] of Object.entries(stackMap)) {
59
+ if (deps.includes(dep) && !output.stack.includes(label)) {
60
+ output.stack.push(label);
61
+ }
62
+ }
63
+ if (deps.includes('typescript') || existsSync(resolve(cwd, 'tsconfig.json'))) {
64
+ if (!output.stack.includes('TypeScript')) output.stack.push('TypeScript');
65
+ }
66
+ } catch { /* malformed package.json */ }
67
+ }
68
+
69
+ // ── go.mod ────────────────────────────────────────────────────────────────────
70
+ const goMod = readFile('go.mod');
71
+ if (goMod) {
72
+ if (!output.stack.includes('Go')) output.stack.push('Go');
73
+ const modName = goMod.match(/^module\s+(\S+)/m)?.[1];
74
+ if (modName && !output.name) output.name = modName.split('/').pop();
75
+ }
76
+
77
+ // ── Cargo.toml ────────────────────────────────────────────────────────────────
78
+ const cargo = readFile('Cargo.toml');
79
+ if (cargo) {
80
+ if (!output.stack.includes('Rust')) output.stack.push('Rust');
81
+ const crateName = cargo.match(/^name\s*=\s*"(.+?)"/m)?.[1];
82
+ if (crateName && !output.name) output.name = crateName;
83
+ }
84
+
85
+ // ── pyproject.toml ────────────────────────────────────────────────────────────
86
+ const pyproject = readFile('pyproject.toml');
87
+ if (pyproject) {
88
+ if (!output.stack.includes('Python')) output.stack.push('Python');
89
+ const pyName = pyproject.match(/^name\s*=\s*"(.+?)"/m)?.[1];
90
+ if (pyName && !output.name) output.name = pyName;
91
+ }
92
+
93
+ // ── .git/config (repo URL) ────────────────────────────────────────────────────
94
+ const gitConfig = readFile('.git/config');
95
+ if (gitConfig) {
96
+ const repoMatch = gitConfig.match(/url\s*=\s*(.+)/);
97
+ if (repoMatch) output.repo = repoMatch[1].trim();
98
+ }
99
+
100
+ // ── CLAUDE.md ─────────────────────────────────────────────────────────────────
101
+ const claudeMd = readFile('CLAUDE.md');
102
+ if (claudeMd) {
103
+ const goal = extractSection(claudeMd, 'Current Goal');
104
+ if (goal && !output.goal) output.goal = goal.split('\n')[0].trim();
105
+
106
+ const doNot = extractSection(claudeMd, 'Do Not Do');
107
+ if (doNot) {
108
+ const bullets = doNot.split('\n')
109
+ .filter(l => /^[-*]\s+/.test(l))
110
+ .map(l => l.replace(/^[-*]\s+/, '').trim());
111
+ output.constraints = bullets;
112
+ }
113
+
114
+ const stack = extractSection(claudeMd, 'Tech Stack');
115
+ if (stack && output.stack.length === 0) {
116
+ output.stack = stack.split(/[,\n]/).map(s => s.replace(/^[-*]\s+/, '').trim()).filter(Boolean);
117
+ }
118
+
119
+ // Description from first section or "What This Is"
120
+ const whatItIs = extractSection(claudeMd, 'What This Is') || extractSection(claudeMd, 'About');
121
+ if (whatItIs && !output.description) output.description = whatItIs.split('\n')[0].trim();
122
+ }
123
+
124
+ // ── README.md (description fallback) ─────────────────────────────────────────
125
+ const readme = readFile('README.md');
126
+ if (readme && !output.description) {
127
+ // First non-header, non-badge, non-empty paragraph
128
+ const lines = readme.split('\n');
129
+ for (const line of lines) {
130
+ const trimmed = line.trim();
131
+ if (trimmed && !trimmed.startsWith('#') && !trimmed.startsWith('!') && !trimmed.startsWith('>') && !trimmed.startsWith('[') && trimmed !== '---' && trimmed !== '___') {
132
+ output.description = trimmed.slice(0, 120);
133
+ break;
134
+ }
135
+ }
136
+ }
137
+
138
+ // ── Name fallback: directory name ─────────────────────────────────────────────
139
+ if (!output.name) {
140
+ output.name = basename(cwd).toLowerCase().replace(/\s+/g, '-');
141
+ }
142
+
143
+ console.log(JSON.stringify(output, null, 2));
@@ -0,0 +1,40 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * ck — Context Keeper v2
4
+ * list.mjs — portfolio view of all registered projects
5
+ *
6
+ * Usage: node list.mjs
7
+ * stdout: ASCII table of all projects + prompt to resume
8
+ * exit 0: success exit 1: no projects
9
+ */
10
+
11
+ import { readProjects, loadContext, today, renderListTable } from './shared.mjs';
12
+
13
+ const cwd = process.env.PWD || process.cwd();
14
+ const projects = readProjects();
15
+ const entries = Object.entries(projects);
16
+
17
+ if (entries.length === 0) {
18
+ console.log('No projects registered. Run /ck:init to get started.');
19
+ process.exit(1);
20
+ }
21
+
22
+ // Build enriched list sorted alphabetically by contextDir
23
+ const enriched = entries
24
+ .map(([path, info]) => {
25
+ const context = loadContext(info.contextDir);
26
+ return {
27
+ name: info.name,
28
+ contextDir: info.contextDir,
29
+ path,
30
+ context,
31
+ lastUpdated: info.lastUpdated,
32
+ };
33
+ })
34
+ .sort((a, b) => a.contextDir.localeCompare(b.contextDir));
35
+
36
+ const table = renderListTable(enriched, cwd, today());
37
+ console.log('');
38
+ console.log(table);
39
+ console.log('');
40
+ console.log('Resume which? (number or name)');