@oriro/orirocli 0.1.11 → 0.1.12

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 (1263) hide show
  1. package/ATTRIBUTION.md +53 -53
  2. package/LICENSE +21 -21
  3. package/README.md +2 -7
  4. package/dist/cli.js +402 -40
  5. package/package.json +64 -64
  6. package/skills/1password/SKILL.md +118 -118
  7. package/skills/1password/references/cli-examples.md +29 -29
  8. package/skills/1password/references/get-started.md +21 -21
  9. package/skills/21stdev/SKILL.md +64 -64
  10. package/skills/algorithmic-art/LICENSE +21 -21
  11. package/skills/algorithmic-art/SKILL.md +446 -446
  12. package/skills/algorithmic-art/templates/generator_template.js +223 -223
  13. package/skills/algorithmic-art/templates/viewer.html +598 -598
  14. package/skills/apple-notes/SKILL.md +81 -81
  15. package/skills/apple-reminders/SKILL.md +122 -122
  16. package/skills/bear-notes/SKILL.md +111 -111
  17. package/skills/blogwatcher/SKILL.md +73 -73
  18. package/skills/blucli/SKILL.md +51 -51
  19. package/skills/brand-guidelines/LICENSE +21 -21
  20. package/skills/brand-guidelines/SKILL.md +76 -76
  21. package/skills/business/biz-analysis/LICENSE +21 -21
  22. package/skills/business/biz-analysis/SKILL.md +103 -103
  23. package/skills/business/biz-corporate-strategy/LICENSE +21 -21
  24. package/skills/business/biz-corporate-strategy/SKILL.md +76 -76
  25. package/skills/business/biz-customer-success/LICENSE +21 -21
  26. package/skills/business/biz-customer-success/SKILL.md +55 -55
  27. package/skills/business/biz-entrepreneurship/LICENSE +21 -21
  28. package/skills/business/biz-entrepreneurship/SKILL.md +72 -72
  29. package/skills/business/biz-hr/LICENSE +21 -21
  30. package/skills/business/biz-hr/SKILL.md +67 -67
  31. package/skills/business/biz-international/LICENSE +21 -21
  32. package/skills/business/biz-international/SKILL.md +51 -51
  33. package/skills/business/biz-leadership/LICENSE +21 -21
  34. package/skills/business/biz-leadership/SKILL.md +106 -106
  35. package/skills/business/biz-marketing-strategy/LICENSE +21 -21
  36. package/skills/business/biz-marketing-strategy/SKILL.md +119 -119
  37. package/skills/business/biz-negotiation/LICENSE +21 -21
  38. package/skills/business/biz-negotiation/SKILL.md +152 -152
  39. package/skills/business/biz-operations/LICENSE +21 -21
  40. package/skills/business/biz-operations/SKILL.md +74 -74
  41. package/skills/business/biz-project/LICENSE +21 -21
  42. package/skills/business/biz-project/SKILL.md +203 -203
  43. package/skills/business/biz-risk/LICENSE +21 -21
  44. package/skills/business/biz-risk/SKILL.md +85 -85
  45. package/skills/business/biz-sales/LICENSE +21 -21
  46. package/skills/business/biz-sales/SKILL.md +92 -92
  47. package/skills/business/biz-startup-ops/LICENSE +21 -21
  48. package/skills/business/biz-startup-ops/SKILL.md +70 -70
  49. package/skills/business/biz-strategy/LICENSE +21 -21
  50. package/skills/business/biz-strategy/SKILL.md +233 -233
  51. package/skills/business/biz-supply-chain-advanced/LICENSE +21 -21
  52. package/skills/business/biz-supply-chain-advanced/SKILL.md +68 -68
  53. package/skills/business/fin-chartered-exams/LICENSE +21 -21
  54. package/skills/business/fin-chartered-exams/SKILL.md +69 -69
  55. package/skills/camsnap/SKILL.md +49 -49
  56. package/skills/canvas/SKILL.md +82 -82
  57. package/skills/canvas-design/LICENSE +21 -21
  58. package/skills/canvas-design/SKILL.md +140 -140
  59. package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -93
  60. package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -93
  61. package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -93
  62. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -93
  63. package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -93
  64. package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -93
  65. package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -94
  66. package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -93
  67. package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -93
  68. package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -93
  69. package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -93
  70. package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -93
  71. package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -93
  72. package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -93
  73. package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -93
  74. package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -93
  75. package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -93
  76. package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -93
  77. package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -93
  78. package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -93
  79. package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -93
  80. package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -93
  81. package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -93
  82. package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -93
  83. package/skills/coding-agent/SKILL.md +146 -146
  84. package/skills/communication/comm-business-writing/LICENSE +21 -21
  85. package/skills/communication/comm-business-writing/SKILL.md +67 -67
  86. package/skills/communication/comm-cross-cultural/LICENSE +21 -21
  87. package/skills/communication/comm-cross-cultural/SKILL.md +88 -88
  88. package/skills/communication/comm-journalism/LICENSE +21 -21
  89. package/skills/communication/comm-journalism/SKILL.md +81 -81
  90. package/skills/communication/comm-linguistics/LICENSE +21 -21
  91. package/skills/communication/comm-linguistics/SKILL.md +82 -82
  92. package/skills/communication/comm-negotiation/LICENSE +21 -21
  93. package/skills/communication/comm-negotiation/SKILL.md +120 -120
  94. package/skills/communication/comm-presentations/LICENSE +21 -21
  95. package/skills/communication/comm-presentations/SKILL.md +93 -93
  96. package/skills/communication/comm-public-speaking/LICENSE +21 -21
  97. package/skills/communication/comm-public-speaking/SKILL.md +68 -68
  98. package/skills/communication/comm-writing/LICENSE +21 -21
  99. package/skills/communication/comm-writing/SKILL.md +69 -69
  100. package/skills/craft/ai-engineering/LICENSE +21 -21
  101. package/skills/craft/ai-engineering/SKILL.md +828 -828
  102. package/skills/craft/app-builder-guide/LICENSE +21 -21
  103. package/skills/craft/app-builder-guide/SKILL.md +332 -332
  104. package/skills/craft/become-an-ai-engineer-26/CONTRIBUTING.md +46 -46
  105. package/skills/craft/become-an-ai-engineer-26/LICENSE +21 -21
  106. package/skills/craft/become-an-ai-engineer-26/README.md +270 -270
  107. package/skills/craft/become-an-ai-engineer-26/SKILL.md +667 -667
  108. package/skills/craft/become-an-ai-engineer-26/community/BUILDS.md +13 -13
  109. package/skills/craft/become-an-ai-engineer-26/community/DISCUSSIONS.md +8 -8
  110. package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/README.md +14 -14
  111. package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/project/TEMPLATE.md +33 -33
  112. package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/README.md +25 -25
  113. package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/code/raw_loop.py +126 -126
  114. package/skills/craft/become-an-ai-engineer-26/phases/phase-2-architecture/README.md +17 -17
  115. package/skills/craft/become-an-ai-engineer-26/phases/phase-3-harness/README.md +17 -17
  116. package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/README.md +21 -21
  117. package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/code/.github/workflows/eval.yml +40 -40
  118. package/skills/craft/become-an-ai-engineer-26/phases/phase-5-production/README.md +16 -16
  119. package/skills/craft/become-an-ai-engineer-26/projects/1-mobile-app-slm/README.md +11 -11
  120. package/skills/craft/become-an-ai-engineer-26/projects/2-self-improving-coder/README.md +11 -11
  121. package/skills/craft/become-an-ai-engineer-26/projects/3-video-editor-agent/README.md +11 -11
  122. package/skills/craft/become-an-ai-engineer-26/projects/4-personal-life-os/README.md +12 -12
  123. package/skills/craft/become-an-ai-engineer-26/projects/5-enterprise-workflow/README.md +12 -12
  124. package/skills/craft/become-an-ai-engineer-26/references/benchmark-numbers.md +41 -41
  125. package/skills/craft/become-an-ai-engineer-26/references/mhc-stable-training.md +73 -73
  126. package/skills/craft/become-an-ai-engineer-26/references/stack-decisions.md +37 -37
  127. package/skills/craft/become-an-ai-engineer-26/references/yarn-context-extension.md +123 -123
  128. package/skills/craft/codex-result-handling/LICENSE +21 -21
  129. package/skills/craft/codex-result-handling/SKILL.md +26 -26
  130. package/skills/craft/debug-and-build-methodology/LICENSE +21 -21
  131. package/skills/craft/debug-and-build-methodology/SKILL.md +432 -432
  132. package/skills/craft/design/LICENSE +21 -21
  133. package/skills/craft/design/SKILL.md +274 -274
  134. package/skills/craft/dev/LICENSE +21 -21
  135. package/skills/craft/dev/SKILL.md +12 -12
  136. package/skills/craft/dev/release.md +85 -85
  137. package/skills/craft/dev/roll.md +50 -50
  138. package/skills/craft/doc-coauthoring/LICENSE +21 -21
  139. package/skills/craft/doc-coauthoring/SKILL.md +397 -397
  140. package/skills/craft/focus/LICENSE +21 -21
  141. package/skills/craft/focus/SKILL.md +432 -432
  142. package/skills/craft/focus/UPSTREAM_README.md +233 -233
  143. package/skills/craft/gh/LICENSE +21 -21
  144. package/skills/craft/gh/SKILL.md +84 -84
  145. package/skills/craft/gh-skill/LICENSE +21 -21
  146. package/skills/craft/gh-skill/SKILL.md +121 -121
  147. package/skills/craft/godmode/LICENSE +21 -21
  148. package/skills/craft/godmode/SKILL.md +87 -87
  149. package/skills/craft/godmode/references/android-launch.md +680 -680
  150. package/skills/craft/godmode/references/data-gcp.md +1038 -1038
  151. package/skills/craft/godmode/references/expo-eas.md +816 -816
  152. package/skills/craft/godmode/references/ios-launch.md +734 -734
  153. package/skills/craft/google-ai-latest/LICENSE +21 -21
  154. package/skills/craft/google-ai-latest/SKILL.md +682 -682
  155. package/skills/craft/gpt-5-4-prompting/LICENSE +21 -21
  156. package/skills/craft/gpt-5-4-prompting/SKILL.md +63 -63
  157. package/skills/craft/gpt-5-4-prompting/references/codex-prompt-antipatterns.md +101 -101
  158. package/skills/craft/gpt-5-4-prompting/references/codex-prompt-recipes.md +150 -150
  159. package/skills/craft/gpt-5-4-prompting/references/prompt-blocks.md +172 -172
  160. package/skills/craft/grill-me/LICENSE +21 -21
  161. package/skills/craft/grill-me/SKILL.md +13 -13
  162. package/skills/craft/idea-to-deploy/LICENSE +21 -21
  163. package/skills/craft/idea-to-deploy/SKILL.md +292 -292
  164. package/skills/craft/idea-to-deploy/references/auth-playbook.md +195 -195
  165. package/skills/craft/idea-to-deploy/references/gcp-deployment.md +268 -268
  166. package/skills/craft/idea-to-deploy/references/stack-selection.md +117 -117
  167. package/skills/craft/image-generation-engineer/LICENSE +21 -21
  168. package/skills/craft/image-generation-engineer/SKILL.md +183 -183
  169. package/skills/craft/image-generation-engineer/references/architectures.md +260 -260
  170. package/skills/craft/image-generation-engineer/references/foundations.md +107 -107
  171. package/skills/craft/image-generation-engineer/references/inference-and-serving.md +253 -253
  172. package/skills/craft/image-generation-engineer/references/training.md +149 -149
  173. package/skills/craft/marketing/LICENSE +21 -21
  174. package/skills/craft/marketing/SKILL.md +1954 -1954
  175. package/skills/craft/master-architect/LICENSE +21 -21
  176. package/skills/craft/master-architect/SKILL.md +361 -361
  177. package/skills/craft/master-architect/references/ai-ml.md +317 -317
  178. package/skills/craft/master-architect/references/architecture.md +268 -268
  179. package/skills/craft/master-architect/references/auth-playbook.md +195 -195
  180. package/skills/craft/master-architect/references/cloud.md +323 -323
  181. package/skills/craft/master-architect/references/cyber.md +839 -839
  182. package/skills/craft/master-architect/references/data-eng.md +366 -366
  183. package/skills/craft/master-architect/references/devops.md +550 -550
  184. package/skills/craft/master-architect/references/gcp-deployment.md +268 -268
  185. package/skills/craft/master-architect/references/languages.md +748 -748
  186. package/skills/craft/master-architect/references/legacy.md +240 -240
  187. package/skills/craft/master-architect/references/mobile.md +447 -447
  188. package/skills/craft/master-architect/references/patterns.md +451 -451
  189. package/skills/craft/master-architect/references/saas-patterns.md +379 -379
  190. package/skills/craft/master-architect/references/sdlc.md +349 -349
  191. package/skills/craft/master-architect/references/stack-selection.md +117 -117
  192. package/skills/craft/oriro-ui-2026/LICENSE +21 -21
  193. package/skills/craft/oriro-ui-2026/SKILL.md +329 -329
  194. package/skills/craft/playwright-cli/LICENSE +21 -21
  195. package/skills/craft/playwright-cli/SKILL.md +393 -393
  196. package/skills/craft/playwright-cli/references/element-attributes.md +23 -23
  197. package/skills/craft/playwright-cli/references/playwright-tests.md +39 -39
  198. package/skills/craft/playwright-cli/references/request-mocking.md +87 -87
  199. package/skills/craft/playwright-cli/references/running-code.md +240 -240
  200. package/skills/craft/playwright-cli/references/session-management.md +226 -226
  201. package/skills/craft/playwright-cli/references/spec-driven-testing.md +312 -312
  202. package/skills/craft/playwright-cli/references/storage-state.md +275 -275
  203. package/skills/craft/playwright-cli/references/test-generation.md +134 -134
  204. package/skills/craft/playwright-cli/references/tracing.md +142 -142
  205. package/skills/craft/playwright-cli/references/video-recording.md +150 -150
  206. package/skills/craft/remotion-best-practices/LICENSE +21 -21
  207. package/skills/craft/remotion-best-practices/SKILL.md +345 -345
  208. package/skills/craft/remotion-best-practices/rules/3d.md +86 -86
  209. package/skills/craft/remotion-best-practices/rules/assets/charts-bar-chart.tsx +165 -165
  210. package/skills/craft/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +89 -89
  211. package/skills/craft/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +101 -101
  212. package/skills/craft/remotion-best-practices/rules/audio-visualization.md +195 -195
  213. package/skills/craft/remotion-best-practices/rules/audio.md +167 -167
  214. package/skills/craft/remotion-best-practices/rules/calculate-metadata.md +118 -118
  215. package/skills/craft/remotion-best-practices/rules/compositions.md +132 -132
  216. package/skills/craft/remotion-best-practices/rules/display-captions.md +176 -176
  217. package/skills/craft/remotion-best-practices/rules/ffmpeg.md +34 -34
  218. package/skills/craft/remotion-best-practices/rules/get-audio-duration.md +58 -58
  219. package/skills/craft/remotion-best-practices/rules/get-video-dimensions.md +68 -68
  220. package/skills/craft/remotion-best-practices/rules/get-video-duration.md +60 -60
  221. package/skills/craft/remotion-best-practices/rules/gifs.md +135 -135
  222. package/skills/craft/remotion-best-practices/rules/google-fonts.md +72 -72
  223. package/skills/craft/remotion-best-practices/rules/html-in-canvas.md +122 -122
  224. package/skills/craft/remotion-best-practices/rules/images.md +67 -67
  225. package/skills/craft/remotion-best-practices/rules/import-srt-captions.md +69 -69
  226. package/skills/craft/remotion-best-practices/rules/light-leaks.md +73 -73
  227. package/skills/craft/remotion-best-practices/rules/local-fonts.md +65 -65
  228. package/skills/craft/remotion-best-practices/rules/lottie.md +67 -67
  229. package/skills/craft/remotion-best-practices/rules/maplibre.md +441 -441
  230. package/skills/craft/remotion-best-practices/rules/measuring-dom-nodes.md +34 -34
  231. package/skills/craft/remotion-best-practices/rules/measuring-text.md +140 -140
  232. package/skills/craft/remotion-best-practices/rules/parameters.md +109 -109
  233. package/skills/craft/remotion-best-practices/rules/sequencing.md +144 -144
  234. package/skills/craft/remotion-best-practices/rules/sfx.md +30 -30
  235. package/skills/craft/remotion-best-practices/rules/silence-detection.md +73 -73
  236. package/skills/craft/remotion-best-practices/rules/subtitles.md +36 -36
  237. package/skills/craft/remotion-best-practices/rules/tailwind.md +11 -11
  238. package/skills/craft/remotion-best-practices/rules/text-animations.md +20 -20
  239. package/skills/craft/remotion-best-practices/rules/timing.md +130 -130
  240. package/skills/craft/remotion-best-practices/rules/transcribe-captions.md +70 -70
  241. package/skills/craft/remotion-best-practices/rules/transitions.md +193 -193
  242. package/skills/craft/remotion-best-practices/rules/transparent-videos.md +102 -102
  243. package/skills/craft/remotion-best-practices/rules/trimming.md +51 -51
  244. package/skills/craft/remotion-best-practices/rules/videos.md +169 -169
  245. package/skills/craft/remotion-best-practices/rules/voiceover.md +94 -94
  246. package/skills/craft/supabase-postgres-best-practices/CHANGELOG.md +25 -25
  247. package/skills/craft/supabase-postgres-best-practices/LICENSE +21 -21
  248. package/skills/craft/supabase-postgres-best-practices/SKILL.md +69 -69
  249. package/skills/craft/supabase-postgres-best-practices/references/_contributing.md +166 -166
  250. package/skills/craft/supabase-postgres-best-practices/references/_sections.md +47 -47
  251. package/skills/craft/supabase-postgres-best-practices/references/_template.md +34 -34
  252. package/skills/craft/supabase-postgres-best-practices/references/advanced-full-text-search.md +55 -55
  253. package/skills/craft/supabase-postgres-best-practices/references/advanced-jsonb-indexing.md +49 -49
  254. package/skills/craft/supabase-postgres-best-practices/references/conn-idle-timeout.md +46 -46
  255. package/skills/craft/supabase-postgres-best-practices/references/conn-limits.md +44 -44
  256. package/skills/craft/supabase-postgres-best-practices/references/conn-pooling.md +41 -41
  257. package/skills/craft/supabase-postgres-best-practices/references/conn-prepared-statements.md +46 -46
  258. package/skills/craft/supabase-postgres-best-practices/references/data-batch-inserts.md +54 -54
  259. package/skills/craft/supabase-postgres-best-practices/references/data-n-plus-one.md +53 -53
  260. package/skills/craft/supabase-postgres-best-practices/references/data-pagination.md +50 -50
  261. package/skills/craft/supabase-postgres-best-practices/references/data-upsert.md +50 -50
  262. package/skills/craft/supabase-postgres-best-practices/references/lock-advisory.md +56 -56
  263. package/skills/craft/supabase-postgres-best-practices/references/lock-deadlock-prevention.md +68 -68
  264. package/skills/craft/supabase-postgres-best-practices/references/lock-short-transactions.md +50 -50
  265. package/skills/craft/supabase-postgres-best-practices/references/lock-skip-locked.md +54 -54
  266. package/skills/craft/supabase-postgres-best-practices/references/monitor-explain-analyze.md +45 -45
  267. package/skills/craft/supabase-postgres-best-practices/references/monitor-pg-stat-statements.md +55 -55
  268. package/skills/craft/supabase-postgres-best-practices/references/monitor-vacuum-analyze.md +55 -55
  269. package/skills/craft/supabase-postgres-best-practices/references/query-composite-indexes.md +44 -44
  270. package/skills/craft/supabase-postgres-best-practices/references/query-covering-indexes.md +40 -40
  271. package/skills/craft/supabase-postgres-best-practices/references/query-index-types.md +48 -48
  272. package/skills/craft/supabase-postgres-best-practices/references/query-missing-indexes.md +43 -43
  273. package/skills/craft/supabase-postgres-best-practices/references/query-partial-indexes.md +45 -45
  274. package/skills/craft/supabase-postgres-best-practices/references/schema-constraints.md +80 -80
  275. package/skills/craft/supabase-postgres-best-practices/references/schema-data-types.md +46 -46
  276. package/skills/craft/supabase-postgres-best-practices/references/schema-foreign-key-indexes.md +59 -59
  277. package/skills/craft/supabase-postgres-best-practices/references/schema-lowercase-identifiers.md +55 -55
  278. package/skills/craft/supabase-postgres-best-practices/references/schema-partitioning.md +55 -55
  279. package/skills/craft/supabase-postgres-best-practices/references/schema-primary-keys.md +61 -61
  280. package/skills/craft/supabase-postgres-best-practices/references/security-privileges.md +54 -54
  281. package/skills/craft/supabase-postgres-best-practices/references/security-rls-basics.md +50 -50
  282. package/skills/craft/supabase-postgres-best-practices/references/security-rls-performance.md +63 -63
  283. package/skills/craft/uipm-banner-design/LICENSE +21 -21
  284. package/skills/craft/uipm-banner-design/SKILL.md +201 -201
  285. package/skills/craft/uipm-banner-design/references/banner-sizes-and-styles.md +129 -129
  286. package/skills/craft/uipm-brand/LICENSE +21 -21
  287. package/skills/craft/uipm-brand/SKILL.md +104 -104
  288. package/skills/craft/uipm-brand/references/approval-checklist.md +184 -184
  289. package/skills/craft/uipm-brand/references/asset-organization.md +167 -167
  290. package/skills/craft/uipm-brand/references/brand-guideline-template.md +161 -161
  291. package/skills/craft/uipm-brand/references/color-palette-management.md +203 -203
  292. package/skills/craft/uipm-brand/references/consistency-checklist.md +105 -105
  293. package/skills/craft/uipm-brand/references/logo-usage-rules.md +204 -204
  294. package/skills/craft/uipm-brand/references/messaging-framework.md +91 -91
  295. package/skills/craft/uipm-brand/references/typography-specifications.md +265 -265
  296. package/skills/craft/uipm-brand/references/update.md +128 -128
  297. package/skills/craft/uipm-brand/references/visual-identity.md +109 -109
  298. package/skills/craft/uipm-brand/references/voice-framework.md +99 -99
  299. package/skills/craft/uipm-brand/scripts/extract-colors.cjs +333 -333
  300. package/skills/craft/uipm-brand/scripts/inject-brand-context.cjs +324 -324
  301. package/skills/craft/uipm-brand/scripts/sync-brand-to-tokens.cjs +269 -269
  302. package/skills/craft/uipm-brand/scripts/validate-asset.cjs +361 -361
  303. package/skills/craft/uipm-brand/templates/brand-guidelines-starter.md +280 -280
  304. package/skills/craft/uipm-design/LICENSE +21 -21
  305. package/skills/craft/uipm-design/SKILL.md +305 -305
  306. package/skills/craft/uipm-design/data/cip/deliverables.csv +50 -50
  307. package/skills/craft/uipm-design/data/cip/industries.csv +20 -20
  308. package/skills/craft/uipm-design/data/cip/mockup-contexts.csv +20 -20
  309. package/skills/craft/uipm-design/data/cip/styles.csv +20 -20
  310. package/skills/craft/uipm-design/data/icon/styles.csv +16 -16
  311. package/skills/craft/uipm-design/data/logo/colors.csv +56 -56
  312. package/skills/craft/uipm-design/data/logo/industries.csv +56 -56
  313. package/skills/craft/uipm-design/data/logo/styles.csv +56 -56
  314. package/skills/craft/uipm-design/references/banner-sizes-and-styles.md +129 -129
  315. package/skills/craft/uipm-design/references/cip-deliverable-guide.md +111 -111
  316. package/skills/craft/uipm-design/references/cip-design.md +121 -121
  317. package/skills/craft/uipm-design/references/cip-prompt-engineering.md +94 -94
  318. package/skills/craft/uipm-design/references/cip-style-guide.md +76 -76
  319. package/skills/craft/uipm-design/references/design-routing.md +226 -226
  320. package/skills/craft/uipm-design/references/icon-design.md +122 -122
  321. package/skills/craft/uipm-design/references/logo-color-psychology.md +113 -113
  322. package/skills/craft/uipm-design/references/logo-design.md +92 -92
  323. package/skills/craft/uipm-design/references/logo-prompt-engineering.md +176 -176
  324. package/skills/craft/uipm-design/references/logo-style-guide.md +129 -129
  325. package/skills/craft/uipm-design/references/slides-copywriting-formulas.md +92 -92
  326. package/skills/craft/uipm-design/references/slides-create.md +5 -5
  327. package/skills/craft/uipm-design/references/slides-html-template.md +374 -374
  328. package/skills/craft/uipm-design/references/slides-layout-patterns.md +155 -155
  329. package/skills/craft/uipm-design/references/slides-strategies.md +97 -97
  330. package/skills/craft/uipm-design/references/slides.md +42 -42
  331. package/skills/craft/uipm-design/references/social-photos-design.md +353 -353
  332. package/skills/craft/uipm-design/scripts/cip/core.py +215 -215
  333. package/skills/craft/uipm-design/scripts/cip/generate.py +484 -484
  334. package/skills/craft/uipm-design/scripts/cip/render-html.py +424 -424
  335. package/skills/craft/uipm-design/scripts/cip/search.py +127 -127
  336. package/skills/craft/uipm-design/scripts/icon/generate.py +487 -487
  337. package/skills/craft/uipm-design/scripts/logo/core.py +175 -175
  338. package/skills/craft/uipm-design/scripts/logo/generate.py +362 -362
  339. package/skills/craft/uipm-design/scripts/logo/search.py +114 -114
  340. package/skills/craft/uipm-design-system/LICENSE +21 -21
  341. package/skills/craft/uipm-design-system/SKILL.md +255 -255
  342. package/skills/craft/uipm-design-system/data/slide-backgrounds.csv +11 -11
  343. package/skills/craft/uipm-design-system/data/slide-charts.csv +26 -26
  344. package/skills/craft/uipm-design-system/data/slide-color-logic.csv +14 -14
  345. package/skills/craft/uipm-design-system/data/slide-copy.csv +26 -26
  346. package/skills/craft/uipm-design-system/data/slide-layout-logic.csv +16 -16
  347. package/skills/craft/uipm-design-system/data/slide-layouts.csv +26 -26
  348. package/skills/craft/uipm-design-system/data/slide-strategies.csv +16 -16
  349. package/skills/craft/uipm-design-system/data/slide-typography.csv +15 -15
  350. package/skills/craft/uipm-design-system/references/component-specs.md +236 -236
  351. package/skills/craft/uipm-design-system/references/component-tokens.md +214 -214
  352. package/skills/craft/uipm-design-system/references/primitive-tokens.md +199 -199
  353. package/skills/craft/uipm-design-system/references/semantic-tokens.md +215 -215
  354. package/skills/craft/uipm-design-system/references/states-and-variants.md +243 -243
  355. package/skills/craft/uipm-design-system/references/tailwind-integration.md +257 -257
  356. package/skills/craft/uipm-design-system/references/token-architecture.md +226 -226
  357. package/skills/craft/uipm-design-system/scripts/embed-tokens.cjs +97 -97
  358. package/skills/craft/uipm-design-system/scripts/fetch-background.py +317 -317
  359. package/skills/craft/uipm-design-system/scripts/generate-slide.py +753 -753
  360. package/skills/craft/uipm-design-system/scripts/generate-tokens.cjs +213 -213
  361. package/skills/craft/uipm-design-system/scripts/html-token-validator.py +327 -327
  362. package/skills/craft/uipm-design-system/scripts/search-slides.py +218 -218
  363. package/skills/craft/uipm-design-system/scripts/slide-token-validator.py +35 -35
  364. package/skills/craft/uipm-design-system/scripts/slide_search_core.py +453 -453
  365. package/skills/craft/uipm-design-system/scripts/validate-tokens.cjs +254 -254
  366. package/skills/craft/uipm-design-system/templates/design-tokens-starter.json +143 -143
  367. package/skills/craft/uipm-slides/LICENSE +21 -21
  368. package/skills/craft/uipm-slides/SKILL.md +45 -45
  369. package/skills/craft/uipm-slides/references/copywriting-formulas.md +92 -92
  370. package/skills/craft/uipm-slides/references/create.md +5 -5
  371. package/skills/craft/uipm-slides/references/html-template.md +374 -374
  372. package/skills/craft/uipm-slides/references/layout-patterns.md +155 -155
  373. package/skills/craft/uipm-slides/references/slide-strategies.md +97 -97
  374. package/skills/craft/uipm-ui-ux-pro-max/LICENSE +21 -21
  375. package/skills/craft/uipm-ui-ux-pro-max/SKILL.md +678 -678
  376. package/skills/craft/uipm-ui-ux-pro-max/data/_sync_all.py +414 -414
  377. package/skills/craft/uipm-ui-ux-pro-max/data/app-interface.csv +30 -30
  378. package/skills/craft/uipm-ui-ux-pro-max/data/charts.csv +26 -26
  379. package/skills/craft/uipm-ui-ux-pro-max/data/colors.csv +161 -161
  380. package/skills/craft/uipm-ui-ux-pro-max/data/design.csv +1775 -1775
  381. package/skills/craft/uipm-ui-ux-pro-max/data/draft.csv +1778 -1778
  382. package/skills/craft/uipm-ui-ux-pro-max/data/google-fonts.csv +1924 -1924
  383. package/skills/craft/uipm-ui-ux-pro-max/data/icons.csv +105 -105
  384. package/skills/craft/uipm-ui-ux-pro-max/data/landing.csv +35 -35
  385. package/skills/craft/uipm-ui-ux-pro-max/data/products.csv +162 -162
  386. package/skills/craft/uipm-ui-ux-pro-max/data/react-performance.csv +45 -45
  387. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/angular.csv +51 -51
  388. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/astro.csv +54 -54
  389. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/flutter.csv +53 -53
  390. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
  391. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
  392. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/laravel.csv +51 -51
  393. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
  394. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
  395. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
  396. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react-native.csv +52 -52
  397. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react.csv +54 -54
  398. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
  399. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/svelte.csv +54 -54
  400. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
  401. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/threejs.csv +54 -54
  402. package/skills/craft/uipm-ui-ux-pro-max/data/stacks/vue.csv +50 -50
  403. package/skills/craft/uipm-ui-ux-pro-max/data/styles.csv +85 -85
  404. package/skills/craft/uipm-ui-ux-pro-max/data/typography.csv +74 -74
  405. package/skills/craft/uipm-ui-ux-pro-max/data/ui-reasoning.csv +162 -162
  406. package/skills/craft/uipm-ui-ux-pro-max/data/ux-guidelines.csv +99 -99
  407. package/skills/craft/uipm-ui-ux-pro-max/scripts/core.py +262 -262
  408. package/skills/craft/uipm-ui-ux-pro-max/scripts/design_system.py +1148 -1148
  409. package/skills/craft/uipm-ui-ux-pro-max/scripts/search.py +114 -114
  410. package/skills/craft/uipm-ui-ux-pro-max/templates/base/quick-reference.md +297 -297
  411. package/skills/craft/uipm-ui-ux-pro-max/templates/base/skill-content.md +375 -375
  412. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/agent.json +21 -21
  413. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/augment.json +18 -18
  414. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/claude.json +21 -21
  415. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codebuddy.json +21 -21
  416. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codex.json +21 -21
  417. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/continue.json +21 -21
  418. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/copilot.json +21 -21
  419. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/cursor.json +21 -21
  420. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/droid.json +21 -21
  421. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/gemini.json +21 -21
  422. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kilocode.json +21 -21
  423. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kiro.json +21 -21
  424. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/opencode.json +21 -21
  425. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/qoder.json +21 -21
  426. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/roocode.json +21 -21
  427. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/trae.json +21 -21
  428. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/warp.json +18 -18
  429. package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/windsurf.json +21 -21
  430. package/skills/craft/vercel-optimize/AGENTS.md +48 -48
  431. package/skills/craft/vercel-optimize/CONTRIBUTING.md +41 -41
  432. package/skills/craft/vercel-optimize/LICENSE +21 -21
  433. package/skills/craft/vercel-optimize/README.md +91 -91
  434. package/skills/craft/vercel-optimize/SKILL.md +325 -325
  435. package/skills/craft/vercel-optimize/lib/auth-route.mjs +23 -23
  436. package/skills/craft/vercel-optimize/lib/budget-summary.mjs +208 -208
  437. package/skills/craft/vercel-optimize/lib/citations.mjs +147 -147
  438. package/skills/craft/vercel-optimize/lib/cost-coverage.mjs +162 -162
  439. package/skills/craft/vercel-optimize/lib/dedup-recs.mjs +340 -340
  440. package/skills/craft/vercel-optimize/lib/deep-dive.mjs +371 -371
  441. package/skills/craft/vercel-optimize/lib/display-labels.mjs +219 -219
  442. package/skills/craft/vercel-optimize/lib/extract-claims.mjs +640 -640
  443. package/skills/craft/vercel-optimize/lib/framework-support.mjs +69 -69
  444. package/skills/craft/vercel-optimize/lib/gates/build-minutes-fanout.mjs +73 -73
  445. package/skills/craft/vercel-optimize/lib/gates/cold-start.mjs +72 -72
  446. package/skills/craft/vercel-optimize/lib/gates/contract.mjs +82 -82
  447. package/skills/craft/vercel-optimize/lib/gates/cwv-poor.mjs +95 -95
  448. package/skills/craft/vercel-optimize/lib/gates/external-api-slow.mjs +60 -60
  449. package/skills/craft/vercel-optimize/lib/gates/hard-gates.mjs +70 -70
  450. package/skills/craft/vercel-optimize/lib/gates/index.mjs +45 -45
  451. package/skills/craft/vercel-optimize/lib/gates/isr-overrevalidation.mjs +62 -62
  452. package/skills/craft/vercel-optimize/lib/gates/middleware-heavy.mjs +53 -53
  453. package/skills/craft/vercel-optimize/lib/gates/observability-events-attribution.mjs +58 -58
  454. package/skills/craft/vercel-optimize/lib/gates/platform-bot-protection.mjs +123 -123
  455. package/skills/craft/vercel-optimize/lib/gates/platform-fluid-compute.mjs +94 -94
  456. package/skills/craft/vercel-optimize/lib/gates/region-misconfig.mjs +71 -71
  457. package/skills/craft/vercel-optimize/lib/gates/route-errors.mjs +95 -95
  458. package/skills/craft/vercel-optimize/lib/gates/scanner-driven.mjs +150 -150
  459. package/skills/craft/vercel-optimize/lib/gates/select-candidates.mjs +137 -137
  460. package/skills/craft/vercel-optimize/lib/gates/slow-route.mjs +97 -97
  461. package/skills/craft/vercel-optimize/lib/gates/types.d.ts +38 -38
  462. package/skills/craft/vercel-optimize/lib/gates/uncached-route.mjs +103 -103
  463. package/skills/craft/vercel-optimize/lib/gates/usage-spike-triage.mjs +122 -122
  464. package/skills/craft/vercel-optimize/lib/grade-recommendation.mjs +170 -170
  465. package/skills/craft/vercel-optimize/lib/impact-label.mjs +128 -128
  466. package/skills/craft/vercel-optimize/lib/impact-magnitude.mjs +66 -66
  467. package/skills/craft/vercel-optimize/lib/investigation-brief.mjs +751 -751
  468. package/skills/craft/vercel-optimize/lib/observation-safety.mjs +217 -217
  469. package/skills/craft/vercel-optimize/lib/project-facts.mjs +101 -101
  470. package/skills/craft/vercel-optimize/lib/queries.mjs +333 -333
  471. package/skills/craft/vercel-optimize/lib/reconcile-candidates.mjs +388 -388
  472. package/skills/craft/vercel-optimize/lib/render-report.mjs +1065 -1065
  473. package/skills/craft/vercel-optimize/lib/repo-root.mjs +97 -97
  474. package/skills/craft/vercel-optimize/lib/route-normalize.mjs +224 -224
  475. package/skills/craft/vercel-optimize/lib/sanitizers/bot-protection-certainty.mjs +56 -56
  476. package/skills/craft/vercel-optimize/lib/sanitizers/cache-tag-invalidation-certainty.mjs +33 -33
  477. package/skills/craft/vercel-optimize/lib/sanitizers/count-correct.mjs +53 -53
  478. package/skills/craft/vercel-optimize/lib/sanitizers/function-duration-invocations.mjs +32 -32
  479. package/skills/craft/vercel-optimize/lib/sanitizers/index.mjs +87 -87
  480. package/skills/craft/vercel-optimize/lib/sanitizers/middleware-conflict.mjs +37 -37
  481. package/skills/craft/vercel-optimize/lib/sanitizers/missing-citation.mjs +16 -16
  482. package/skills/craft/vercel-optimize/lib/sanitizers/pre-release.mjs +75 -75
  483. package/skills/craft/vercel-optimize/lib/sanitizers/rate-limit.mjs +73 -73
  484. package/skills/craft/vercel-optimize/lib/sanitizers/rendering-mode-mislabel.mjs +42 -42
  485. package/skills/craft/vercel-optimize/lib/sanitizers/undeclared-dep.mjs +110 -110
  486. package/skills/craft/vercel-optimize/lib/sanitizers/vercel-directive-strip.mjs +37 -37
  487. package/skills/craft/vercel-optimize/lib/sanitizers/window-units.mjs +26 -26
  488. package/skills/craft/vercel-optimize/lib/scanners/cache-components-suspense-dedupe.mjs +114 -114
  489. package/skills/craft/vercel-optimize/lib/scanners/edge-heavy-import.mjs +102 -102
  490. package/skills/craft/vercel-optimize/lib/scanners/force-dynamic.mjs +39 -39
  491. package/skills/craft/vercel-optimize/lib/scanners/headers-in-page.mjs +43 -43
  492. package/skills/craft/vercel-optimize/lib/scanners/index.mjs +35 -35
  493. package/skills/craft/vercel-optimize/lib/scanners/large-static-asset.mjs +93 -93
  494. package/skills/craft/vercel-optimize/lib/scanners/max-age-without-s-maxage.mjs +47 -47
  495. package/skills/craft/vercel-optimize/lib/scanners/middleware-broad-matcher.mjs +53 -53
  496. package/skills/craft/vercel-optimize/lib/scanners/missing-cache-headers.mjs +97 -97
  497. package/skills/craft/vercel-optimize/lib/scanners/prisma-include-tree.mjs +39 -39
  498. package/skills/craft/vercel-optimize/lib/scanners/region-pin-in-config.mjs +89 -89
  499. package/skills/craft/vercel-optimize/lib/scanners/source-maps-production.mjs +33 -33
  500. package/skills/craft/vercel-optimize/lib/scanners/sveltekit-prerender-missing.mjs +47 -47
  501. package/skills/craft/vercel-optimize/lib/scanners/turbo-force-bypass.mjs +136 -136
  502. package/skills/craft/vercel-optimize/lib/scanners/unoptimized-image.mjs +127 -127
  503. package/skills/craft/vercel-optimize/lib/scanners/use-cache-date-stamp.mjs +112 -112
  504. package/skills/craft/vercel-optimize/lib/support-topics.mjs +365 -365
  505. package/skills/craft/vercel-optimize/lib/throttle.mjs +280 -280
  506. package/skills/craft/vercel-optimize/lib/util.mjs +17 -17
  507. package/skills/craft/vercel-optimize/lib/vercel.mjs +855 -855
  508. package/skills/craft/vercel-optimize/lib/verify-claim.mjs +1843 -1843
  509. package/skills/craft/vercel-optimize/lib/workspace-resolver.mjs +552 -552
  510. package/skills/craft/vercel-optimize/metadata.json +14 -14
  511. package/skills/craft/vercel-optimize/references/candidates.md +176 -176
  512. package/skills/craft/vercel-optimize/references/data-collection.md +224 -224
  513. package/skills/craft/vercel-optimize/references/docs-library.json +683 -683
  514. package/skills/craft/vercel-optimize/references/doctrine.md +108 -108
  515. package/skills/craft/vercel-optimize/references/observability-plus.md +109 -109
  516. package/skills/craft/vercel-optimize/references/playbooks/README.md +57 -57
  517. package/skills/craft/vercel-optimize/references/playbooks/ai-application.md +32 -32
  518. package/skills/craft/vercel-optimize/references/playbooks/api-service.md +30 -30
  519. package/skills/craft/vercel-optimize/references/playbooks/content-site.md +30 -30
  520. package/skills/craft/vercel-optimize/references/playbooks/ecommerce.md +30 -30
  521. package/skills/craft/vercel-optimize/references/playbooks/marketing.md +30 -30
  522. package/skills/craft/vercel-optimize/references/playbooks/saas.md +31 -31
  523. package/skills/craft/vercel-optimize/references/playbooks/sveltekit.md +75 -75
  524. package/skills/craft/vercel-optimize/references/recommendations.md +214 -214
  525. package/skills/craft/vercel-optimize/references/scanner-patterns.md +266 -266
  526. package/skills/craft/vercel-optimize/references/scoring.md +208 -208
  527. package/skills/craft/vercel-optimize/references/support-topics/README.md +50 -50
  528. package/skills/craft/vercel-optimize/references/support-topics/astro-edge-middleware-scope.md +30 -30
  529. package/skills/craft/vercel-optimize/references/support-topics/astro-output-mode-and-isr.md +31 -31
  530. package/skills/craft/vercel-optimize/references/support-topics/auth-preserving-parallelization.md +30 -30
  531. package/skills/craft/vercel-optimize/references/support-topics/bot-protection-product-guardrails.md +32 -32
  532. package/skills/craft/vercel-optimize/references/support-topics/build-minutes-monorepo-fanout.md +32 -32
  533. package/skills/craft/vercel-optimize/references/support-topics/cache-components-static-shell-boundaries.md +31 -31
  534. package/skills/craft/vercel-optimize/references/support-topics/cache-components-suspense-dedupe-pitfall.md +32 -32
  535. package/skills/craft/vercel-optimize/references/support-topics/cdn-cache-auth-safety.md +31 -31
  536. package/skills/craft/vercel-optimize/references/support-topics/cold-start-initialization-bundle.md +31 -31
  537. package/skills/craft/vercel-optimize/references/support-topics/core-web-vitals-client-bottlenecks.md +33 -33
  538. package/skills/craft/vercel-optimize/references/support-topics/database-egress-pooling-region.md +32 -32
  539. package/skills/craft/vercel-optimize/references/support-topics/dynamic-rendering-traps.md +31 -31
  540. package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path-platform.md +31 -31
  541. package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path.md +31 -31
  542. package/skills/craft/vercel-optimize/references/support-topics/fast-data-transfer-payloads.md +26 -26
  543. package/skills/craft/vercel-optimize/references/support-topics/fluid-compute-caveats.md +26 -26
  544. package/skills/craft/vercel-optimize/references/support-topics/function-duration-io-and-after.md +31 -31
  545. package/skills/craft/vercel-optimize/references/support-topics/function-invocation-reduction.md +31 -31
  546. package/skills/craft/vercel-optimize/references/support-topics/function-region-misconfiguration-ttfb.md +31 -31
  547. package/skills/craft/vercel-optimize/references/support-topics/image-optimization-cost-control.md +31 -31
  548. package/skills/craft/vercel-optimize/references/support-topics/isr-revalidation-static-generation.md +31 -31
  549. package/skills/craft/vercel-optimize/references/support-topics/middleware-proxy-edge-cost.md +30 -30
  550. package/skills/craft/vercel-optimize/references/support-topics/next-fetch-revalidate-floor.md +30 -30
  551. package/skills/craft/vercel-optimize/references/support-topics/next-font-cls-self-hosting.md +31 -31
  552. package/skills/craft/vercel-optimize/references/support-topics/next-heavy-ui-lazy-load-boundaries.md +28 -28
  553. package/skills/craft/vercel-optimize/references/support-topics/next-image-lcp-preload-sizes.md +31 -31
  554. package/skills/craft/vercel-optimize/references/support-topics/next-route-handler-get-cache-defaults.md +30 -30
  555. package/skills/craft/vercel-optimize/references/support-topics/next-script-third-party-strategy.md +31 -31
  556. package/skills/craft/vercel-optimize/references/support-topics/nextjs-version-cache-semantics.md +31 -31
  557. package/skills/craft/vercel-optimize/references/support-topics/not-found-catchall-request-waste.md +33 -33
  558. package/skills/craft/vercel-optimize/references/support-topics/nuxt-route-rules-cache-isr.md +31 -31
  559. package/skills/craft/vercel-optimize/references/support-topics/observability-events-cost-attribution.md +27 -27
  560. package/skills/craft/vercel-optimize/references/support-topics/post-response-work-waituntil.md +26 -26
  561. package/skills/craft/vercel-optimize/references/support-topics/route-error-durable-offload.md +33 -33
  562. package/skills/craft/vercel-optimize/references/support-topics/route-error-runtime-limits.md +31 -31
  563. package/skills/craft/vercel-optimize/references/support-topics/runtime-cache-reusable-data.md +30 -30
  564. package/skills/craft/vercel-optimize/references/support-topics/sveltekit-isr-prerender-safety.md +31 -31
  565. package/skills/craft/vercel-optimize/references/support-topics/sveltekit-split-cold-start-tradeoff.md +30 -30
  566. package/skills/craft/vercel-optimize/references/support-topics/usage-spike-triage.md +31 -31
  567. package/skills/craft/vercel-optimize/references/support-topics/use-cache-date-stamp-isr-write-amplifier.md +31 -31
  568. package/skills/craft/vercel-optimize/references/support-topics/use-cache-remote-shared-origin-data.md +30 -30
  569. package/skills/craft/vercel-optimize/references/support-topics/workflow-resumable-stream-routes.md +32 -32
  570. package/skills/craft/vercel-optimize/references/verification.md +102 -102
  571. package/skills/craft/vercel-optimize/references/voice.md +76 -76
  572. package/skills/craft/vercel-optimize/scripts/budget-summary.mjs +58 -58
  573. package/skills/craft/vercel-optimize/scripts/build-docs.mjs +76 -76
  574. package/skills/craft/vercel-optimize/scripts/check-citations.mjs +91 -91
  575. package/skills/craft/vercel-optimize/scripts/check-docs-fresh.mjs +100 -100
  576. package/skills/craft/vercel-optimize/scripts/collect-signals.mjs +638 -638
  577. package/skills/craft/vercel-optimize/scripts/collect-sub-agent-outputs.mjs +306 -306
  578. package/skills/craft/vercel-optimize/scripts/deep-dive.mjs +358 -358
  579. package/skills/craft/vercel-optimize/scripts/gate-investigations.mjs +178 -178
  580. package/skills/craft/vercel-optimize/scripts/merge-signals.mjs +203 -203
  581. package/skills/craft/vercel-optimize/scripts/prepare-investigation-brief.mjs +249 -249
  582. package/skills/craft/vercel-optimize/scripts/reconcile-candidates.mjs +69 -69
  583. package/skills/craft/vercel-optimize/scripts/render-report.mjs +462 -462
  584. package/skills/craft/vercel-optimize/scripts/scan-codebase.mjs +361 -361
  585. package/skills/craft/vercel-optimize/scripts/verify-and-regen.mjs +379 -379
  586. package/skills/craft/vercel-optimize/scripts/verify-finding.mjs +21 -21
  587. package/skills/craft/web-design-guidelines/LICENSE +21 -21
  588. package/skills/craft/web-design-guidelines/SKILL.md +43 -43
  589. package/skills/craft/zero-to-live/LICENSE +21 -21
  590. package/skills/craft/zero-to-live/SKILL.md +422 -422
  591. package/skills/creative/creative-3d-modeling/LICENSE +21 -21
  592. package/skills/creative/creative-3d-modeling/SKILL.md +70 -70
  593. package/skills/creative/creative-architecture/LICENSE +21 -21
  594. package/skills/creative/creative-architecture/SKILL.md +94 -94
  595. package/skills/creative/creative-design-principles/LICENSE +21 -21
  596. package/skills/creative/creative-design-principles/SKILL.md +95 -95
  597. package/skills/creative/creative-fashion-advanced/LICENSE +21 -21
  598. package/skills/creative/creative-fashion-advanced/SKILL.md +68 -68
  599. package/skills/creative/creative-fashion-design/LICENSE +21 -21
  600. package/skills/creative/creative-fashion-design/SKILL.md +66 -66
  601. package/skills/creative/creative-game-design/LICENSE +21 -21
  602. package/skills/creative/creative-game-design/SKILL.md +77 -77
  603. package/skills/creative/creative-industrial-design/LICENSE +21 -21
  604. package/skills/creative/creative-industrial-design/SKILL.md +57 -57
  605. package/skills/creative/creative-interior-design/LICENSE +21 -21
  606. package/skills/creative/creative-interior-design/SKILL.md +59 -59
  607. package/skills/creative/creative-music-theory/LICENSE +21 -21
  608. package/skills/creative/creative-music-theory/SKILL.md +98 -98
  609. package/skills/creative/creative-photography/LICENSE +21 -21
  610. package/skills/creative/creative-photography/SKILL.md +87 -87
  611. package/skills/creative/creative-textile-science/LICENSE +21 -21
  612. package/skills/creative/creative-textile-science/SKILL.md +67 -67
  613. package/skills/creative/creative-ux/LICENSE +21 -21
  614. package/skills/creative/creative-ux/SKILL.md +81 -81
  615. package/skills/creative/creative-video/LICENSE +21 -21
  616. package/skills/creative/creative-video/SKILL.md +84 -84
  617. package/skills/creative/creative-writing-craft/LICENSE +21 -21
  618. package/skills/creative/creative-writing-craft/SKILL.md +91 -91
  619. package/skills/diagram-maker/SKILL.md +56 -56
  620. package/skills/diagram-maker/references/excalidraw-patterns.md +85 -85
  621. package/skills/diagram-maker/references/svg-template.md +112 -112
  622. package/skills/discord/SKILL.md +140 -140
  623. package/skills/education/edu-adult-learning/LICENSE +21 -21
  624. package/skills/education/edu-adult-learning/SKILL.md +81 -81
  625. package/skills/education/edu-africa-multilingual/LICENSE +21 -21
  626. package/skills/education/edu-africa-multilingual/SKILL.md +55 -55
  627. package/skills/education/edu-arabic/LICENSE +21 -21
  628. package/skills/education/edu-arabic/SKILL.md +60 -60
  629. package/skills/education/edu-australia-nz/LICENSE +21 -21
  630. package/skills/education/edu-australia-nz/SKILL.md +48 -48
  631. package/skills/education/edu-china-mandarin/LICENSE +21 -21
  632. package/skills/education/edu-china-mandarin/SKILL.md +58 -58
  633. package/skills/education/edu-critical-thinking/LICENSE +21 -21
  634. package/skills/education/edu-critical-thinking/SKILL.md +86 -86
  635. package/skills/education/edu-curriculum/LICENSE +21 -21
  636. package/skills/education/edu-curriculum/SKILL.md +87 -87
  637. package/skills/education/edu-ed-tech/LICENSE +21 -21
  638. package/skills/education/edu-ed-tech/SKILL.md +73 -73
  639. package/skills/education/edu-france/LICENSE +21 -21
  640. package/skills/education/edu-france/SKILL.md +42 -42
  641. package/skills/education/edu-germany/LICENSE +21 -21
  642. package/skills/education/edu-germany/SKILL.md +46 -46
  643. package/skills/education/edu-india-competitive/LICENSE +21 -21
  644. package/skills/education/edu-india-competitive/SKILL.md +159 -159
  645. package/skills/education/edu-india-east/LICENSE +21 -21
  646. package/skills/education/edu-india-east/SKILL.md +60 -60
  647. package/skills/education/edu-india-hindi/LICENSE +21 -21
  648. package/skills/education/edu-india-hindi/SKILL.md +107 -107
  649. package/skills/education/edu-india-south/LICENSE +21 -21
  650. package/skills/education/edu-india-south/SKILL.md +64 -64
  651. package/skills/education/edu-india-west/LICENSE +21 -21
  652. package/skills/education/edu-india-west/SKILL.md +68 -68
  653. package/skills/education/edu-indonesia-malay/LICENSE +21 -21
  654. package/skills/education/edu-indonesia-malay/SKILL.md +57 -57
  655. package/skills/education/edu-international-ib/LICENSE +21 -21
  656. package/skills/education/edu-international-ib/SKILL.md +61 -61
  657. package/skills/education/edu-japan/LICENSE +21 -21
  658. package/skills/education/edu-japan/SKILL.md +48 -48
  659. package/skills/education/edu-korea/LICENSE +21 -21
  660. package/skills/education/edu-korea/SKILL.md +48 -48
  661. package/skills/education/edu-learning-science/LICENSE +21 -21
  662. package/skills/education/edu-learning-science/SKILL.md +76 -76
  663. package/skills/education/edu-portuguese-brazil/LICENSE +21 -21
  664. package/skills/education/edu-portuguese-brazil/SKILL.md +51 -51
  665. package/skills/education/edu-russia/LICENSE +21 -21
  666. package/skills/education/edu-russia/SKILL.md +50 -50
  667. package/skills/education/edu-spain-latam/LICENSE +21 -21
  668. package/skills/education/edu-spain-latam/SKILL.md +55 -55
  669. package/skills/education/edu-special/LICENSE +21 -21
  670. package/skills/education/edu-special/SKILL.md +76 -76
  671. package/skills/education/edu-thailand/LICENSE +21 -21
  672. package/skills/education/edu-thailand/SKILL.md +55 -55
  673. package/skills/education/edu-turkey/LICENSE +21 -21
  674. package/skills/education/edu-turkey/SKILL.md +58 -58
  675. package/skills/education/edu-uk-gcse-alevel/LICENSE +21 -21
  676. package/skills/education/edu-uk-gcse-alevel/SKILL.md +51 -51
  677. package/skills/education/edu-usa-graduate/LICENSE +21 -21
  678. package/skills/education/edu-usa-graduate/SKILL.md +57 -57
  679. package/skills/education/edu-usa-sat-act/LICENSE +21 -21
  680. package/skills/education/edu-usa-sat-act/SKILL.md +55 -55
  681. package/skills/education/edu-vietnam/LICENSE +21 -21
  682. package/skills/education/edu-vietnam/SKILL.md +53 -53
  683. package/skills/eightctl/SKILL.md +54 -54
  684. package/skills/engineering/eng-aerospace/LICENSE +21 -21
  685. package/skills/engineering/eng-aerospace/SKILL.md +117 -117
  686. package/skills/engineering/eng-chemical/LICENSE +21 -21
  687. package/skills/engineering/eng-chemical/SKILL.md +63 -63
  688. package/skills/engineering/eng-civil/LICENSE +21 -21
  689. package/skills/engineering/eng-civil/SKILL.md +223 -223
  690. package/skills/engineering/eng-control-systems/LICENSE +21 -21
  691. package/skills/engineering/eng-control-systems/SKILL.md +158 -158
  692. package/skills/engineering/eng-cryogenics/LICENSE +21 -21
  693. package/skills/engineering/eng-cryogenics/SKILL.md +151 -151
  694. package/skills/engineering/eng-electrical/LICENSE +21 -21
  695. package/skills/engineering/eng-electrical/SKILL.md +70 -70
  696. package/skills/engineering/eng-electronics-embedded/LICENSE +21 -21
  697. package/skills/engineering/eng-electronics-embedded/SKILL.md +89 -89
  698. package/skills/engineering/eng-environmental/LICENSE +21 -21
  699. package/skills/engineering/eng-environmental/SKILL.md +66 -66
  700. package/skills/engineering/eng-manufacturing/LICENSE +21 -21
  701. package/skills/engineering/eng-manufacturing/SKILL.md +78 -78
  702. package/skills/engineering/eng-mechanical/LICENSE +21 -21
  703. package/skills/engineering/eng-mechanical/SKILL.md +66 -66
  704. package/skills/engineering/eng-project/LICENSE +21 -21
  705. package/skills/engineering/eng-project/SKILL.md +72 -72
  706. package/skills/engineering/eng-propulsion/LICENSE +21 -21
  707. package/skills/engineering/eng-propulsion/SKILL.md +133 -133
  708. package/skills/engineering/eng-robotics/LICENSE +21 -21
  709. package/skills/engineering/eng-robotics/SKILL.md +92 -92
  710. package/skills/engineering/eng-systems/LICENSE +21 -21
  711. package/skills/engineering/eng-systems/SKILL.md +81 -81
  712. package/skills/environment/env-biodiversity/LICENSE +21 -21
  713. package/skills/environment/env-biodiversity/SKILL.md +66 -66
  714. package/skills/environment/env-circular-economy/LICENSE +21 -21
  715. package/skills/environment/env-circular-economy/SKILL.md +71 -71
  716. package/skills/environment/env-climate-action/LICENSE +21 -21
  717. package/skills/environment/env-climate-action/SKILL.md +55 -55
  718. package/skills/environment/env-energy/LICENSE +21 -21
  719. package/skills/environment/env-energy/SKILL.md +83 -83
  720. package/skills/environment/env-sustainability-biz/LICENSE +21 -21
  721. package/skills/environment/env-sustainability-biz/SKILL.md +65 -65
  722. package/skills/environment/env-water/LICENSE +21 -21
  723. package/skills/environment/env-water/SKILL.md +67 -67
  724. package/skills/finance/finance-accounting/LICENSE +21 -21
  725. package/skills/finance/finance-accounting/SKILL.md +239 -239
  726. package/skills/finance/finance-banking/LICENSE +21 -21
  727. package/skills/finance/finance-banking/SKILL.md +54 -54
  728. package/skills/finance/finance-corporate/LICENSE +21 -21
  729. package/skills/finance/finance-corporate/SKILL.md +105 -105
  730. package/skills/finance/finance-crypto/LICENSE +21 -21
  731. package/skills/finance/finance-crypto/SKILL.md +94 -94
  732. package/skills/finance/finance-debt-management/LICENSE +21 -21
  733. package/skills/finance/finance-debt-management/SKILL.md +87 -87
  734. package/skills/finance/finance-insurance/LICENSE +21 -21
  735. package/skills/finance/finance-insurance/SKILL.md +91 -91
  736. package/skills/finance/finance-investing/LICENSE +21 -21
  737. package/skills/finance/finance-investing/SKILL.md +269 -269
  738. package/skills/finance/finance-options-derivatives/LICENSE +21 -21
  739. package/skills/finance/finance-options-derivatives/SKILL.md +68 -68
  740. package/skills/finance/finance-personal/LICENSE +21 -21
  741. package/skills/finance/finance-personal/SKILL.md +268 -268
  742. package/skills/finance/finance-real-estate/LICENSE +21 -21
  743. package/skills/finance/finance-real-estate/SKILL.md +110 -110
  744. package/skills/finance/finance-startup/LICENSE +21 -21
  745. package/skills/finance/finance-startup/SKILL.md +253 -253
  746. package/skills/finance/finance-tax-planning/LICENSE +21 -21
  747. package/skills/finance/finance-tax-planning/SKILL.md +89 -89
  748. package/skills/finance/finance-trading/LICENSE +21 -21
  749. package/skills/finance/finance-trading/SKILL.md +112 -112
  750. package/skills/gemini/SKILL.md +51 -51
  751. package/skills/gh-issues/SKILL.md +216 -216
  752. package/skills/gifgrep/SKILL.md +89 -89
  753. package/skills/github/SKILL.md +87 -87
  754. package/skills/gog/SKILL.md +120 -120
  755. package/skills/goplaces/SKILL.md +56 -56
  756. package/skills/health/health-aging/LICENSE +21 -21
  757. package/skills/health/health-aging/SKILL.md +82 -82
  758. package/skills/health/health-chronic/LICENSE +21 -21
  759. package/skills/health/health-chronic/SKILL.md +202 -202
  760. package/skills/health/health-dental/LICENSE +21 -21
  761. package/skills/health/health-dental/SKILL.md +41 -41
  762. package/skills/health/health-eye-care/LICENSE +21 -21
  763. package/skills/health/health-eye-care/SKILL.md +56 -56
  764. package/skills/health/health-first-aid/LICENSE +21 -21
  765. package/skills/health/health-first-aid/SKILL.md +201 -201
  766. package/skills/health/health-fitness/LICENSE +21 -21
  767. package/skills/health/health-fitness/SKILL.md +111 -111
  768. package/skills/health/health-general/LICENSE +21 -21
  769. package/skills/health/health-general/SKILL.md +277 -277
  770. package/skills/health/health-mens/LICENSE +21 -21
  771. package/skills/health/health-mens/SKILL.md +53 -53
  772. package/skills/health/health-mental/LICENSE +21 -21
  773. package/skills/health/health-mental/SKILL.md +221 -221
  774. package/skills/health/health-naturopathy-ayurveda/LICENSE +21 -21
  775. package/skills/health/health-naturopathy-ayurveda/SKILL.md +60 -60
  776. package/skills/health/health-nutrition/LICENSE +21 -21
  777. package/skills/health/health-nutrition/SKILL.md +262 -262
  778. package/skills/health/health-pediatric/LICENSE +21 -21
  779. package/skills/health/health-pediatric/SKILL.md +94 -94
  780. package/skills/health/health-pharmacology/LICENSE +21 -21
  781. package/skills/health/health-pharmacology/SKILL.md +87 -87
  782. package/skills/health/health-pregnancy/LICENSE +21 -21
  783. package/skills/health/health-pregnancy/SKILL.md +71 -71
  784. package/skills/health/health-skin/LICENSE +21 -21
  785. package/skills/health/health-skin/SKILL.md +71 -71
  786. package/skills/health/health-sleep/LICENSE +21 -21
  787. package/skills/health/health-sleep/SKILL.md +81 -81
  788. package/skills/health/health-womens/LICENSE +21 -21
  789. package/skills/health/health-womens/SKILL.md +72 -72
  790. package/skills/health/health-yoga-wellness/LICENSE +21 -21
  791. package/skills/health/health-yoga-wellness/SKILL.md +58 -58
  792. package/skills/healthcare-systems/health-sys-global/LICENSE +21 -21
  793. package/skills/healthcare-systems/health-sys-global/SKILL.md +69 -69
  794. package/skills/healthcare-systems/health-sys-management/LICENSE +21 -21
  795. package/skills/healthcare-systems/health-sys-management/SKILL.md +71 -71
  796. package/skills/healthcare-systems/health-sys-navigation/LICENSE +21 -21
  797. package/skills/healthcare-systems/health-sys-navigation/SKILL.md +60 -60
  798. package/skills/healthcare-systems/health-sys-public/LICENSE +21 -21
  799. package/skills/healthcare-systems/health-sys-public/SKILL.md +71 -71
  800. package/skills/healthcheck/SKILL.md +109 -109
  801. package/skills/himalaya/SKILL.md +84 -84
  802. package/skills/himalaya/references/configuration.md +184 -184
  803. package/skills/himalaya/references/message-composition.md +199 -199
  804. package/skills/humanities/humanities-history-world/LICENSE +21 -21
  805. package/skills/humanities/humanities-history-world/SKILL.md +59 -59
  806. package/skills/humanities/humanities-indian-classical/LICENSE +21 -21
  807. package/skills/humanities/humanities-indian-classical/SKILL.md +104 -104
  808. package/skills/humanities/humanities-philosophy/LICENSE +21 -21
  809. package/skills/humanities/humanities-philosophy/SKILL.md +105 -105
  810. package/skills/humanities/humanities-world-religions/LICENSE +21 -21
  811. package/skills/humanities/humanities-world-religions/SKILL.md +67 -67
  812. package/skills/impeccable/SKILL.md +185 -185
  813. package/skills/imsg/SKILL.md +126 -126
  814. package/skills/industry/industry-construction/LICENSE +21 -21
  815. package/skills/industry/industry-construction/SKILL.md +81 -81
  816. package/skills/industry/industry-education-sector/LICENSE +21 -21
  817. package/skills/industry/industry-education-sector/SKILL.md +49 -49
  818. package/skills/industry/industry-fashion/LICENSE +21 -21
  819. package/skills/industry/industry-fashion/SKILL.md +82 -82
  820. package/skills/industry/industry-food/LICENSE +21 -21
  821. package/skills/industry/industry-food/SKILL.md +79 -79
  822. package/skills/industry/industry-government/LICENSE +21 -21
  823. package/skills/industry/industry-government/SKILL.md +80 -80
  824. package/skills/industry/industry-hospitality/LICENSE +21 -21
  825. package/skills/industry/industry-hospitality/SKILL.md +73 -73
  826. package/skills/industry/industry-insurance-sector/LICENSE +21 -21
  827. package/skills/industry/industry-insurance-sector/SKILL.md +57 -57
  828. package/skills/industry/industry-logistics/LICENSE +21 -21
  829. package/skills/industry/industry-logistics/SKILL.md +80 -80
  830. package/skills/industry/industry-media/LICENSE +21 -21
  831. package/skills/industry/industry-media/SKILL.md +66 -66
  832. package/skills/industry/industry-nonprofit/LICENSE +21 -21
  833. package/skills/industry/industry-nonprofit/SKILL.md +77 -77
  834. package/skills/industry/industry-pharma/LICENSE +21 -21
  835. package/skills/industry/industry-pharma/SKILL.md +69 -69
  836. package/skills/industry/industry-real-estate/LICENSE +21 -21
  837. package/skills/industry/industry-real-estate/SKILL.md +61 -61
  838. package/skills/industry/industry-sports/LICENSE +21 -21
  839. package/skills/industry/industry-sports/SKILL.md +71 -71
  840. package/skills/industry/industry-tech-startup/LICENSE +21 -21
  841. package/skills/industry/industry-tech-startup/SKILL.md +82 -82
  842. package/skills/internal-comms/LICENSE +21 -21
  843. package/skills/internal-comms/SKILL.md +38 -38
  844. package/skills/internal-comms/examples/3p-updates.md +49 -49
  845. package/skills/internal-comms/examples/company-newsletter.md +76 -76
  846. package/skills/internal-comms/examples/faq-answers.md +35 -35
  847. package/skills/internal-comms/examples/general-comms.md +19 -19
  848. package/skills/legal/legal-business/LICENSE +21 -21
  849. package/skills/legal/legal-business/SKILL.md +227 -227
  850. package/skills/legal/legal-consumer/LICENSE +21 -21
  851. package/skills/legal/legal-consumer/SKILL.md +155 -155
  852. package/skills/legal/legal-contracts/LICENSE +21 -21
  853. package/skills/legal/legal-contracts/SKILL.md +268 -268
  854. package/skills/legal/legal-corporate-governance/LICENSE +21 -21
  855. package/skills/legal/legal-corporate-governance/SKILL.md +53 -53
  856. package/skills/legal/legal-employment/LICENSE +21 -21
  857. package/skills/legal/legal-employment/SKILL.md +291 -291
  858. package/skills/legal/legal-immigration/LICENSE +21 -21
  859. package/skills/legal/legal-immigration/SKILL.md +146 -146
  860. package/skills/legal/legal-international/LICENSE +21 -21
  861. package/skills/legal/legal-international/SKILL.md +51 -51
  862. package/skills/legal/legal-ip/LICENSE +21 -21
  863. package/skills/legal/legal-ip/SKILL.md +264 -264
  864. package/skills/legal/legal-privacy/LICENSE +21 -21
  865. package/skills/legal/legal-privacy/SKILL.md +161 -161
  866. package/skills/legal/legal-real-estate/LICENSE +21 -21
  867. package/skills/legal/legal-real-estate/SKILL.md +142 -142
  868. package/skills/legal/legal-startup/LICENSE +21 -21
  869. package/skills/legal/legal-startup/SKILL.md +182 -182
  870. package/skills/legal/legal-tax/LICENSE +21 -21
  871. package/skills/legal/legal-tax/SKILL.md +156 -156
  872. package/skills/mcp-builder/LICENSE +21 -21
  873. package/skills/mcp-builder/SKILL.md +257 -257
  874. package/skills/mcp-builder/reference/evaluation.md +630 -630
  875. package/skills/mcp-builder/reference/mcp_best_practices.md +269 -269
  876. package/skills/mcp-builder/reference/node_mcp_server.md +980 -980
  877. package/skills/mcp-builder/reference/python_mcp_server.md +737 -737
  878. package/skills/mcp-builder/scripts/connections.py +151 -151
  879. package/skills/mcp-builder/scripts/evaluation.py +373 -373
  880. package/skills/mcp-builder/scripts/example_evaluation.xml +22 -22
  881. package/skills/mcp-builder/scripts/requirements.txt +2 -2
  882. package/skills/mcporter/SKILL.md +65 -65
  883. package/skills/meme-maker/SKILL.md +46 -46
  884. package/skills/meme-maker/references/templates.json +358 -358
  885. package/skills/meme-maker/scripts/meme.mjs +398 -398
  886. package/skills/mental-health/mental-health-cbt/LICENSE +21 -21
  887. package/skills/mental-health/mental-health-cbt/SKILL.md +254 -254
  888. package/skills/mental-health/psych-addiction/LICENSE +21 -21
  889. package/skills/mental-health/psych-addiction/SKILL.md +79 -79
  890. package/skills/mental-health/psych-behavioral-econ/LICENSE +21 -21
  891. package/skills/mental-health/psych-behavioral-econ/SKILL.md +84 -84
  892. package/skills/mental-health/psych-child/LICENSE +21 -21
  893. package/skills/mental-health/psych-child/SKILL.md +84 -84
  894. package/skills/mental-health/psych-grief/LICENSE +21 -21
  895. package/skills/mental-health/psych-grief/SKILL.md +85 -85
  896. package/skills/mental-health/psych-mindfulness/LICENSE +21 -21
  897. package/skills/mental-health/psych-mindfulness/SKILL.md +71 -71
  898. package/skills/mental-health/psych-org/LICENSE +21 -21
  899. package/skills/mental-health/psych-org/SKILL.md +115 -115
  900. package/skills/mental-health/psych-positive/LICENSE +21 -21
  901. package/skills/mental-health/psych-positive/SKILL.md +86 -86
  902. package/skills/mental-health/psych-relationships/LICENSE +21 -21
  903. package/skills/mental-health/psych-relationships/SKILL.md +100 -100
  904. package/skills/mental-health/psych-trauma/LICENSE +21 -21
  905. package/skills/mental-health/psych-trauma/SKILL.md +109 -109
  906. package/skills/model-usage/SKILL.md +75 -75
  907. package/skills/model-usage/references/codexbar-cli.md +33 -33
  908. package/skills/model-usage/scripts/model_usage.py +319 -319
  909. package/skills/model-usage/scripts/test_model_usage.py +40 -40
  910. package/skills/nano-pdf/SKILL.md +42 -42
  911. package/skills/node-connect/SKILL.md +147 -147
  912. package/skills/node-inspect-debugger/SKILL.md +88 -88
  913. package/skills/notion/SKILL.md +154 -154
  914. package/skills/obsidian/SKILL.md +123 -123
  915. package/skills/openai-whisper/SKILL.md +42 -42
  916. package/skills/openai-whisper-api/SKILL.md +75 -75
  917. package/skills/openai-whisper-api/scripts/transcribe.sh +154 -154
  918. package/skills/openhue/SKILL.md +116 -116
  919. package/skills/oracle/SKILL.md +130 -130
  920. package/skills/ordercli/SKILL.md +82 -82
  921. package/skills/peekaboo/SKILL.md +217 -217
  922. package/skills/pyproject.toml +10 -10
  923. package/skills/python-debugpy/SKILL.md +76 -76
  924. package/skills/sag/SKILL.md +91 -91
  925. package/skills/science/sci-astronomy/LICENSE +21 -21
  926. package/skills/science/sci-astronomy/SKILL.md +80 -80
  927. package/skills/science/sci-biology/LICENSE +21 -21
  928. package/skills/science/sci-biology/SKILL.md +74 -74
  929. package/skills/science/sci-chemistry/LICENSE +21 -21
  930. package/skills/science/sci-chemistry/SKILL.md +89 -89
  931. package/skills/science/sci-climate/LICENSE +21 -21
  932. package/skills/science/sci-climate/SKILL.md +72 -72
  933. package/skills/science/sci-data-analysis/LICENSE +21 -21
  934. package/skills/science/sci-data-analysis/SKILL.md +87 -87
  935. package/skills/science/sci-environmental-science/LICENSE +21 -21
  936. package/skills/science/sci-environmental-science/SKILL.md +69 -69
  937. package/skills/science/sci-geology/LICENSE +21 -21
  938. package/skills/science/sci-geology/SKILL.md +56 -56
  939. package/skills/science/sci-method/LICENSE +21 -21
  940. package/skills/science/sci-method/SKILL.md +77 -77
  941. package/skills/science/sci-neuroscience/LICENSE +21 -21
  942. package/skills/science/sci-neuroscience/SKILL.md +79 -79
  943. package/skills/science/sci-physics/LICENSE +21 -21
  944. package/skills/science/sci-physics/SKILL.md +78 -78
  945. package/skills/science/sci-research-methods/LICENSE +21 -21
  946. package/skills/science/sci-research-methods/SKILL.md +83 -83
  947. package/skills/science/sci-statistics/LICENSE +21 -21
  948. package/skills/science/sci-statistics/SKILL.md +249 -249
  949. package/skills/session-logs/SKILL.md +155 -155
  950. package/skills/sherpa-onnx-tts/SKILL.md +113 -113
  951. package/skills/skill-creator/SKILL.md +81 -81
  952. package/skills/skill-creator/license.txt +202 -202
  953. package/skills/skill-creator/scripts/init_skill.py +378 -378
  954. package/skills/skill-creator/scripts/package_skill.py +144 -144
  955. package/skills/skill-creator/scripts/quick_validate.py +169 -169
  956. package/skills/skill-creator/scripts/test_init_skill.py +51 -51
  957. package/skills/skill-creator/scripts/test_package_skill.py +199 -199
  958. package/skills/skill-creator/scripts/test_quick_validate.py +116 -116
  959. package/skills/slack/SKILL.md +82 -82
  960. package/skills/slack-gif-creator/LICENSE +21 -21
  961. package/skills/slack-gif-creator/SKILL.md +293 -293
  962. package/skills/slack-gif-creator/requirements.txt +3 -3
  963. package/skills/social-sciences/social-anthropology/LICENSE +21 -21
  964. package/skills/social-sciences/social-anthropology/SKILL.md +62 -62
  965. package/skills/social-sciences/social-economics/LICENSE +21 -21
  966. package/skills/social-sciences/social-economics/SKILL.md +88 -88
  967. package/skills/social-sciences/social-geography/LICENSE +21 -21
  968. package/skills/social-sciences/social-geography/SKILL.md +61 -61
  969. package/skills/social-sciences/social-international-dev/LICENSE +21 -21
  970. package/skills/social-sciences/social-international-dev/SKILL.md +76 -76
  971. package/skills/social-sciences/social-political-science/LICENSE +21 -21
  972. package/skills/social-sciences/social-political-science/SKILL.md +70 -70
  973. package/skills/social-sciences/social-public-policy/LICENSE +21 -21
  974. package/skills/social-sciences/social-public-policy/SKILL.md +73 -73
  975. package/skills/social-sciences/social-sociology/LICENSE +21 -21
  976. package/skills/social-sciences/social-sociology/SKILL.md +78 -78
  977. package/skills/songsee/SKILL.md +53 -53
  978. package/skills/sonoscli/SKILL.md +69 -69
  979. package/skills/spike/SKILL.md +55 -55
  980. package/skills/spotify-player/SKILL.md +68 -68
  981. package/skills/summarize/SKILL.md +90 -90
  982. package/skills/taskflow/SKILL.md +153 -153
  983. package/skills/taskflow/examples/inbox-triage.lobster +33 -33
  984. package/skills/taskflow/examples/pr-intake.lobster +32 -32
  985. package/skills/taskflow-inbox-triage/SKILL.md +123 -123
  986. package/skills/technical/ai-ethics/LICENSE +21 -21
  987. package/skills/technical/ai-ethics/SKILL.md +92 -92
  988. package/skills/technical/ai-product-builder/LICENSE +21 -21
  989. package/skills/technical/ai-product-builder/SKILL.md +180 -180
  990. package/skills/technical/analytics-setup/LICENSE +21 -21
  991. package/skills/technical/analytics-setup/SKILL.md +125 -125
  992. package/skills/technical/api-builder/LICENSE +21 -21
  993. package/skills/technical/api-builder/SKILL.md +202 -202
  994. package/skills/technical/architecture-decisions/LICENSE +21 -21
  995. package/skills/technical/architecture-decisions/SKILL.md +120 -120
  996. package/skills/technical/auth-security/LICENSE +21 -21
  997. package/skills/technical/auth-security/SKILL.md +209 -209
  998. package/skills/technical/blockchain-web3/LICENSE +21 -21
  999. package/skills/technical/blockchain-web3/SKILL.md +84 -84
  1000. package/skills/technical/cloud-architecture/LICENSE +21 -21
  1001. package/skills/technical/cloud-architecture/SKILL.md +85 -85
  1002. package/skills/technical/content-platform/LICENSE +21 -21
  1003. package/skills/technical/content-platform/SKILL.md +134 -134
  1004. package/skills/technical/cybersecurity-advanced/LICENSE +21 -21
  1005. package/skills/technical/cybersecurity-advanced/SKILL.md +99 -99
  1006. package/skills/technical/data-engineering/LICENSE +21 -21
  1007. package/skills/technical/data-engineering/SKILL.md +117 -117
  1008. package/skills/technical/database-design/LICENSE +21 -21
  1009. package/skills/technical/database-design/SKILL.md +185 -185
  1010. package/skills/technical/devops-cicd/LICENSE +21 -21
  1011. package/skills/technical/devops-cicd/SKILL.md +181 -181
  1012. package/skills/technical/ecommerce-builder/LICENSE +21 -21
  1013. package/skills/technical/ecommerce-builder/SKILL.md +123 -123
  1014. package/skills/technical/email-marketing/LICENSE +21 -21
  1015. package/skills/technical/email-marketing/SKILL.md +128 -128
  1016. package/skills/technical/fintech-builder/LICENSE +21 -21
  1017. package/skills/technical/fintech-builder/SKILL.md +141 -141
  1018. package/skills/technical/full-stack-web/LICENSE +21 -21
  1019. package/skills/technical/full-stack-web/SKILL.md +173 -173
  1020. package/skills/technical/gdpr-basics/LICENSE +21 -21
  1021. package/skills/technical/gdpr-basics/SKILL.md +145 -145
  1022. package/skills/technical/launch-playbook/LICENSE +21 -21
  1023. package/skills/technical/launch-playbook/SKILL.md +95 -95
  1024. package/skills/technical/marketing-copy/LICENSE +21 -21
  1025. package/skills/technical/marketing-copy/SKILL.md +126 -126
  1026. package/skills/technical/marketplace-builder/LICENSE +21 -21
  1027. package/skills/technical/marketplace-builder/SKILL.md +105 -105
  1028. package/skills/technical/mobile-pwa/LICENSE +21 -21
  1029. package/skills/technical/mobile-pwa/SKILL.md +191 -191
  1030. package/skills/technical/no-code-tools/LICENSE +21 -21
  1031. package/skills/technical/no-code-tools/SKILL.md +80 -80
  1032. package/skills/technical/open-source/LICENSE +21 -21
  1033. package/skills/technical/open-source/SKILL.md +71 -71
  1034. package/skills/technical/performance-optimization/LICENSE +21 -21
  1035. package/skills/technical/performance-optimization/SKILL.md +155 -155
  1036. package/skills/technical/pricing-design/LICENSE +21 -21
  1037. package/skills/technical/pricing-design/SKILL.md +87 -87
  1038. package/skills/technical/product-management/LICENSE +21 -21
  1039. package/skills/technical/product-management/SKILL.md +94 -94
  1040. package/skills/technical/saas-builder/LICENSE +21 -21
  1041. package/skills/technical/saas-builder/SKILL.md +138 -138
  1042. package/skills/technical/scope-estimation/LICENSE +21 -21
  1043. package/skills/technical/scope-estimation/SKILL.md +99 -99
  1044. package/skills/technical/secrets-management/LICENSE +21 -21
  1045. package/skills/technical/secrets-management/SKILL.md +135 -135
  1046. package/skills/technical/seo-technical/LICENSE +21 -21
  1047. package/skills/technical/seo-technical/SKILL.md +136 -136
  1048. package/skills/technical/technical-writing/LICENSE +21 -21
  1049. package/skills/technical/technical-writing/SKILL.md +149 -149
  1050. package/skills/technical/ux-research-tools/LICENSE +21 -21
  1051. package/skills/technical/ux-research-tools/SKILL.md +54 -54
  1052. package/skills/theme-factory/LICENSE +21 -21
  1053. package/skills/theme-factory/SKILL.md +65 -65
  1054. package/skills/theme-factory/themes/arctic-frost.md +19 -19
  1055. package/skills/theme-factory/themes/botanical-garden.md +19 -19
  1056. package/skills/theme-factory/themes/desert-rose.md +19 -19
  1057. package/skills/theme-factory/themes/forest-canopy.md +19 -19
  1058. package/skills/theme-factory/themes/golden-hour.md +19 -19
  1059. package/skills/theme-factory/themes/midnight-galaxy.md +19 -19
  1060. package/skills/theme-factory/themes/modern-minimalist.md +19 -19
  1061. package/skills/theme-factory/themes/ocean-depths.md +19 -19
  1062. package/skills/theme-factory/themes/sunset-boulevard.md +19 -19
  1063. package/skills/theme-factory/themes/tech-innovation.md +19 -19
  1064. package/skills/things-mac/SKILL.md +90 -90
  1065. package/skills/tmux/SKILL.md +95 -95
  1066. package/skills/tmux/scripts/find-sessions.sh +112 -112
  1067. package/skills/tmux/scripts/wait-for-text.sh +83 -83
  1068. package/skills/trades/trades-agriculture/LICENSE +21 -21
  1069. package/skills/trades/trades-agriculture/SKILL.md +80 -80
  1070. package/skills/trades/trades-automotive/LICENSE +21 -21
  1071. package/skills/trades/trades-automotive/SKILL.md +84 -84
  1072. package/skills/trades/trades-carpentry/LICENSE +21 -21
  1073. package/skills/trades/trades-carpentry/SKILL.md +71 -71
  1074. package/skills/trades/trades-cooking-pro/LICENSE +21 -21
  1075. package/skills/trades/trades-cooking-pro/SKILL.md +90 -90
  1076. package/skills/trades/trades-electrical/LICENSE +21 -21
  1077. package/skills/trades/trades-electrical/SKILL.md +146 -146
  1078. package/skills/trades/trades-hvac/LICENSE +21 -21
  1079. package/skills/trades/trades-hvac/SKILL.md +80 -80
  1080. package/skills/trades/trades-landscaping/LICENSE +21 -21
  1081. package/skills/trades/trades-landscaping/SKILL.md +60 -60
  1082. package/skills/trades/trades-metalworking/LICENSE +21 -21
  1083. package/skills/trades/trades-metalworking/SKILL.md +64 -64
  1084. package/skills/trades/trades-painting/LICENSE +21 -21
  1085. package/skills/trades/trades-painting/SKILL.md +70 -70
  1086. package/skills/trades/trades-plumbing/LICENSE +21 -21
  1087. package/skills/trades/trades-plumbing/SKILL.md +160 -160
  1088. package/skills/trades/trades-welding/LICENSE +21 -21
  1089. package/skills/trades/trades-welding/SKILL.md +82 -82
  1090. package/skills/trello/SKILL.md +112 -112
  1091. package/skills/uipm-ui-styling/SKILL.md +328 -328
  1092. package/skills/video-frames/SKILL.md +50 -50
  1093. package/skills/video-frames/scripts/frame.sh +81 -81
  1094. package/skills/voice-call/SKILL.md +49 -49
  1095. package/skills/wacli/SKILL.md +76 -76
  1096. package/skills/weather/SKILL.md +91 -91
  1097. package/skills/web-artifacts-builder/LICENSE +21 -21
  1098. package/skills/web-artifacts-builder/SKILL.md +82 -82
  1099. package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +53 -53
  1100. package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -322
  1101. package/skills/xurl/SKILL.md +124 -124
  1102. package/skills/graphify/SKILL.md +0 -619
  1103. package/skills/graphify/__init__.py +0 -28
  1104. package/skills/graphify/__main__.py +0 -4582
  1105. package/skills/graphify/affected.py +0 -154
  1106. package/skills/graphify/always_on/agents-md.md +0 -12
  1107. package/skills/graphify/always_on/antigravity-rules.md +0 -14
  1108. package/skills/graphify/always_on/claude-md.md +0 -9
  1109. package/skills/graphify/always_on/gemini-md.md +0 -9
  1110. package/skills/graphify/always_on/kiro-steering.md +0 -5
  1111. package/skills/graphify/always_on/vscode-instructions.md +0 -17
  1112. package/skills/graphify/analyze.py +0 -724
  1113. package/skills/graphify/benchmark.py +0 -155
  1114. package/skills/graphify/build.py +0 -487
  1115. package/skills/graphify/cache.py +0 -417
  1116. package/skills/graphify/callflow_html.py +0 -2020
  1117. package/skills/graphify/cluster.py +0 -272
  1118. package/skills/graphify/command-kilo.md +0 -15
  1119. package/skills/graphify/dedup.py +0 -429
  1120. package/skills/graphify/detect.py +0 -1379
  1121. package/skills/graphify/diagnostics.py +0 -390
  1122. package/skills/graphify/export.py +0 -1408
  1123. package/skills/graphify/extract.py +0 -11570
  1124. package/skills/graphify/global_graph.py +0 -159
  1125. package/skills/graphify/google_workspace.py +0 -223
  1126. package/skills/graphify/hooks.py +0 -457
  1127. package/skills/graphify/ingest.py +0 -331
  1128. package/skills/graphify/llm.py +0 -1896
  1129. package/skills/graphify/manifest.py +0 -4
  1130. package/skills/graphify/mcp_ingest.py +0 -392
  1131. package/skills/graphify/multigraph_compat.py +0 -212
  1132. package/skills/graphify/pg_introspect.py +0 -142
  1133. package/skills/graphify/prs.py +0 -748
  1134. package/skills/graphify/querylog.py +0 -70
  1135. package/skills/graphify/report.py +0 -218
  1136. package/skills/graphify/scip_ingest.py +0 -363
  1137. package/skills/graphify/security.py +0 -336
  1138. package/skills/graphify/semantic_cleanup.py +0 -319
  1139. package/skills/graphify/serve.py +0 -1309
  1140. package/skills/graphify/skill-aider.md +0 -1246
  1141. package/skills/graphify/skill-amp.md +0 -613
  1142. package/skills/graphify/skill-claw.md +0 -616
  1143. package/skills/graphify/skill-codex.md +0 -613
  1144. package/skills/graphify/skill-copilot.md +0 -616
  1145. package/skills/graphify/skill-devin.md +0 -1372
  1146. package/skills/graphify/skill-droid.md +0 -613
  1147. package/skills/graphify/skill-kilo.md +0 -625
  1148. package/skills/graphify/skill-kiro.md +0 -615
  1149. package/skills/graphify/skill-opencode.md +0 -608
  1150. package/skills/graphify/skill-pi.md +0 -615
  1151. package/skills/graphify/skill-trae.md +0 -614
  1152. package/skills/graphify/skill-vscode.md +0 -612
  1153. package/skills/graphify/skill-windows.md +0 -651
  1154. package/skills/graphify/skills/amp/references/add-watch.md +0 -56
  1155. package/skills/graphify/skills/amp/references/exports.md +0 -71
  1156. package/skills/graphify/skills/amp/references/extraction-spec.md +0 -68
  1157. package/skills/graphify/skills/amp/references/github-and-merge.md +0 -46
  1158. package/skills/graphify/skills/amp/references/hooks.md +0 -33
  1159. package/skills/graphify/skills/amp/references/query.md +0 -249
  1160. package/skills/graphify/skills/amp/references/transcribe.md +0 -48
  1161. package/skills/graphify/skills/amp/references/update.md +0 -179
  1162. package/skills/graphify/skills/claude/references/add-watch.md +0 -56
  1163. package/skills/graphify/skills/claude/references/exports.md +0 -71
  1164. package/skills/graphify/skills/claude/references/extraction-spec.md +0 -68
  1165. package/skills/graphify/skills/claude/references/github-and-merge.md +0 -46
  1166. package/skills/graphify/skills/claude/references/hooks.md +0 -33
  1167. package/skills/graphify/skills/claude/references/query.md +0 -103
  1168. package/skills/graphify/skills/claude/references/transcribe.md +0 -48
  1169. package/skills/graphify/skills/claude/references/update.md +0 -179
  1170. package/skills/graphify/skills/claw/references/add-watch.md +0 -56
  1171. package/skills/graphify/skills/claw/references/exports.md +0 -71
  1172. package/skills/graphify/skills/claw/references/extraction-spec.md +0 -29
  1173. package/skills/graphify/skills/claw/references/github-and-merge.md +0 -46
  1174. package/skills/graphify/skills/claw/references/hooks.md +0 -33
  1175. package/skills/graphify/skills/claw/references/query.md +0 -249
  1176. package/skills/graphify/skills/claw/references/transcribe.md +0 -48
  1177. package/skills/graphify/skills/claw/references/update.md +0 -179
  1178. package/skills/graphify/skills/codex/references/add-watch.md +0 -56
  1179. package/skills/graphify/skills/codex/references/exports.md +0 -71
  1180. package/skills/graphify/skills/codex/references/extraction-spec.md +0 -29
  1181. package/skills/graphify/skills/codex/references/github-and-merge.md +0 -46
  1182. package/skills/graphify/skills/codex/references/hooks.md +0 -33
  1183. package/skills/graphify/skills/codex/references/query.md +0 -249
  1184. package/skills/graphify/skills/codex/references/transcribe.md +0 -48
  1185. package/skills/graphify/skills/codex/references/update.md +0 -179
  1186. package/skills/graphify/skills/copilot/references/add-watch.md +0 -56
  1187. package/skills/graphify/skills/copilot/references/exports.md +0 -71
  1188. package/skills/graphify/skills/copilot/references/extraction-spec.md +0 -68
  1189. package/skills/graphify/skills/copilot/references/github-and-merge.md +0 -46
  1190. package/skills/graphify/skills/copilot/references/hooks.md +0 -33
  1191. package/skills/graphify/skills/copilot/references/query.md +0 -249
  1192. package/skills/graphify/skills/copilot/references/transcribe.md +0 -48
  1193. package/skills/graphify/skills/copilot/references/update.md +0 -179
  1194. package/skills/graphify/skills/droid/references/add-watch.md +0 -56
  1195. package/skills/graphify/skills/droid/references/exports.md +0 -71
  1196. package/skills/graphify/skills/droid/references/extraction-spec.md +0 -68
  1197. package/skills/graphify/skills/droid/references/github-and-merge.md +0 -46
  1198. package/skills/graphify/skills/droid/references/hooks.md +0 -33
  1199. package/skills/graphify/skills/droid/references/query.md +0 -249
  1200. package/skills/graphify/skills/droid/references/transcribe.md +0 -48
  1201. package/skills/graphify/skills/droid/references/update.md +0 -179
  1202. package/skills/graphify/skills/kilo/references/add-watch.md +0 -56
  1203. package/skills/graphify/skills/kilo/references/exports.md +0 -71
  1204. package/skills/graphify/skills/kilo/references/extraction-spec.md +0 -68
  1205. package/skills/graphify/skills/kilo/references/github-and-merge.md +0 -46
  1206. package/skills/graphify/skills/kilo/references/hooks.md +0 -33
  1207. package/skills/graphify/skills/kilo/references/query.md +0 -249
  1208. package/skills/graphify/skills/kilo/references/transcribe.md +0 -48
  1209. package/skills/graphify/skills/kilo/references/update.md +0 -179
  1210. package/skills/graphify/skills/kiro/references/add-watch.md +0 -56
  1211. package/skills/graphify/skills/kiro/references/exports.md +0 -71
  1212. package/skills/graphify/skills/kiro/references/extraction-spec.md +0 -29
  1213. package/skills/graphify/skills/kiro/references/github-and-merge.md +0 -46
  1214. package/skills/graphify/skills/kiro/references/hooks.md +0 -33
  1215. package/skills/graphify/skills/kiro/references/query.md +0 -249
  1216. package/skills/graphify/skills/kiro/references/transcribe.md +0 -48
  1217. package/skills/graphify/skills/kiro/references/update.md +0 -179
  1218. package/skills/graphify/skills/opencode/references/add-watch.md +0 -56
  1219. package/skills/graphify/skills/opencode/references/exports.md +0 -71
  1220. package/skills/graphify/skills/opencode/references/extraction-spec.md +0 -68
  1221. package/skills/graphify/skills/opencode/references/github-and-merge.md +0 -46
  1222. package/skills/graphify/skills/opencode/references/hooks.md +0 -33
  1223. package/skills/graphify/skills/opencode/references/query.md +0 -249
  1224. package/skills/graphify/skills/opencode/references/transcribe.md +0 -48
  1225. package/skills/graphify/skills/opencode/references/update.md +0 -179
  1226. package/skills/graphify/skills/pi/references/add-watch.md +0 -56
  1227. package/skills/graphify/skills/pi/references/exports.md +0 -71
  1228. package/skills/graphify/skills/pi/references/extraction-spec.md +0 -29
  1229. package/skills/graphify/skills/pi/references/github-and-merge.md +0 -46
  1230. package/skills/graphify/skills/pi/references/hooks.md +0 -33
  1231. package/skills/graphify/skills/pi/references/query.md +0 -249
  1232. package/skills/graphify/skills/pi/references/transcribe.md +0 -48
  1233. package/skills/graphify/skills/pi/references/update.md +0 -179
  1234. package/skills/graphify/skills/trae/references/add-watch.md +0 -56
  1235. package/skills/graphify/skills/trae/references/exports.md +0 -71
  1236. package/skills/graphify/skills/trae/references/extraction-spec.md +0 -68
  1237. package/skills/graphify/skills/trae/references/github-and-merge.md +0 -46
  1238. package/skills/graphify/skills/trae/references/hooks.md +0 -35
  1239. package/skills/graphify/skills/trae/references/query.md +0 -249
  1240. package/skills/graphify/skills/trae/references/transcribe.md +0 -48
  1241. package/skills/graphify/skills/trae/references/update.md +0 -179
  1242. package/skills/graphify/skills/vscode/references/add-watch.md +0 -56
  1243. package/skills/graphify/skills/vscode/references/exports.md +0 -71
  1244. package/skills/graphify/skills/vscode/references/extraction-spec.md +0 -68
  1245. package/skills/graphify/skills/vscode/references/github-and-merge.md +0 -46
  1246. package/skills/graphify/skills/vscode/references/hooks.md +0 -33
  1247. package/skills/graphify/skills/vscode/references/query.md +0 -249
  1248. package/skills/graphify/skills/vscode/references/transcribe.md +0 -48
  1249. package/skills/graphify/skills/vscode/references/update.md +0 -179
  1250. package/skills/graphify/skills/windows/references/add-watch.md +0 -56
  1251. package/skills/graphify/skills/windows/references/exports.md +0 -71
  1252. package/skills/graphify/skills/windows/references/extraction-spec.md +0 -68
  1253. package/skills/graphify/skills/windows/references/github-and-merge.md +0 -46
  1254. package/skills/graphify/skills/windows/references/hooks.md +0 -33
  1255. package/skills/graphify/skills/windows/references/query.md +0 -249
  1256. package/skills/graphify/skills/windows/references/transcribe.md +0 -48
  1257. package/skills/graphify/skills/windows/references/update.md +0 -179
  1258. package/skills/graphify/symbol_resolution.py +0 -538
  1259. package/skills/graphify/transcribe.py +0 -184
  1260. package/skills/graphify/tree_html.py +0 -582
  1261. package/skills/graphify/validate.py +0 -72
  1262. package/skills/graphify/watch.py +0 -898
  1263. package/skills/graphify/wiki.py +0 -282
@@ -1,1372 +0,0 @@
1
- ---
2
- name: graphify
3
- description: "Use for any question about a codebase, its architecture, file relationships, or project content — especially when graphify-out/ exists, where the question should be treated as a graphify query first. Turns any input (code, docs, papers, images, videos) into a persistent knowledge graph with god nodes, community detection, and query/path/explain tools."
4
- argument-hint: "[path|query|subcommand]"
5
- model: sonnet
6
- allowed-tools:
7
- - read
8
- - grep
9
- - glob
10
- - exec
11
- triggers:
12
- - user
13
- - model
14
- ---
15
-
16
- # /graphify
17
-
18
- Turn any folder of files into a navigable knowledge graph with community detection, an honest audit trail, and three outputs: interactive HTML, GraphRAG-ready JSON, and a plain-language GRAPH_REPORT.md.
19
-
20
- ## Usage
21
-
22
- ```
23
- /graphify # full pipeline on current directory
24
- /graphify <path> # full pipeline on specific path
25
- /graphify <path> --mode deep # thorough extraction, richer INFERRED edges
26
- /graphify <path> --update # incremental - re-extract only new/changed files
27
- /graphify <path> --cluster-only # rerun clustering on existing graph
28
- /graphify <path> --no-viz # skip visualization, just report + JSON
29
- /graphify <path> --html # (HTML is generated by default - this flag is a no-op)
30
- /graphify <path> --svg # also export graph.svg (embeds in Notion, GitHub)
31
- /graphify <path> --graphml # export graph.graphml (Gephi, yEd)
32
- /graphify <path> --neo4j # generate graphify-out/cypher.txt for Neo4j
33
- /graphify <path> --neo4j-push bolt://localhost:7687 # push directly to Neo4j
34
- /graphify <path> --mcp # start MCP stdio server for agent access
35
- /graphify <path> --watch # watch folder, auto-rebuild on code changes (no LLM needed)
36
- /graphify <path> --wiki # build agent-crawlable wiki (index.md + one article per community)
37
- /graphify add <url> # fetch URL, save to ./raw, update graph
38
- /graphify add <url> --author "Name" # tag who wrote it
39
- /graphify add <url> --contributor "Name" # tag who added it to the corpus
40
- /graphify query "<question>" # BFS traversal - broad context
41
- /graphify query "<question>" --dfs # DFS - trace a specific path
42
- /graphify query "<question>" --budget 1500 # cap answer at N tokens
43
- /graphify path "AuthModule" "Database" # shortest path between two concepts
44
- /graphify explain "SwinTransformer" # plain-language explanation of a node
45
- ```
46
-
47
- ## What graphify is for
48
-
49
- graphify is built around Andrej Karpathy's /raw folder workflow: drop anything into a folder - papers, tweets, screenshots, code, notes - and get a structured knowledge graph that shows you what you didn't know was connected.
50
-
51
- Three things it does that your AI assistant alone cannot:
52
- 1. **Persistent graph** - relationships are stored in `graphify-out/graph.json` and survive across sessions. Ask questions weeks later without re-reading everything.
53
- 2. **Honest audit trail** - every edge is tagged EXTRACTED, INFERRED, or AMBIGUOUS. You know what was found vs invented.
54
- 3. **Cross-document surprise** - community detection finds connections between concepts in different files that you would never think to ask about directly.
55
-
56
- Use it for:
57
- - A codebase you're new to (understand architecture before touching anything)
58
- - A reading list (papers + tweets + notes -> one navigable graph)
59
- - A research corpus (citation graph + concept graph in one)
60
- - Your personal /raw folder (drop everything in, let it grow, query it)
61
-
62
- ## What You Must Do When Invoked
63
-
64
- If the user invoked `/graphify --help` or `/graphify -h` (with no other arguments), print the contents of the `## Usage` section above verbatim and stop. Do not run any commands, do not detect files, do not default the path to `.`. Just print the Usage block and return.
65
-
66
- If no path was given, use `.` (current directory). Do not ask the user for a path.
67
-
68
- Follow these steps in order. Do not skip steps.
69
-
70
- ### Step 1 - Ensure graphify is installed
71
-
72
- ```bash
73
- # Detect the correct Python interpreter (handles uv tool, pipx, venv, system installs)
74
- PYTHON=""
75
- GRAPHIFY_BIN=$(which graphify 2>/dev/null)
76
- # 1. uv tool installs — most reliable on modern Mac/Linux
77
- if [ -z "$PYTHON" ] && command -v uv >/dev/null 2>&1; then
78
- _UV_PY=$(uv tool run graphifyy python -c "import sys; print(sys.executable)" 2>/dev/null)
79
- if [ -n "$_UV_PY" ]; then PYTHON="$_UV_PY"; fi
80
- fi
81
- # 2. Read shebang from graphify binary (pipx and direct pip installs)
82
- if [ -z "$PYTHON" ] && [ -n "$GRAPHIFY_BIN" ]; then
83
- _SHEBANG=$(head -1 "$GRAPHIFY_BIN" | tr -d '#!')
84
- case "$_SHEBANG" in
85
- *[!a-zA-Z0-9/_.-]*) ;;
86
- *) "$_SHEBANG" -c "import graphify" 2>/dev/null && PYTHON="$_SHEBANG" ;;
87
- esac
88
- fi
89
- # 3. Fall back to python3
90
- if [ -z "$PYTHON" ]; then PYTHON="python3"; fi
91
- if ! "$PYTHON" -c "import graphify" 2>/dev/null; then
92
- if command -v uv >/dev/null 2>&1; then
93
- uv tool install --upgrade graphifyy -q 2>&1 | tail -3
94
- _UV_PY=$(uv tool run graphifyy python -c "import sys; print(sys.executable)" 2>/dev/null)
95
- if [ -n "$_UV_PY" ]; then PYTHON="$_UV_PY"; fi
96
- else
97
- "$PYTHON" -m pip install graphifyy -q 2>/dev/null \
98
- || "$PYTHON" -m pip install graphifyy -q --break-system-packages 2>&1 | tail -3
99
- fi
100
- fi
101
- # Write interpreter path for all subsequent steps (persists across invocations)
102
- mkdir -p graphify-out
103
- "$PYTHON" -c "import sys; open('graphify-out/.graphify_python', 'w', encoding='utf-8').write(sys.executable)"
104
- # Force UTF-8 I/O on Windows (prevents garbled CJK/non-ASCII output)
105
- export PYTHONUTF8=1
106
- ```
107
-
108
- If the import succeeds, print nothing and move straight to Step 2.
109
-
110
- **In every subsequent bash block, replace `python3` with `$(cat graphify-out/.graphify_python)` to use the correct interpreter.**
111
-
112
- ### Step 2 - Detect files
113
-
114
- ```bash
115
- $(cat graphify-out/.graphify_python) -c "
116
- import json
117
- from graphify.detect import detect
118
- from pathlib import Path
119
- result = detect(Path('INPUT_PATH'))
120
- print(json.dumps(result))
121
- " > graphify-out/.graphify_detect.json
122
- ```
123
-
124
- Replace INPUT_PATH with the actual path the user provided. Do NOT cat or print the JSON - read it silently and present a clean summary instead:
125
-
126
- ```
127
- Corpus: X files · ~Y words
128
- code: N files (.py .ts .go ...)
129
- docs: N files (.md .txt ...)
130
- papers: N files (.pdf ...)
131
- images: N files
132
- video: N files (.mp4 .mp3 ...)
133
- ```
134
-
135
- Omit any category with 0 files from the summary.
136
-
137
- Then act on it:
138
- - If `total_files` is 0: stop with "No supported files found in [path]."
139
- - If `skipped_sensitive` is non-empty: mention file count skipped, not the file names.
140
- - If `total_words` > 2,000,000 OR `total_files` > 200: show the warning and the top 5 subdirectories by file count, then ask which subfolder to run on. Wait for the user's answer before proceeding.
141
- - Otherwise: proceed directly to Step 2.5 if video files were detected, or Step 3 if not.
142
-
143
- ### Step 2.5 - Transcribe video / audio files (only if video files detected)
144
-
145
- Skip this step entirely if `detect` returned zero `video` files.
146
-
147
- Video and audio files cannot be read directly. Transcribe them to text first, then treat the transcripts as doc files in Step 3.
148
-
149
- **Strategy:** Read the god nodes from the detect output or analysis file. You are already a language model - write a one-sentence domain hint yourself from those labels. Then pass it to Whisper as the initial prompt. No separate API call needed.
150
-
151
- **However**, if the corpus has *only* video files and no other docs/code, use the generic fallback prompt: `"Use proper punctuation and paragraph breaks."`
152
-
153
- **Step 1 - Write the Whisper prompt yourself.**
154
-
155
- Read the top god node labels from detect output or analysis, then compose a short domain hint sentence, for example:
156
-
157
- - Labels: `transformer, attention, encoder, decoder` -> `"Machine learning research on transformer architectures and attention mechanisms. Use proper punctuation and paragraph breaks."`
158
- - Labels: `kubernetes, deployment, pod, helm` -> `"DevOps discussion about Kubernetes deployments and Helm charts. Use proper punctuation and paragraph breaks."`
159
-
160
- Set it as `GRAPHIFY_WHISPER_PROMPT` in the environment before running the transcription command.
161
-
162
- **Step 2 - Transcribe:**
163
-
164
- ```bash
165
- $(cat graphify-out/.graphify_python) -c "
166
- import json, os
167
- from pathlib import Path
168
- from graphify.transcribe import transcribe_all
169
-
170
- detect = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
171
- video_files = detect.get('files', {}).get('video', [])
172
- prompt = os.environ.get('GRAPHIFY_WHISPER_PROMPT', 'Use proper punctuation and paragraph breaks.')
173
-
174
- transcript_paths = transcribe_all(video_files, initial_prompt=prompt)
175
- print(json.dumps(transcript_paths))
176
- " > graphify-out/.graphify_transcripts.json
177
- ```
178
-
179
- After transcription:
180
- - Read the transcript paths from `graphify-out/.graphify_transcripts.json`
181
- - Add them to the docs list before dispatching semantic subagents in Step 3B
182
- - Print how many transcripts were created: `Transcribed N video file(s) -> treating as docs`
183
- - If transcription fails for a file, print a warning and continue with the rest
184
-
185
- **Whisper model:** Default is `base`. If the user passed `--whisper-model <name>`, set `GRAPHIFY_WHISPER_MODEL=<name>` in the environment before running the command above.
186
-
187
- ### Step 3 - Extract entities and relationships
188
-
189
- **Before starting:** note whether `--mode deep` was given. You must pass `DEEP_MODE=true` to every subagent in Step B2 if it was. Track this from the original invocation - do not lose it.
190
-
191
- This step has two parts: **structural extraction** (deterministic, free) and **semantic extraction** (your AI model, costs tokens).
192
-
193
- **Run Part A (AST) and Part B (semantic) in parallel. Dispatch all semantic subagents AND start AST extraction in the same message. Both can run simultaneously since they operate on different file types. Merge results in Part C as before.**
194
-
195
- Note: Parallelizing AST + semantic saves 5-15s on large corpora. AST is deterministic and fast; start it while subagents are processing docs/papers.
196
-
197
- #### Part A - Structural extraction for code files
198
-
199
- For any code files detected, run AST extraction in parallel with Part B subagents:
200
-
201
- ```bash
202
- $(cat graphify-out/.graphify_python) -c "
203
- import sys, json
204
- from graphify.extract import collect_files, extract
205
- from pathlib import Path
206
- import json
207
-
208
- code_files = []
209
- detect = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
210
- for f in detect.get('files', {}).get('code', []):
211
- code_files.extend(collect_files(Path(f)) if Path(f).is_dir() else [Path(f)])
212
-
213
- if code_files:
214
- result = extract(code_files)
215
- Path('graphify-out/.graphify_ast.json').write_text(json.dumps(result, indent=2))
216
- print(f'AST: {len(result[\"nodes\"])} nodes, {len(result[\"edges\"])} edges')
217
- else:
218
- Path('graphify-out/.graphify_ast.json').write_text(json.dumps({'nodes':[],'edges':[],'input_tokens':0,'output_tokens':0}))
219
- print('No code files - skipping AST extraction')
220
- "
221
- ```
222
-
223
- #### Part B - Semantic extraction (parallel subagents)
224
-
225
- **Fast path:** If detection found zero docs, papers, and images (code-only corpus), skip Part B entirely and go straight to Part C. AST handles code - there is nothing for semantic subagents to do.
226
-
227
- Before dispatching subagents, print a timing estimate:
228
- - Load `total_words` and file counts from `graphify-out/.graphify_detect.json`
229
- - Estimate agents needed: `ceil(uncached_non_code_files / 22)` (chunk size is 20-25)
230
- - Estimate time: ~45s per agent batch (they run in parallel, so total ≈ 45s × ceil(agents/parallel_limit))
231
- - Print: "Semantic extraction: ~N files → X agents, estimated ~Ys"
232
-
233
- **MANDATORY: You MUST use the subagent system here. Reading files yourself one-by-one is forbidden - it is 5-10x slower. If you do not use parallel subagents you are doing this wrong.**
234
-
235
- **Step B0 - Check extraction cache first**
236
-
237
- Before dispatching any subagents, check which files already have cached extraction results:
238
-
239
- ```bash
240
- $(cat graphify-out/.graphify_python) -c "
241
- import json
242
- from graphify.cache import check_semantic_cache
243
- from pathlib import Path
244
-
245
- detect = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
246
- all_files = [f for files in detect['files'].values() for f in files]
247
-
248
- cached_nodes, cached_edges, cached_hyperedges, uncached = check_semantic_cache(all_files)
249
-
250
- if cached_nodes or cached_edges or cached_hyperedges:
251
- Path('graphify-out/.graphify_cached.json').write_text(json.dumps({'nodes': cached_nodes, 'edges': cached_edges, 'hyperedges': cached_hyperedges}))
252
- Path('graphify-out/.graphify_uncached.txt').write_text('\n'.join(uncached))
253
- print(f'Cache: {len(all_files)-len(uncached)} files hit, {len(uncached)} files need extraction')
254
- "
255
- ```
256
-
257
- Only dispatch subagents for files listed in `graphify-out/.graphify_uncached.txt`. If all files are cached, skip to Part C directly.
258
-
259
- **Step B1 - Split into chunks**
260
-
261
- Load files from `graphify-out/.graphify_uncached.txt`. Split into chunks of 20-25 files each. Each image gets its own chunk (vision needs separate context). When splitting, group files from the same directory together so related artifacts land in the same chunk and cross-file relationships are more likely to be extracted.
262
-
263
- **Step B2 - Dispatch subagents**
264
-
265
- Dispatch ALL subagents in the same response so they run in parallel.
266
-
267
- Concrete example for 3 chunks:
268
- ```
269
- [Subagent 1: files 1-15]
270
- [Subagent 2: files 16-30]
271
- [Subagent 3: files 31-45]
272
- ```
273
- All three in one message. Not three separate messages.
274
-
275
- For each chunk, dispatch a subagent with this exact prompt (fill in FILE_LIST):
276
-
277
- ```
278
- You are a graphify extraction subagent. Read the files listed and extract a knowledge graph fragment.
279
- Output ONLY valid JSON with no commentary: {"nodes": [...], "edges": [...], "hyperedges": [...], "input_tokens": 0, "output_tokens": 0}
280
-
281
- Extraction rules:
282
- - EXTRACTED: relationship explicit in source (import, call, citation)
283
- - INFERRED: reasonable inference (shared structure, implied dependency)
284
- - AMBIGUOUS: uncertain — flag it, do not omit
285
- - Code files: extract semantic edges AST cannot find (design patterns, protocol conformance). Do not re-extract imports.
286
- - Doc/paper files: named concepts, entities, citations. Store rationale (WHY decisions were made) as a `rationale` attribute on the relevant node. Use `file_type:"rationale"` for concept-like nodes (ideas, principles, mechanisms) and `file_type:"concept"` for named concepts. `file_type` MUST be one of exactly these six values: `code`, `document`, `paper`, `image`, `rationale`, `concept`. When adding `calls` edges: source is caller, target is callee.
287
- - Image files: use vision to understand what the image IS - do not just OCR.
288
- UI screenshot: layout patterns, design decisions, key elements, purpose.
289
- Chart: metric, trend/insight, data source.
290
- Tweet/post: claim as node, author, concepts mentioned.
291
- Diagram: components and connections.
292
- Research figure: what it demonstrates, method, result.
293
- Handwritten/whiteboard: ideas and arrows, mark uncertain readings AMBIGUOUS.
294
- - DEEP_MODE (if set): be aggressive with INFERRED edges
295
- - Semantic similarity: if two concepts solve the same problem without a structural link, add `semantically_similar_to` INFERRED edge (confidence 0.6-0.95). Non-obvious cross-file links only.
296
- - Hyperedges: if 3+ nodes share a concept/flow not captured by pairwise edges, add a hyperedge. Max 3 per file.
297
- - If a file has YAML frontmatter (--- ... ---), copy source_url, captured_at, author,
298
- contributor onto every node from that file.
299
- - confidence_score is REQUIRED on every edge - never omit it, never use 0.5 as a default:
300
- - EXTRACTED edges: confidence_score = 1.0 always
301
- - INFERRED edges: pick exactly ONE value from this set — never 0.5:
302
- 0.95 direct structural evidence (shared data structure, named cross-file reference).
303
- 0.85 strong inference (clear functional alignment, no direct symbol link).
304
- 0.75 reasonable inference (shared problem domain + similar shape, requires interpretation).
305
- 0.65 weak inference (thematically related, no shape evidence).
306
- 0.55 speculative but plausible (surface-level co-occurrence only).
307
- Models follow discrete rubrics better than continuous ranges; the bimodal
308
- distribution observed in production (>50% at 0.5, >40% at 0.85+) shows the
309
- range guidance is being collapsed to a binary. If no value above fits, mark
310
- the edge AMBIGUOUS rather than picking 0.4 or below.
311
- - AMBIGUOUS edges: 0.1-0.3
312
-
313
- Schema:
314
- {"nodes":[{"id":"filestem_entityname","label":"Human Readable Name","file_type":"code|document|paper|image|rationale|concept","source_file":"relative/path","source_location":null,"source_url":null,"captured_at":null,"author":null,"contributor":null}],"edges":[{"source":"node_id","target":"node_id","relation":"calls|implements|references|cites|conceptually_related_to|shares_data_with|semantically_similar_to|rationale_for","confidence":"EXTRACTED|INFERRED|AMBIGUOUS","confidence_score":1.0,"source_file":"relative/path","source_location":null,"weight":1.0}],"hyperedges":[{"id":"snake_case_id","label":"Human Readable Label","nodes":["node_id1","node_id2","node_id3"],"relation":"participate_in|implement|form","confidence":"EXTRACTED|INFERRED","confidence_score":0.75,"source_file":"relative/path"}],"input_tokens":0,"output_tokens":0}
315
-
316
- Files:
317
- FILE_LIST
318
- ```
319
-
320
- **Step B3 - Cache and merge**
321
-
322
- Wait for all subagents. For each result:
323
- - Check that `graphify-out/.graphify_chunk_N.json` exists on disk — this is the success signal
324
- - If the file exists and contains valid JSON with `nodes` and `edges`, include it and save to cache
325
- - If the file is missing, the subagent was likely dispatched as read-only — print a warning: "chunk N missing from disk — subagent may have been read-only. Re-run with general-purpose agent." Do not silently skip.
326
- - If a subagent failed or returned invalid JSON, print a warning and skip that chunk - do not abort
327
-
328
- If more than half the chunks failed or are missing, stop and tell the user to re-run and ensure `subagent_type="general-purpose"` is used.
329
-
330
- After each subagent call completes, write its result to `graphify-out/.graphify_chunk_N.json`. **After each subagent call completes, read the real token counts from the subagent tool result's `usage` field and write them back into the chunk JSON before merging** — the chunk JSON itself always has placeholder zeros. Then merge:
331
-
332
- ```bash
333
- $(cat graphify-out/.graphify_python) -c "
334
- import json, glob
335
- from pathlib import Path
336
- from graphify.semantic_cleanup import load_validated_semantic_fragment, sanitize_semantic_fragment
337
-
338
- chunks = sorted(glob.glob('graphify-out/.graphify_chunk_*.json'))
339
- all_nodes, all_edges, all_hyperedges = [], [], []
340
- total_in, total_out = 0, 0
341
- for c in chunks:
342
- d, errors = load_validated_semantic_fragment(Path(c))
343
- if errors:
344
- print(f'Skipping invalid chunk {c}: ' + '; '.join(errors[:3]))
345
- continue
346
- d = sanitize_semantic_fragment(d)
347
- all_nodes += d.get('nodes', [])
348
- all_edges += d.get('edges', [])
349
- all_hyperedges += d.get('hyperedges', [])
350
- total_in += d.get('input_tokens', 0)
351
- total_out += d.get('output_tokens', 0)
352
- Path('graphify-out/.graphify_semantic_new.json').write_text(json.dumps({
353
- 'nodes': all_nodes, 'edges': all_edges, 'hyperedges': all_hyperedges,
354
- 'input_tokens': total_in, 'output_tokens': total_out,
355
- }, indent=2))
356
- print(f'Merged {len(chunks)} chunks: {total_in:,} in / {total_out:,} out tokens')
357
- "
358
- ```
359
-
360
- Save new results to cache:
361
- ```bash
362
- $(cat graphify-out/.graphify_python) -c "
363
- import json
364
- from graphify.cache import save_semantic_cache
365
- from pathlib import Path
366
-
367
- new = json.loads(Path('graphify-out/.graphify_semantic_new.json').read_text()) if Path('graphify-out/.graphify_semantic_new.json').exists() else {'nodes':[],'edges':[],'hyperedges':[]}
368
- saved = save_semantic_cache(new.get('nodes', []), new.get('edges', []), new.get('hyperedges', []))
369
- print(f'Cached {saved} files')
370
- "
371
- ```
372
-
373
- Merge cached + new results into `graphify-out/.graphify_semantic.json`:
374
- ```bash
375
- $(cat graphify-out/.graphify_python) -c "
376
- import json
377
- from pathlib import Path
378
- from graphify.semantic_cleanup import sanitize_semantic_fragment
379
-
380
- cached = json.loads(Path('graphify-out/.graphify_cached.json').read_text()) if Path('graphify-out/.graphify_cached.json').exists() else {'nodes':[],'edges':[],'hyperedges':[]}
381
- new = json.loads(Path('graphify-out/.graphify_semantic_new.json').read_text()) if Path('graphify-out/.graphify_semantic_new.json').exists() else {'nodes':[],'edges':[],'hyperedges':[]}
382
-
383
- all_nodes = cached['nodes'] + new.get('nodes', [])
384
- all_edges = cached['edges'] + new.get('edges', [])
385
- all_hyperedges = cached.get('hyperedges', []) + new.get('hyperedges', [])
386
- seen = set()
387
- deduped = []
388
- for n in all_nodes:
389
- if n['id'] not in seen:
390
- seen.add(n['id'])
391
- deduped.append(n)
392
-
393
- merged = {
394
- 'nodes': deduped,
395
- 'edges': all_edges,
396
- 'hyperedges': all_hyperedges,
397
- 'input_tokens': new.get('input_tokens', 0),
398
- 'output_tokens': new.get('output_tokens', 0),
399
- }
400
- merged = sanitize_semantic_fragment(merged)
401
- Path('graphify-out/.graphify_semantic.json').write_text(json.dumps(merged, indent=2))
402
- print(f'Extraction complete - {len(deduped)} nodes, {len(all_edges)} edges ({len(cached[\"nodes\"])} from cache, {len(new.get(\"nodes\",[]))} new)')
403
- "
404
- ```
405
- Clean up temp files: `rm -f graphify-out/.graphify_cached.json graphify-out/.graphify_uncached.txt graphify-out/.graphify_semantic_new.json`
406
-
407
- #### Part C - Merge AST + semantic into final extraction
408
-
409
- ```bash
410
- $(cat graphify-out/.graphify_python) -c "
411
- import sys, json
412
- from pathlib import Path
413
- from graphify.semantic_cleanup import sanitize_semantic_fragment
414
-
415
- ast = json.loads(Path('graphify-out/.graphify_ast.json').read_text())
416
- sem = json.loads(Path('graphify-out/.graphify_semantic.json').read_text())
417
-
418
- # Merge: AST nodes first, semantic nodes deduplicated by id
419
- seen = {n['id'] for n in ast['nodes']}
420
- merged_nodes = list(ast['nodes'])
421
- for n in sem['nodes']:
422
- if n['id'] not in seen:
423
- merged_nodes.append(n)
424
- seen.add(n['id'])
425
-
426
- merged_edges = ast['edges'] + sem['edges']
427
- merged_hyperedges = sem.get('hyperedges', [])
428
- merged = {
429
- 'nodes': merged_nodes,
430
- 'edges': merged_edges,
431
- 'hyperedges': merged_hyperedges,
432
- 'input_tokens': sem.get('input_tokens', 0),
433
- 'output_tokens': sem.get('output_tokens', 0),
434
- }
435
- merged = sanitize_semantic_fragment(merged)
436
- Path('graphify-out/.graphify_extract.json').write_text(json.dumps(merged, indent=2))
437
- total = len(merged_nodes)
438
- edges = len(merged_edges)
439
- print(f'Merged: {total} nodes, {edges} edges ({len(ast[\"nodes\"])} AST + {len(sem[\"nodes\"])} semantic)')
440
- "
441
- ```
442
-
443
- ### Step 4 - Build graph, cluster, analyze, generate outputs
444
-
445
- ```bash
446
- mkdir -p graphify-out
447
- $(cat graphify-out/.graphify_python) -c "
448
- import sys, json
449
- from graphify.build import build_from_json
450
- from graphify.cluster import cluster, score_all
451
- from graphify.analyze import god_nodes, surprising_connections, suggest_questions
452
- from graphify.report import generate
453
- from graphify.export import to_json
454
- from pathlib import Path
455
-
456
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
457
- detection = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
458
-
459
- G = build_from_json(extraction)
460
- communities = cluster(G)
461
- cohesion = score_all(G, communities)
462
- tokens = {'input': extraction.get('input_tokens', 0), 'output': extraction.get('output_tokens', 0)}
463
- gods = god_nodes(G)
464
- surprises = surprising_connections(G, communities)
465
- labels = {cid: 'Community ' + str(cid) for cid in communities}
466
- # Placeholder questions - regenerated with real labels in Step 5
467
- questions = suggest_questions(G, communities, labels)
468
-
469
- report = generate(G, communities, cohesion, labels, gods, surprises, detection, tokens, 'INPUT_PATH', suggested_questions=questions)
470
- Path('graphify-out/GRAPH_REPORT.md').write_text(report)
471
- to_json(G, communities, 'graphify-out/graph.json')
472
-
473
- analysis = {
474
- 'communities': {str(k): v for k, v in communities.items()},
475
- 'cohesion': {str(k): v for k, v in cohesion.items()},
476
- 'gods': gods,
477
- 'surprises': surprises,
478
- 'questions': questions,
479
- }
480
- Path('graphify-out/.graphify_analysis.json').write_text(json.dumps(analysis, indent=2))
481
- if G.number_of_nodes() == 0:
482
- print('ERROR: Graph is empty - extraction produced no nodes.')
483
- print('Possible causes: all files were skipped, binary-only corpus, or extraction failed.')
484
- raise SystemExit(1)
485
- print(f'Graph: {G.number_of_nodes()} nodes, {G.number_of_edges()} edges, {len(communities)} communities')
486
- "
487
- ```
488
-
489
- If this step prints `ERROR: Graph is empty`, stop and tell the user what happened - do not proceed to labeling or visualization.
490
-
491
- Replace INPUT_PATH with the actual path.
492
-
493
- ### Step 5 - Label communities
494
-
495
- Read `graphify-out/.graphify_analysis.json`. For each community key, look at its node labels and write a 2-5 word plain-language name (e.g. "Attention Mechanism", "Training Pipeline", "Data Loading").
496
-
497
- Then regenerate the report and save the labels for the visualizer:
498
-
499
- ```bash
500
- $(cat graphify-out/.graphify_python) -c "
501
- import sys, json
502
- from graphify.build import build_from_json
503
- from graphify.cluster import score_all
504
- from graphify.analyze import god_nodes, surprising_connections, suggest_questions
505
- from graphify.report import generate
506
- from pathlib import Path
507
-
508
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
509
- detection = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
510
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
511
-
512
- G = build_from_json(extraction)
513
- communities = {int(k): v for k, v in analysis['communities'].items()}
514
- cohesion = {int(k): v for k, v in analysis['cohesion'].items()}
515
- tokens = {'input': extraction.get('input_tokens', 0), 'output': extraction.get('output_tokens', 0)}
516
-
517
- # LABELS - replace these with the names you chose above
518
- labels = LABELS_DICT
519
-
520
- # Regenerate questions with real community labels (labels affect question phrasing)
521
- questions = suggest_questions(G, communities, labels)
522
-
523
- report = generate(G, communities, cohesion, labels, analysis['gods'], analysis['surprises'], detection, tokens, 'INPUT_PATH', suggested_questions=questions)
524
- Path('graphify-out/GRAPH_REPORT.md').write_text(report)
525
- Path('graphify-out/.graphify_labels.json').write_text(json.dumps({str(k): v for k, v in labels.items()}))
526
- print('Report updated with community labels')
527
- "
528
- ```
529
-
530
- Replace `LABELS_DICT` with the actual dict you constructed (e.g. `{0: "Attention Mechanism", 1: "Training Pipeline"}`).
531
- Replace INPUT_PATH with the actual path.
532
-
533
- ### Step 6 - Generate Obsidian vault (opt-in) + HTML
534
-
535
- **Generate HTML always** (unless `--no-viz`). **Obsidian vault only if `--obsidian` was explicitly given** — skip it otherwise, it generates one file per node.
536
-
537
- If `--obsidian` was given:
538
-
539
- ```bash
540
- $(cat graphify-out/.graphify_python) -c "
541
- import sys, json
542
- from graphify.build import build_from_json
543
- from graphify.export import to_obsidian, to_canvas
544
- from pathlib import Path
545
-
546
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
547
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
548
- labels_raw = json.loads(Path('graphify-out/.graphify_labels.json').read_text()) if Path('graphify-out/.graphify_labels.json').exists() else {}
549
-
550
- G = build_from_json(extraction)
551
- communities = {int(k): v for k, v in analysis['communities'].items()}
552
- cohesion = {int(k): v for k, v in analysis['cohesion'].items()}
553
- labels = {int(k): v for k, v in labels_raw.items()}
554
-
555
- n = to_obsidian(G, communities, 'graphify-out/obsidian', community_labels=labels or None, cohesion=cohesion)
556
- print(f'Obsidian vault: {n} notes in graphify-out/obsidian/')
557
-
558
- to_canvas(G, communities, 'graphify-out/obsidian/graph.canvas', community_labels=labels or None)
559
- print('Canvas: graphify-out/obsidian/graph.canvas - open in Obsidian for structured community layout')
560
- print()
561
- print('Open graphify-out/obsidian/ as a vault in Obsidian.')
562
- print(' Graph view - nodes colored by community (set automatically)')
563
- print(' graph.canvas - structured layout with communities as groups')
564
- print(' _COMMUNITY_* - overview notes with cohesion scores and dataview queries')
565
- "
566
- ```
567
-
568
- Generate the HTML graph (always, unless `--no-viz`):
569
-
570
- ```bash
571
- $(cat graphify-out/.graphify_python) -c "
572
- import sys, json
573
- from graphify.build import build_from_json
574
- from graphify.export import to_html
575
- from pathlib import Path
576
-
577
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
578
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
579
- labels_raw = json.loads(Path('graphify-out/.graphify_labels.json').read_text()) if Path('graphify-out/.graphify_labels.json').exists() else {}
580
-
581
- G = build_from_json(extraction)
582
- communities = {int(k): v for k, v in analysis['communities'].items()}
583
- labels = {int(k): v for k, v in labels_raw.items()}
584
-
585
- NODE_LIMIT = 5000
586
- if G.number_of_nodes() > NODE_LIMIT:
587
- from collections import Counter
588
- print(f'Graph has {G.number_of_nodes()} nodes (above {NODE_LIMIT} limit). Building aggregated community view...')
589
- node_to_community = {nid: cid for cid, members in communities.items() for nid in members}
590
- import networkx as nx_meta
591
- meta = nx_meta.Graph()
592
- for cid, members in communities.items():
593
- meta.add_node(str(cid), label=labels.get(cid, f'Community {cid}'))
594
- edge_counts = Counter()
595
- for u, v in G.edges():
596
- cu, cv = node_to_community.get(u), node_to_community.get(v)
597
- if cu is not None and cv is not None and cu != cv:
598
- edge_counts[(min(cu, cv), max(cu, cv))] += 1
599
- for (cu, cv), w in edge_counts.items():
600
- meta.add_edge(str(cu), str(cv), weight=w, relation=f'{w} cross-community edges', confidence='AGGREGATED')
601
- if meta.number_of_nodes() > 1:
602
- meta_communities = {cid: [str(cid)] for cid in communities}
603
- member_counts = {cid: len(members) for cid, members in communities.items()}
604
- to_html(meta, meta_communities, 'graphify-out/graph.html', community_labels=labels or None, member_counts=member_counts)
605
- print(f'graph.html written (aggregated: {meta.number_of_nodes()} community nodes, {meta.number_of_edges()} cross-community edges)')
606
- print('Tip: run with --obsidian for full node-level detail, or --wiki for an agent-crawlable wiki.')
607
- else:
608
- print('Single community — aggregated view not useful. Skipping graph.html.')
609
- else:
610
- to_html(G, communities, 'graphify-out/graph.html', community_labels=labels or None)
611
- print('graph.html written - open in any browser, no server needed')
612
- "
613
- ```
614
-
615
- ### Step 6b - Wiki (only if --wiki flag)
616
-
617
- **Only run this step if `--wiki` was explicitly given in the original command.**
618
-
619
- The wiki is an agent-crawlable export — `index.md` plus one article per community plus god-node articles. It is the recommended fallback for graphs too large to render as HTML, and it's the most useful output for an autonomous agent navigating the graph between sessions.
620
-
621
- Run this before Step 9 (cleanup) so `graphify-out/.graphify_labels.json` is still available.
622
-
623
- ```bash
624
- $(cat graphify-out/.graphify_python) -c "
625
- import json
626
- from graphify.build import build_from_json
627
- from graphify.wiki import to_wiki
628
- from graphify.analyze import god_nodes
629
- from pathlib import Path
630
-
631
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
632
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
633
- labels_raw = json.loads(Path('graphify-out/.graphify_labels.json').read_text()) if Path('graphify-out/.graphify_labels.json').exists() else {}
634
-
635
- G = build_from_json(extraction)
636
- communities = {int(k): v for k, v in analysis['communities'].items()}
637
- cohesion = {int(k): v for k, v in analysis['cohesion'].items()}
638
- labels = {int(k): v for k, v in labels_raw.items()}
639
- gods = god_nodes(G)
640
-
641
- n = to_wiki(G, communities, 'graphify-out/wiki', community_labels=labels or None, cohesion=cohesion, god_nodes_data=gods)
642
- print(f'Wiki: {n} articles written to graphify-out/wiki/')
643
- print(' graphify-out/wiki/index.md -> agent entry point')
644
- "
645
- ```
646
-
647
- ### Step 7 - Neo4j export (only if --neo4j or --neo4j-push flag)
648
-
649
- **If `--neo4j`** - generate a Cypher file for manual import:
650
-
651
- ```bash
652
- $(cat graphify-out/.graphify_python) -c "
653
- import sys, json
654
- from graphify.build import build_from_json
655
- from graphify.export import to_cypher
656
- from pathlib import Path
657
-
658
- G = build_from_json(json.loads(Path('graphify-out/.graphify_extract.json').read_text()))
659
- to_cypher(G, 'graphify-out/cypher.txt')
660
- print('cypher.txt written - import with: cypher-shell < graphify-out/cypher.txt')
661
- "
662
- ```
663
-
664
- **If `--neo4j-push <uri>`** - push directly to a running Neo4j instance. Ask the user for credentials if not provided:
665
-
666
- ```bash
667
- $(cat graphify-out/.graphify_python) -c "
668
- import sys, json
669
- from graphify.build import build_from_json
670
- from graphify.export import push_to_neo4j
671
- from pathlib import Path
672
-
673
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
674
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
675
- G = build_from_json(extraction)
676
- communities = {int(k): v for k, v in analysis['communities'].items()}
677
-
678
- result = push_to_neo4j(G, uri='NEO4J_URI', user='NEO4J_USER', password='NEO4J_PASSWORD', communities=communities)
679
- print(f'Pushed to Neo4j: {result[\"nodes\"]} nodes, {result[\"edges\"]} edges')
680
- "
681
- ```
682
-
683
- Replace `NEO4J_URI`, `NEO4J_USER`, `NEO4J_PASSWORD` with actual values. Default URI is `bolt://localhost:7687`, default user is `neo4j`. Uses MERGE - safe to re-run without creating duplicates.
684
-
685
- ### Step 7b - SVG export (only if --svg flag)
686
-
687
- ```bash
688
- $(cat graphify-out/.graphify_python) -c "
689
- import sys, json
690
- from graphify.build import build_from_json
691
- from graphify.export import to_svg
692
- from pathlib import Path
693
-
694
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
695
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
696
- labels_raw = json.loads(Path('graphify-out/.graphify_labels.json').read_text()) if Path('graphify-out/.graphify_labels.json').exists() else {}
697
-
698
- G = build_from_json(extraction)
699
- communities = {int(k): v for k, v in analysis['communities'].items()}
700
- labels = {int(k): v for k, v in labels_raw.items()}
701
-
702
- to_svg(G, communities, 'graphify-out/graph.svg', community_labels=labels or None)
703
- print('graph.svg written - embeds in Obsidian, Notion, GitHub READMEs')
704
- "
705
- ```
706
-
707
- ### Step 7c - GraphML export (only if --graphml flag)
708
-
709
- ```bash
710
- $(cat graphify-out/.graphify_python) -c "
711
- import json
712
- from graphify.build import build_from_json
713
- from graphify.export import to_graphml
714
- from pathlib import Path
715
-
716
- extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
717
- analysis = json.loads(Path('graphify-out/.graphify_analysis.json').read_text())
718
-
719
- G = build_from_json(extraction)
720
- communities = {int(k): v for k, v in analysis['communities'].items()}
721
-
722
- to_graphml(G, communities, 'graphify-out/graph.graphml')
723
- print('graph.graphml written - open in Gephi, yEd, or any GraphML tool')
724
- "
725
- ```
726
-
727
- ### Step 7d - MCP server (only if --mcp flag)
728
-
729
- ```bash
730
- python3 -m graphify.serve graphify-out/graph.json
731
- ```
732
-
733
- This starts a stdio MCP server that exposes tools: `query_graph`, `get_node`, `get_neighbors`, `get_community`, `god_nodes`, `graph_stats`, `shortest_path`. Add to Claude Desktop or any MCP-compatible agent orchestrator so other agents can query the graph live.
734
-
735
- To configure in Claude Desktop, add to `claude_desktop_config.json`:
736
- ```json
737
- {
738
- "mcpServers": {
739
- "graphify": {
740
- "command": "python3",
741
- "args": ["-m", "graphify.serve", "/absolute/path/to/graphify-out/graph.json"]
742
- }
743
- }
744
- }
745
- ```
746
-
747
- ### Step 8 - Token reduction benchmark (only if total_words > 5000)
748
-
749
- If `total_words` from `graphify-out/.graphify_detect.json` is greater than 5,000, run:
750
-
751
- ```bash
752
- $(cat graphify-out/.graphify_python) -c "
753
- import json
754
- from graphify.benchmark import run_benchmark, print_benchmark
755
- from pathlib import Path
756
-
757
- detection = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
758
- result = run_benchmark('graphify-out/graph.json', corpus_words=detection['total_words'])
759
- print_benchmark(result)
760
- "
761
- ```
762
-
763
- Print the output directly in chat. If `total_words <= 5000`, skip silently - the graph value is structural clarity, not token compression, for small corpora.
764
-
765
- ---
766
-
767
- ### Step 9 - Save manifest, update cost tracker, clean up, and report
768
-
769
- ```bash
770
- $(cat graphify-out/.graphify_python) -c "
771
- import json
772
- from pathlib import Path
773
- from datetime import datetime, timezone
774
- from graphify.detect import save_manifest
775
-
776
- # Save manifest for --update
777
- detect = json.loads(Path('graphify-out/.graphify_detect.json').read_text())
778
- save_manifest(detect['files'])
779
-
780
- # Update cumulative cost tracker
781
- extract = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
782
- input_tok = extract.get('input_tokens', 0)
783
- output_tok = extract.get('output_tokens', 0)
784
-
785
- cost_path = Path('graphify-out/cost.json')
786
- if cost_path.exists():
787
- cost = json.loads(cost_path.read_text())
788
- else:
789
- cost = {'runs': [], 'total_input_tokens': 0, 'total_output_tokens': 0}
790
-
791
- cost['runs'].append({
792
- 'date': datetime.now(timezone.utc).isoformat(),
793
- 'input_tokens': input_tok,
794
- 'output_tokens': output_tok,
795
- 'files': detect.get('total_files', 0),
796
- })
797
- cost['total_input_tokens'] += input_tok
798
- cost['total_output_tokens'] += output_tok
799
- cost_path.write_text(json.dumps(cost, indent=2))
800
-
801
- print(f'This run: {input_tok:,} input tokens, {output_tok:,} output tokens')
802
- print(f'All time: {cost[\"total_input_tokens\"]:,} input, {cost[\"total_output_tokens\"]:,} output ({len(cost[\"runs\"])} runs)')
803
- "
804
- rm -f graphify-out/.graphify_detect.json graphify-out/.graphify_extract.json graphify-out/.graphify_ast.json graphify-out/.graphify_semantic.json graphify-out/.graphify_analysis.json graphify-out/.graphify_labels.json graphify-out/.graphify_incremental.json graphify-out/.graphify_transcripts.json graphify-out/.graphify_old.json; find graphify-out -maxdepth 1 -name '.graphify_chunk_*.json' -delete 2>/dev/null
805
- rm -f graphify-out/.needs_update 2>/dev/null || true
806
- ```
807
-
808
- Tell the user (omit the obsidian line unless --obsidian was given; omit the wiki line unless --wiki was given):
809
- ```
810
- Graph complete. Outputs in PATH_TO_DIR/graphify-out/
811
-
812
- graph.html - interactive graph, open in browser
813
- GRAPH_REPORT.md - audit report
814
- graph.json - raw graph data
815
- obsidian/ - Obsidian vault (only if --obsidian was given)
816
- wiki/ - agent-crawlable wiki, start at wiki/index.md (only if --wiki was given)
817
- ```
818
-
819
- If graphify saved you time, consider supporting it: https://github.com/sponsors/safishamsi
820
-
821
- Replace PATH_TO_DIR with the actual absolute path of the directory that was processed.
822
-
823
- Then paste these sections from GRAPH_REPORT.md directly into the chat:
824
- - God Nodes
825
- - Surprising Connections
826
- - Suggested Questions
827
-
828
- Do NOT paste the full report - just those three sections. Keep it concise.
829
-
830
- Then immediately offer to explore. Pick the single most interesting suggested question from the report - the one that crosses the most community boundaries or has the most surprising bridge node - and ask:
831
-
832
- > "The most interesting question this graph can answer: **[question]**. Want me to trace it?"
833
-
834
- If the user says yes, run `/graphify query "[question]"` on the graph and walk them through the answer using the graph structure - which nodes connect, which community boundaries get crossed, what the path reveals. Keep going as long as they want to explore. Each answer should end with a natural follow-up ("this connects to X - want to go deeper?") so the session feels like navigation, not a one-shot report.
835
-
836
- The graph is the map. Your job after the pipeline is to be the guide.
837
-
838
- ---
839
-
840
- ## Interpreter guard for subcommands
841
-
842
- Before running any subcommand below (`--update`, `--cluster-only`, `query`, `path`, `explain`, `add`), check that `.graphify_python` exists. If it's missing (e.g. user deleted `graphify-out/`), re-resolve the interpreter first:
843
-
844
- ```bash
845
- if [ ! -f graphify-out/.graphify_python ]; then
846
- GRAPHIFY_BIN=$(which graphify 2>/dev/null)
847
- if [ -n "$GRAPHIFY_BIN" ]; then
848
- PYTHON=$(head -1 "$GRAPHIFY_BIN" | tr -d '#!')
849
- case "$PYTHON" in *[!a-zA-Z0-9/_.-]*) PYTHON="python3" ;; esac
850
- else
851
- PYTHON="python3"
852
- fi
853
- mkdir -p graphify-out
854
- "$PYTHON" -c "import sys; open('graphify-out/.graphify_python', 'w').write(sys.executable)"
855
- fi
856
- ```
857
-
858
- ---
859
-
860
- ## For --update (incremental re-extraction)
861
-
862
- Use when you've added or modified files since the last run. Only re-extracts changed files - saves tokens and time.
863
-
864
- ```bash
865
- $(cat graphify-out/.graphify_python) -c "
866
- import sys, json
867
- from graphify.detect import detect_incremental, save_manifest
868
- from pathlib import Path
869
-
870
- result = detect_incremental(Path('INPUT_PATH'))
871
- new_total = result.get('new_total', 0)
872
- print(json.dumps(result, indent=2))
873
- Path('graphify-out/.graphify_incremental.json').write_text(json.dumps(result))
874
- deleted = list(result.get('deleted_files', []))
875
- if new_total == 0 and not deleted:
876
- print('No files changed since last run. Nothing to update.')
877
- raise SystemExit(0)
878
- if deleted:
879
- print(f'{len(deleted)} deleted file(s) to prune.')
880
- if new_total > 0:
881
- print(f'{new_total} new/changed file(s) to re-extract.')
882
- "
883
- ```
884
-
885
- If new files exist, first check whether all changed files are code files:
886
-
887
- ```bash
888
- $(cat graphify-out/.graphify_python) -c "
889
- import json
890
- from pathlib import Path
891
-
892
- result = json.loads(open('graphify-out/.graphify_incremental.json').read()) if Path('graphify-out/.graphify_incremental.json').exists() else {}
893
- code_exts = {'.py','.ts','.js','.go','.rs','.java','.cpp','.c','.rb','.swift','.kt','.cs','.scala','.php','.cc','.cxx','.hpp','.h','.kts','.lua','.toc'}
894
- new_files = result.get('new_files', {})
895
- all_changed = [f for files in new_files.values() for f in files]
896
- code_only = all(Path(f).suffix.lower() in code_exts for f in all_changed)
897
- print('code_only:', code_only)
898
- "
899
- ```
900
-
901
- If `code_only` is True: print `[graphify update] Code-only changes detected - skipping semantic extraction (no LLM needed)`, run only Step 3A (AST) on the changed files, skip Step 3B entirely (no subagents), then go straight to merge and Steps 4-8.
902
-
903
- If `code_only` is False (any changed file is a doc/paper/image): run the full Steps 3A-3C pipeline as normal.
904
-
905
- If no new files exist (only deletions), create an empty extraction so the merge step can prune:
906
-
907
- ```bash
908
- if [ ! -f graphify-out/.graphify_extract.json ]; then
909
- echo '[graphify update] Only deletions -- creating empty extraction for merge.'
910
- $(cat graphify-out/.graphify_python) -c "
911
- import json
912
- from pathlib import Path
913
- Path('graphify-out/.graphify_extract.json').write_text(json.dumps({'nodes':[],'edges':[],'hyperedges':[],'input_tokens':0,'output_tokens':0}), encoding='utf-8')
914
- "
915
- fi
916
- ```
917
-
918
- Then:
919
-
920
- ```bash
921
- $(cat graphify-out/.graphify_python) -c "
922
- import sys, json
923
- from graphify.build import build_from_json
924
- from graphify.export import to_json
925
- from networkx.readwrite import json_graph
926
- import networkx as nx
927
- from pathlib import Path
928
-
929
- # Load existing graph
930
- existing_data = json.loads(Path('graphify-out/graph.json').read_text())
931
- G_existing = json_graph.node_link_graph(existing_data, edges='links')
932
-
933
- # Load new extraction
934
- new_extraction = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
935
- G_new = build_from_json(new_extraction)
936
-
937
- # Merge: new nodes/edges into existing graph
938
- G_existing.update(G_new)
939
- print(f'Merged: {G_existing.number_of_nodes()} nodes, {G_existing.number_of_edges()} edges')
940
- "
941
- ```
942
-
943
- Then run Steps 4-8 on the merged graph as normal.
944
-
945
- After Step 4, show the graph diff:
946
-
947
- ```bash
948
- $(cat graphify-out/.graphify_python) -c "
949
- import json
950
- from graphify.analyze import graph_diff
951
- from graphify.build import build_from_json
952
- from networkx.readwrite import json_graph
953
- import networkx as nx
954
- from pathlib import Path
955
-
956
- old_data = json.loads(Path('graphify-out/.graphify_old.json').read_text()) if Path('graphify-out/.graphify_old.json').exists() else None
957
- new_extract = json.loads(Path('graphify-out/.graphify_extract.json').read_text())
958
- G_new = build_from_json(new_extract)
959
-
960
- if old_data:
961
- G_old = json_graph.node_link_graph(old_data, edges='links')
962
- diff = graph_diff(G_old, G_new)
963
- print(diff['summary'])
964
- if diff['new_nodes']:
965
- print('New nodes:', ', '.join(n['label'] for n in diff['new_nodes'][:5]))
966
- if diff['new_edges']:
967
- print('New edges:', len(diff['new_edges']))
968
- "
969
- ```
970
-
971
- Before the merge step, save the old graph: `cp graphify-out/graph.json graphify-out/.graphify_old.json`
972
- Clean up after: `rm -f graphify-out/.graphify_old.json`
973
-
974
- ---
975
-
976
- ## For --cluster-only
977
-
978
- Skip Steps 1-3. Load the existing graph from `graphify-out/graph.json` and re-run clustering:
979
-
980
- ```bash
981
- $(cat graphify-out/.graphify_python) -c "
982
- import sys, json
983
- from graphify.cluster import cluster, score_all
984
- from graphify.analyze import god_nodes, surprising_connections
985
- from graphify.report import generate
986
- from graphify.export import to_json
987
- from networkx.readwrite import json_graph
988
- import networkx as nx
989
- from pathlib import Path
990
-
991
- data = json.loads(Path('graphify-out/graph.json').read_text())
992
- G = json_graph.node_link_graph(data, edges='links')
993
-
994
- detection = {'total_files': 0, 'total_words': 99999, 'needs_graph': True, 'warning': None,
995
- 'files': {'code': [], 'document': [], 'paper': []}}
996
- tokens = {'input': 0, 'output': 0}
997
-
998
- communities = cluster(G)
999
- cohesion = score_all(G, communities)
1000
- gods = god_nodes(G)
1001
- surprises = surprising_connections(G, communities)
1002
- labels = {cid: 'Community ' + str(cid) for cid in communities}
1003
-
1004
- report = generate(G, communities, cohesion, labels, gods, surprises, detection, tokens, '.')
1005
- Path('graphify-out/GRAPH_REPORT.md').write_text(report)
1006
- to_json(G, communities, 'graphify-out/graph.json')
1007
-
1008
- analysis = {
1009
- 'communities': {str(k): v for k, v in communities.items()},
1010
- 'cohesion': {str(k): v for k, v in cohesion.items()},
1011
- 'gods': gods,
1012
- 'surprises': surprises,
1013
- }
1014
- Path('graphify-out/.graphify_analysis.json').write_text(json.dumps(analysis, indent=2))
1015
- print(f'Re-clustered: {len(communities)} communities')
1016
- "
1017
- ```
1018
-
1019
- Then run Steps 5-9 as normal (label communities, generate viz, benchmark, clean up, report).
1020
-
1021
- ---
1022
-
1023
- ## For /graphify query
1024
-
1025
- Two traversal modes - choose based on the question:
1026
-
1027
- | Mode | Flag | Best for |
1028
- |------|------|----------|
1029
- | BFS (default) | _(none)_ | "What is X connected to?" - broad context, nearest neighbors first |
1030
- | DFS | `--dfs` | "How does X reach Y?" - trace a specific chain or dependency path |
1031
-
1032
- First check the graph exists:
1033
- ```bash
1034
- $(cat graphify-out/.graphify_python) -c "
1035
- from pathlib import Path
1036
- if not Path('graphify-out/graph.json').exists():
1037
- print('ERROR: No graph found. Run /graphify <path> first to build the graph.')
1038
- raise SystemExit(1)
1039
- "
1040
- ```
1041
- If it fails, stop and tell the user to run `/graphify <path>` first.
1042
-
1043
- Load `graphify-out/graph.json`, then:
1044
-
1045
- 1. Find the 1-3 nodes whose label best matches key terms in the question.
1046
- 2. Run the appropriate traversal from each starting node.
1047
- 3. Read the subgraph - node labels, edge relations, confidence tags, source locations.
1048
- 4. Answer using **only** what the graph contains. Quote `source_location` when citing a specific fact.
1049
- 5. If the graph lacks enough information, say so - do not hallucinate edges.
1050
-
1051
- ```bash
1052
- $(cat graphify-out/.graphify_python) -c "
1053
- import sys, json
1054
- from networkx.readwrite import json_graph
1055
- import networkx as nx
1056
- from pathlib import Path
1057
-
1058
- data = json.loads(Path('graphify-out/graph.json').read_text())
1059
- G = json_graph.node_link_graph(data, edges='links')
1060
-
1061
- question = 'QUESTION'
1062
- mode = 'MODE' # 'bfs' or 'dfs'
1063
- terms = [t.lower() for t in question.split() if len(t) > 3]
1064
-
1065
- # Find best-matching start nodes
1066
- scored = []
1067
- for nid, ndata in G.nodes(data=True):
1068
- label = ndata.get('label', '').lower()
1069
- score = sum(1 for t in terms if t in label)
1070
- if score > 0:
1071
- scored.append((score, nid))
1072
- scored.sort(reverse=True)
1073
- start_nodes = [nid for _, nid in scored[:3]]
1074
-
1075
- if not start_nodes:
1076
- print('No matching nodes found for query terms:', terms)
1077
- sys.exit(0)
1078
-
1079
- subgraph_nodes = set()
1080
- subgraph_edges = []
1081
-
1082
- if mode == 'dfs':
1083
- # DFS: follow one path as deep as possible before backtracking.
1084
- # Depth-limited to 6 to avoid traversing the whole graph.
1085
- visited = set()
1086
- stack = [(n, 0) for n in reversed(start_nodes)]
1087
- while stack:
1088
- node, depth = stack.pop()
1089
- if node in visited or depth > 6:
1090
- continue
1091
- visited.add(node)
1092
- subgraph_nodes.add(node)
1093
- for neighbor in G.neighbors(node):
1094
- if neighbor not in visited:
1095
- stack.append((neighbor, depth + 1))
1096
- subgraph_edges.append((node, neighbor))
1097
- else:
1098
- # BFS: explore all neighbors layer by layer up to depth 3.
1099
- frontier = set(start_nodes)
1100
- subgraph_nodes = set(start_nodes)
1101
- for _ in range(3):
1102
- next_frontier = set()
1103
- for n in frontier:
1104
- for neighbor in G.neighbors(n):
1105
- if neighbor not in subgraph_nodes:
1106
- next_frontier.add(neighbor)
1107
- subgraph_edges.append((n, neighbor))
1108
- subgraph_nodes.update(next_frontier)
1109
- frontier = next_frontier
1110
-
1111
- # Token-budget aware output: rank by relevance, cut at budget (~4 chars/token)
1112
- token_budget = BUDGET # default 2000
1113
- char_budget = token_budget * 4
1114
-
1115
- # Score each node by term overlap for ranked output
1116
- def relevance(nid):
1117
- label = G.nodes[nid].get('label', '').lower()
1118
- return sum(1 for t in terms if t in label)
1119
-
1120
- ranked_nodes = sorted(subgraph_nodes, key=relevance, reverse=True)
1121
-
1122
- lines = [f'Traversal: {mode.upper()} | Start: {[G.nodes[n].get(\"label\",n) for n in start_nodes]} | {len(subgraph_nodes)} nodes']
1123
- for nid in ranked_nodes:
1124
- d = G.nodes[nid]
1125
- lines.append(f' NODE {d.get(\"label\", nid)} [src={d.get(\"source_file\",\"\")} loc={d.get(\"source_location\",\"\")}]')
1126
- for u, v in subgraph_edges:
1127
- if u in subgraph_nodes and v in subgraph_nodes:
1128
- _raw = G[u][v]; d = next(iter(_raw.values()), {}) if isinstance(G, nx.MultiGraph) else _raw
1129
- lines.append(f' EDGE {G.nodes[u].get(\"label\",u)} --{d.get(\"relation\",\"\")} [{d.get(\"confidence\",\"\")}]--> {G.nodes[v].get(\"label\",v)}')
1130
-
1131
- output = '\n'.join(lines)
1132
- if len(output) > char_budget:
1133
- output = output[:char_budget] + f'\n... (truncated at ~{token_budget} token budget - use --budget N for more)'
1134
- print(output)
1135
- "
1136
- ```
1137
-
1138
- Replace `QUESTION` with the user's actual question, `MODE` with `bfs` or `dfs`, and `BUDGET` with the token budget (default `2000`, or whatever `--budget N` specifies). Then answer based on the subgraph output above.
1139
-
1140
- After writing the answer, save it back into the graph so it improves future queries:
1141
-
1142
- ```bash
1143
- $(cat graphify-out/.graphify_python) -m graphify save-result --question "QUESTION" --answer "ANSWER" --type query --nodes NODE1 NODE2
1144
- ```
1145
-
1146
- ---
1147
-
1148
- ## For /graphify path
1149
-
1150
- Find the shortest path between two named concepts in the graph.
1151
-
1152
- First check the graph exists:
1153
- ```bash
1154
- $(cat graphify-out/.graphify_python) -c "
1155
- from pathlib import Path
1156
- if not Path('graphify-out/graph.json').exists():
1157
- print('ERROR: No graph found. Run /graphify <path> first to build the graph.')
1158
- raise SystemExit(1)
1159
- "
1160
- ```
1161
-
1162
- ```bash
1163
- $(cat graphify-out/.graphify_python) -c "
1164
- import json, sys
1165
- import networkx as nx
1166
- from networkx.readwrite import json_graph
1167
- from pathlib import Path
1168
-
1169
- data = json.loads(Path('graphify-out/graph.json').read_text())
1170
- G = json_graph.node_link_graph(data, edges='links')
1171
-
1172
- a_term = 'NODE_A'
1173
- b_term = 'NODE_B'
1174
-
1175
- def find_node(term):
1176
- term = term.lower()
1177
- scored = sorted(
1178
- [(sum(1 for w in term.split() if w in G.nodes[n].get('label','').lower()), n)
1179
- for n in G.nodes()],
1180
- reverse=True
1181
- )
1182
- return scored[0][1] if scored and scored[0][0] > 0 else None
1183
-
1184
- src = find_node(a_term)
1185
- tgt = find_node(b_term)
1186
-
1187
- if not src or not tgt:
1188
- print(f'Could not find nodes matching: {a_term!r} or {b_term!r}')
1189
- sys.exit(0)
1190
-
1191
- try:
1192
- path = nx.shortest_path(G, src, tgt)
1193
- print(f'Shortest path ({len(path)-1} hops):')
1194
- for i, nid in enumerate(path):
1195
- label = G.nodes[nid].get('label', nid)
1196
- if i < len(path) - 1:
1197
- _raw = G[nid][path[i+1]]; edge = next(iter(_raw.values()), {}) if isinstance(G, nx.MultiGraph) else _raw
1198
- rel = edge.get('relation', '')
1199
- conf = edge.get('confidence', '')
1200
- print(f' {label} --{rel}--> [{conf}]')
1201
- else:
1202
- print(f' {label}')
1203
- except nx.NetworkXNoPath:
1204
- print(f'No path found between {a_term!r} and {b_term!r}')
1205
- except nx.NodeNotFound as e:
1206
- print(f'Node not found: {e}')
1207
- "
1208
- ```
1209
-
1210
- Replace `NODE_A` and `NODE_B` with the actual concept names. Then explain the path in plain language - what each hop means, why it's significant.
1211
-
1212
- After writing the explanation, save it back:
1213
-
1214
- ```bash
1215
- $(cat graphify-out/.graphify_python) -m graphify save-result --question "Path from NODE_A to NODE_B" --answer "ANSWER" --type path_query --nodes NODE_A NODE_B
1216
- ```
1217
-
1218
- ---
1219
-
1220
- ## For /graphify explain
1221
-
1222
- Give a plain-language explanation of a single node - everything connected to it.
1223
-
1224
- First check the graph exists:
1225
- ```bash
1226
- $(cat graphify-out/.graphify_python) -c "
1227
- from pathlib import Path
1228
- if not Path('graphify-out/graph.json').exists():
1229
- print('ERROR: No graph found. Run /graphify <path> first to build the graph.')
1230
- raise SystemExit(1)
1231
- "
1232
- ```
1233
-
1234
- ```bash
1235
- $(cat graphify-out/.graphify_python) -c "
1236
- import json, sys
1237
- import networkx as nx
1238
- from networkx.readwrite import json_graph
1239
- from pathlib import Path
1240
-
1241
- data = json.loads(Path('graphify-out/graph.json').read_text())
1242
- G = json_graph.node_link_graph(data, edges='links')
1243
-
1244
- term = 'NODE_NAME'
1245
- term_lower = term.lower()
1246
-
1247
- # Find best matching node
1248
- scored = sorted(
1249
- [(sum(1 for w in term_lower.split() if w in G.nodes[n].get('label','').lower()), n)
1250
- for n in G.nodes()],
1251
- reverse=True
1252
- )
1253
- if not scored or scored[0][0] == 0:
1254
- print(f'No node matching {term!r}')
1255
- sys.exit(0)
1256
-
1257
- nid = scored[0][1]
1258
- data_n = G.nodes[nid]
1259
- print(f'NODE: {data_n.get(\"label\", nid)}')
1260
- print(f' source: {data_n.get(\"source_file\",\"unknown\")}')
1261
- print(f' type: {data_n.get(\"file_type\",\"unknown\")}')
1262
- print(f' degree: {G.degree(nid)}')
1263
- print()
1264
- print('CONNECTIONS:')
1265
- for neighbor in G.neighbors(nid):
1266
- _raw = G[nid][neighbor]; edge = next(iter(_raw.values()), {}) if isinstance(G, nx.MultiGraph) else _raw
1267
- nlabel = G.nodes[neighbor].get('label', neighbor)
1268
- rel = edge.get('relation', '')
1269
- conf = edge.get('confidence', '')
1270
- src_file = G.nodes[neighbor].get('source_file', '')
1271
- print(f' --{rel}--> {nlabel} [{conf}] ({src_file})')
1272
- "
1273
- ```
1274
-
1275
- Replace `NODE_NAME` with the concept. Then write a 3-5 sentence explanation using source locations as citations.
1276
-
1277
- After writing the explanation, save it back:
1278
-
1279
- ```bash
1280
- $(cat graphify-out/.graphify_python) -m graphify save-result --question "Explain NODE_NAME" --answer "ANSWER" --type explain --nodes NODE_NAME
1281
- ```
1282
-
1283
- ---
1284
-
1285
- ## For /graphify add
1286
-
1287
- Fetch a URL and add it to the corpus, then update the graph.
1288
-
1289
- ```bash
1290
- $(cat graphify-out/.graphify_python) -c "
1291
- import sys
1292
- from graphify.ingest import ingest
1293
- from pathlib import Path
1294
-
1295
- try:
1296
- out = ingest('URL', Path('./raw'), author='AUTHOR', contributor='CONTRIBUTOR')
1297
- print(f'Saved to {out}')
1298
- except ValueError as e:
1299
- print(f'error: {e}', file=sys.stderr)
1300
- sys.exit(1)
1301
- except RuntimeError as e:
1302
- print(f'error: {e}', file=sys.stderr)
1303
- sys.exit(1)
1304
- "
1305
- ```
1306
-
1307
- Replace `URL` with the actual URL, `AUTHOR` with the user's name if provided, `CONTRIBUTOR` likewise. After a successful save, automatically run the `--update` pipeline on `./raw` to merge the new file into the existing graph.
1308
-
1309
- Supported URL types (auto-detected):
1310
- - Twitter/X -> fetched via oEmbed, saved as `.md` with tweet text and author
1311
- - arXiv -> abstract + metadata saved as `.md`
1312
- - PDF -> downloaded as `.pdf`
1313
- - Images (.png/.jpg/.webp) -> downloaded, vision extraction runs on next build
1314
- - Any webpage -> converted to markdown via html2text
1315
-
1316
- ---
1317
-
1318
- ## For --watch
1319
-
1320
- Start a background watcher that monitors a folder and auto-updates the graph when files change.
1321
-
1322
- ```bash
1323
- python3 -m graphify.watch INPUT_PATH --debounce 3
1324
- ```
1325
-
1326
- Replace INPUT_PATH with the folder to watch. Behavior depends on what changed:
1327
-
1328
- - **Code files only (.py, .ts, .go, etc.):** re-runs AST extraction + rebuild + cluster immediately, no LLM needed. `graph.json` and `GRAPH_REPORT.md` are updated automatically.
1329
- - **Docs, papers, or images:** writes a `graphify-out/needs_update` flag and prints a notification to run `/graphify --update` (LLM semantic re-extraction required).
1330
-
1331
- Debounce (default 3s): waits until file activity stops before triggering, so a wave of parallel agent writes doesn't trigger a rebuild per file.
1332
-
1333
- Press Ctrl+C to stop.
1334
-
1335
- ---
1336
-
1337
- ## For git commit hook
1338
-
1339
- Install a post-commit hook that auto-rebuilds the graph after every commit. No background process needed - triggers once per commit, works with any editor.
1340
-
1341
- ```bash
1342
- graphify hook install # install
1343
- graphify hook uninstall # remove
1344
- graphify hook status # check
1345
- ```
1346
-
1347
- After every `git commit`, the hook detects which code files changed, re-runs AST extraction on those files, and rebuilds `graph.json` and `GRAPH_REPORT.md`. Doc/image changes are ignored by the hook - run `/graphify --update` manually for those.
1348
-
1349
- ---
1350
-
1351
- ## For always-on context in Devin sessions
1352
-
1353
- Run once per project to make graphify always-on in Devin sessions:
1354
-
1355
- ```bash
1356
- graphify devin install --project
1357
- ```
1358
-
1359
- This writes a `## graphify` section to `.windsurf/rules/graphify.md` that instructs Devin to check the graph before answering codebase questions and rebuild it after code changes.
1360
-
1361
- ```bash
1362
- graphify devin uninstall --project # remove
1363
- ```
1364
-
1365
- ---
1366
-
1367
- ## Honesty Rules
1368
-
1369
- - Never invent an edge. If unsure, use AMBIGUOUS.
1370
- - Never skip the corpus check warning.
1371
- - Always show token cost in the report.
1372
- - Never hide cohesion scores behind symbols - show the raw number.