oh-my-opencode 4.5.1 → 4.5.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 (584) hide show
  1. package/README.ja.md +33 -18
  2. package/README.ko.md +33 -18
  3. package/README.md +82 -24
  4. package/README.ru.md +33 -18
  5. package/README.zh-cn.md +45 -24
  6. package/bin/oh-my-opencode.js +47 -2
  7. package/bin/oh-my-opencode.test.ts +174 -0
  8. package/bin/platform.d.ts +6 -0
  9. package/bin/platform.js +19 -0
  10. package/bin/platform.test.ts +66 -1
  11. package/dist/cli/cli-program.d.ts +18 -0
  12. package/dist/cli/index.js +28472 -26159
  13. package/dist/cli/install-codex/codex-cache-bundled-mcps.d.ts +5 -0
  14. package/dist/cli/install-codex/codex-cache-command-shim.d.ts +1 -0
  15. package/dist/cli/install-codex/codex-cache-legacy-bins.d.ts +3 -0
  16. package/dist/cli/install-codex/codex-cache-local-dependencies.d.ts +1 -0
  17. package/dist/cli/install-codex/codex-cache-paths.d.ts +2 -0
  18. package/dist/cli/install-codex/codex-cache.d.ts +31 -0
  19. package/dist/cli/install-codex/codex-config-toml.d.ts +11 -0
  20. package/dist/cli/install-codex/codex-hook-trust.d.ts +6 -0
  21. package/dist/cli/install-codex/codex-marketplace-snapshot.d.ts +15 -0
  22. package/dist/cli/install-codex/codex-marketplace.d.ts +9 -0
  23. package/dist/cli/install-codex/codex-multi-agent-v2-config.d.ts +1 -0
  24. package/dist/cli/install-codex/codex-process.d.ts +2 -0
  25. package/dist/cli/install-codex/index.d.ts +7 -0
  26. package/dist/cli/install-codex/install-codex.d.ts +17 -0
  27. package/dist/cli/install-codex/link-cached-plugin-agents.d.ts +12 -0
  28. package/dist/cli/install-codex/toml-section-editor.d.ts +9 -0
  29. package/dist/cli/install-codex/types.d.ts +56 -0
  30. package/dist/cli/star-request.d.ts +2 -0
  31. package/dist/cli/tui-install-prompts.d.ts +3 -2
  32. package/dist/cli/types.d.ts +8 -0
  33. package/dist/config/schema/agent-names.d.ts +4 -1
  34. package/dist/config/schema/commands.d.ts +1 -2
  35. package/dist/config/schema/oh-my-opencode-config.d.ts +5 -3
  36. package/dist/create-managers.d.ts +1 -0
  37. package/dist/features/background-agent/parent-wake-message-activity.d.ts +23 -0
  38. package/dist/features/background-agent/parent-wake-notifier.d.ts +0 -1
  39. package/dist/features/boulder-state/storage.d.ts +1 -1
  40. package/dist/features/builtin-commands/templates/refactor.d.ts +1 -1
  41. package/dist/features/builtin-commands/templates/remove-ai-slops.d.ts +2 -2
  42. package/dist/features/builtin-commands/types.d.ts +1 -1
  43. package/dist/features/builtin-skills/skill-file-loader.d.ts +4 -0
  44. package/dist/features/builtin-skills/skills/index.d.ts +4 -1
  45. package/dist/features/builtin-skills/skills/init-deep.d.ts +2 -0
  46. package/dist/features/builtin-skills/skills/remove-ai-slops.d.ts +2 -0
  47. package/dist/features/builtin-skills/skills/security-research.d.ts +2 -0
  48. package/dist/features/builtin-skills/skills/security-review.d.ts +2 -0
  49. package/dist/features/opencode-runtime-skills/index.d.ts +2 -0
  50. package/dist/features/opencode-runtime-skills/runtime-skill-config.d.ts +17 -0
  51. package/dist/features/opencode-runtime-skills/skill-markdown.d.ts +7 -0
  52. package/dist/features/opencode-runtime-skills/source-server.d.ts +8 -0
  53. package/dist/hooks/claude-code-hooks/hook-text.d.ts +2 -0
  54. package/dist/hooks/session-recovery/storage/latest-assistant-message.d.ts +5 -0
  55. package/dist/hooks/session-recovery/storage/thinking-prepend.d.ts +3 -0
  56. package/dist/hooks/thinking-block-validator/hook.d.ts +0 -18
  57. package/dist/hooks/todo-continuation-enforcer/pending-question-detection.d.ts +4 -0
  58. package/dist/index.js +1684 -1801
  59. package/dist/oh-my-opencode.schema.json +4 -2
  60. package/dist/plugin-handlers/config-handler.d.ts +2 -1
  61. package/dist/shared/external-plugin-detector.d.ts +8 -0
  62. package/dist/shared/prompt-async-gate/message-inspection-error.d.ts +1 -0
  63. package/dist/shared/prompt-async-gate/pending-tool-turn.d.ts +1 -0
  64. package/dist/shared/prompt-async-gate/prompt-message-state.d.ts +8 -0
  65. package/dist/shared/prompt-timeout-context.d.ts +2 -0
  66. package/dist/testing/create-plugin-module.d.ts +5 -1
  67. package/dist/tools/delegate-task/sync-prompt-sender.d.ts +2 -2
  68. package/package.json +31 -16
  69. package/packages/ast-grep-mcp/dist/cli.js +245 -40
  70. package/packages/lsp-tools-mcp/dist/cli.js +1 -1
  71. package/packages/omo-codex/marketplace.json +17 -0
  72. package/packages/omo-codex/plugin/.codex-plugin/plugin.json +35 -0
  73. package/packages/omo-codex/plugin/.mcp.json +14 -0
  74. package/packages/omo-codex/plugin/README.md +13 -0
  75. package/packages/omo-codex/plugin/components/comment-checker/.gitattributes +13 -0
  76. package/packages/omo-codex/plugin/components/comment-checker/.github/CODEOWNERS +12 -0
  77. package/packages/omo-codex/plugin/components/comment-checker/.github/ISSUE_TEMPLATE/bug.yml +40 -0
  78. package/packages/omo-codex/plugin/components/comment-checker/.github/ISSUE_TEMPLATE/feature.yml +27 -0
  79. package/packages/omo-codex/plugin/components/comment-checker/.github/branch-ruleset.json +45 -0
  80. package/packages/omo-codex/plugin/components/comment-checker/.github/dependabot.yml +16 -0
  81. package/packages/omo-codex/plugin/components/comment-checker/.github/pull_request_template.md +19 -0
  82. package/packages/omo-codex/plugin/components/comment-checker/.github/workflows/ci.yml +47 -0
  83. package/packages/omo-codex/plugin/components/comment-checker/.github/workflows/publish.yml +51 -0
  84. package/packages/omo-codex/plugin/components/comment-checker/AGENTS.md +35 -0
  85. package/packages/omo-codex/plugin/components/comment-checker/CHANGELOG.md +33 -0
  86. package/packages/omo-codex/plugin/components/comment-checker/LICENSE +21 -0
  87. package/packages/omo-codex/plugin/components/comment-checker/NOTICE +6 -0
  88. package/packages/omo-codex/plugin/components/comment-checker/README.md +87 -0
  89. package/packages/omo-codex/plugin/components/comment-checker/biome.json +48 -0
  90. package/packages/omo-codex/plugin/components/comment-checker/hooks/hooks.json +17 -0
  91. package/packages/omo-codex/plugin/components/comment-checker/package.json +57 -0
  92. package/packages/omo-codex/plugin/components/comment-checker/skills/comment-checker/SKILL.md +16 -0
  93. package/packages/omo-codex/plugin/components/comment-checker/src/cli.ts +12 -0
  94. package/packages/omo-codex/plugin/components/comment-checker/src/codex-hook.ts +205 -0
  95. package/packages/omo-codex/plugin/components/comment-checker/src/core.ts +361 -0
  96. package/packages/omo-codex/plugin/components/comment-checker/src/runner.ts +195 -0
  97. package/packages/omo-codex/plugin/components/comment-checker/test/codex-hook-newline.test.ts +52 -0
  98. package/packages/omo-codex/plugin/components/comment-checker/test/codex-hook.test.ts +368 -0
  99. package/packages/omo-codex/plugin/components/comment-checker/test/fixtures/post-tool-use.json +15 -0
  100. package/packages/omo-codex/plugin/components/comment-checker/test/package-smoke.test.ts +93 -0
  101. package/packages/omo-codex/plugin/components/comment-checker/test/runner.test.ts +66 -0
  102. package/packages/omo-codex/plugin/components/comment-checker/tsconfig.build.json +12 -0
  103. package/packages/omo-codex/plugin/components/comment-checker/tsconfig.json +27 -0
  104. package/packages/omo-codex/plugin/components/comment-checker/vitest.config.ts +9 -0
  105. package/packages/omo-codex/plugin/components/lsp/.gitattributes +13 -0
  106. package/packages/omo-codex/plugin/components/lsp/.github/CODEOWNERS +1 -0
  107. package/packages/omo-codex/plugin/components/lsp/.github/ISSUE_TEMPLATE/bug.yml +26 -0
  108. package/packages/omo-codex/plugin/components/lsp/.github/ISSUE_TEMPLATE/feature.yml +19 -0
  109. package/packages/omo-codex/plugin/components/lsp/.github/branch-ruleset.json +45 -0
  110. package/packages/omo-codex/plugin/components/lsp/.github/dependabot.yml +11 -0
  111. package/packages/omo-codex/plugin/components/lsp/.github/pull_request_template.md +11 -0
  112. package/packages/omo-codex/plugin/components/lsp/.github/workflows/ci.yml +56 -0
  113. package/packages/omo-codex/plugin/components/lsp/.github/workflows/publish.yml +60 -0
  114. package/packages/omo-codex/plugin/components/lsp/.mcp.json +9 -0
  115. package/packages/omo-codex/plugin/components/lsp/AGENTS.md +25 -0
  116. package/packages/omo-codex/plugin/components/lsp/CHANGELOG.md +25 -0
  117. package/packages/omo-codex/plugin/components/lsp/LICENSE +21 -0
  118. package/packages/omo-codex/plugin/components/lsp/NOTICE +3 -0
  119. package/packages/omo-codex/plugin/components/lsp/README.md +148 -0
  120. package/packages/omo-codex/plugin/components/lsp/biome.json +48 -0
  121. package/packages/omo-codex/plugin/components/lsp/hooks/hooks.json +17 -0
  122. package/packages/omo-codex/plugin/components/lsp/package.json +64 -0
  123. package/packages/omo-codex/plugin/components/lsp/scripts/build-lsp-tools.mjs +46 -0
  124. package/packages/omo-codex/plugin/components/lsp/scripts/build-lsp-tools.test.mjs +104 -0
  125. package/packages/omo-codex/plugin/components/lsp/scripts/clean-dist.mjs +5 -0
  126. package/packages/omo-codex/plugin/components/lsp/scripts/test.mjs +8 -0
  127. package/packages/omo-codex/plugin/components/lsp/skills/lsp/SKILL.md +35 -0
  128. package/packages/omo-codex/plugin/components/lsp/src/cli.ts +44 -0
  129. package/packages/omo-codex/plugin/components/lsp/src/codex-hook.ts +285 -0
  130. package/packages/omo-codex/plugin/components/lsp/test/codex-hook.test.ts +358 -0
  131. package/packages/omo-codex/plugin/components/lsp/test/fixtures/broken.py +1 -0
  132. package/packages/omo-codex/plugin/components/lsp/test/fixtures/post-tool-use.json +15 -0
  133. package/packages/omo-codex/plugin/components/lsp/test/package-smoke.test.ts +153 -0
  134. package/packages/omo-codex/plugin/components/lsp/tsconfig.build.json +12 -0
  135. package/packages/omo-codex/plugin/components/lsp/tsconfig.json +27 -0
  136. package/packages/omo-codex/plugin/components/lsp/vitest.config.ts +9 -0
  137. package/packages/omo-codex/plugin/components/rules/.codex-plugin/plugin.json +3 -0
  138. package/packages/omo-codex/plugin/components/rules/.gitattributes +13 -0
  139. package/packages/omo-codex/plugin/components/rules/.github/CODEOWNERS +12 -0
  140. package/packages/omo-codex/plugin/components/rules/.github/ISSUE_TEMPLATE/bug.yml +49 -0
  141. package/packages/omo-codex/plugin/components/rules/.github/ISSUE_TEMPLATE/feature.yml +27 -0
  142. package/packages/omo-codex/plugin/components/rules/.github/branch-ruleset.json +45 -0
  143. package/packages/omo-codex/plugin/components/rules/.github/dependabot.yml +16 -0
  144. package/packages/omo-codex/plugin/components/rules/.github/pull_request_template.md +20 -0
  145. package/packages/omo-codex/plugin/components/rules/.github/workflows/ci.yml +47 -0
  146. package/packages/omo-codex/plugin/components/rules/.github/workflows/publish.yml +51 -0
  147. package/packages/omo-codex/plugin/components/rules/AGENTS.md +34 -0
  148. package/packages/omo-codex/plugin/components/rules/CHANGELOG.md +19 -0
  149. package/packages/omo-codex/plugin/components/rules/LICENSE +21 -0
  150. package/packages/omo-codex/plugin/components/rules/NOTICE +15 -0
  151. package/packages/omo-codex/plugin/components/rules/README.md +124 -0
  152. package/packages/omo-codex/plugin/components/rules/biome.json +48 -0
  153. package/packages/omo-codex/plugin/components/rules/bundled-rules/hephaestus.md +209 -0
  154. package/packages/omo-codex/plugin/components/rules/hooks/hooks.json +54 -0
  155. package/packages/omo-codex/plugin/components/rules/package.json +62 -0
  156. package/packages/omo-codex/plugin/components/rules/scripts/bench-codex-rules.mjs +268 -0
  157. package/packages/omo-codex/plugin/components/rules/skills/rules/SKILL.md +34 -0
  158. package/packages/omo-codex/plugin/components/rules/src/cli.ts +143 -0
  159. package/packages/omo-codex/plugin/components/rules/src/codex-hook-options.ts +4 -0
  160. package/packages/omo-codex/plugin/components/rules/src/codex-hook.ts +238 -0
  161. package/packages/omo-codex/plugin/components/rules/src/config.ts +107 -0
  162. package/packages/omo-codex/plugin/components/rules/src/context-pressure.ts +26 -0
  163. package/packages/omo-codex/plugin/components/rules/src/debug-log.ts +65 -0
  164. package/packages/omo-codex/plugin/components/rules/src/dynamic-target-fingerprints.ts +98 -0
  165. package/packages/omo-codex/plugin/components/rules/src/hook-output.ts +19 -0
  166. package/packages/omo-codex/plugin/components/rules/src/path-utils.ts +29 -0
  167. package/packages/omo-codex/plugin/components/rules/src/persistent-cache.ts +234 -0
  168. package/packages/omo-codex/plugin/components/rules/src/post-compact-budget.ts +104 -0
  169. package/packages/omo-codex/plugin/components/rules/src/post-compact-claim.ts +13 -0
  170. package/packages/omo-codex/plugin/components/rules/src/post-compact-state.ts +45 -0
  171. package/packages/omo-codex/plugin/components/rules/src/rules/cache.ts +64 -0
  172. package/packages/omo-codex/plugin/components/rules/src/rules/constants.ts +115 -0
  173. package/packages/omo-codex/plugin/components/rules/src/rules/engine.ts +535 -0
  174. package/packages/omo-codex/plugin/components/rules/src/rules/errors.ts +13 -0
  175. package/packages/omo-codex/plugin/components/rules/src/rules/finder-cache.ts +73 -0
  176. package/packages/omo-codex/plugin/components/rules/src/rules/finder-paths.ts +47 -0
  177. package/packages/omo-codex/plugin/components/rules/src/rules/finder-sources.ts +50 -0
  178. package/packages/omo-codex/plugin/components/rules/src/rules/finder.ts +207 -0
  179. package/packages/omo-codex/plugin/components/rules/src/rules/formatter.ts +123 -0
  180. package/packages/omo-codex/plugin/components/rules/src/rules/matcher.ts +142 -0
  181. package/packages/omo-codex/plugin/components/rules/src/rules/ordering.ts +33 -0
  182. package/packages/omo-codex/plugin/components/rules/src/rules/parser.ts +326 -0
  183. package/packages/omo-codex/plugin/components/rules/src/rules/plugin-root.ts +55 -0
  184. package/packages/omo-codex/plugin/components/rules/src/rules/project-root.ts +30 -0
  185. package/packages/omo-codex/plugin/components/rules/src/rules/scanner.ts +162 -0
  186. package/packages/omo-codex/plugin/components/rules/src/rules/truncator.ts +67 -0
  187. package/packages/omo-codex/plugin/components/rules/src/rules/types.ts +141 -0
  188. package/packages/omo-codex/plugin/components/rules/src/rules-engine-factory.ts +24 -0
  189. package/packages/omo-codex/plugin/components/rules/src/session-state-lock.ts +47 -0
  190. package/packages/omo-codex/plugin/components/rules/src/static-injection.ts +56 -0
  191. package/packages/omo-codex/plugin/components/rules/src/tool-paths.ts +192 -0
  192. package/packages/omo-codex/plugin/components/rules/src/transcript-rule-filter.ts +44 -0
  193. package/packages/omo-codex/plugin/components/rules/src/transcript-search.ts +108 -0
  194. package/packages/omo-codex/plugin/components/rules/test/bundled-rules-priority.test.ts +107 -0
  195. package/packages/omo-codex/plugin/components/rules/test/bundled-rules.test.ts +268 -0
  196. package/packages/omo-codex/plugin/components/rules/test/codex-hook-context-pressure.test.ts +243 -0
  197. package/packages/omo-codex/plugin/components/rules/test/codex-hook-performance.test.ts +99 -0
  198. package/packages/omo-codex/plugin/components/rules/test/codex-hook-post-compact-budget.test.ts +132 -0
  199. package/packages/omo-codex/plugin/components/rules/test/codex-hook-post-compact-context.test.ts +156 -0
  200. package/packages/omo-codex/plugin/components/rules/test/codex-hook-post-compact-dedup.test.ts +299 -0
  201. package/packages/omo-codex/plugin/components/rules/test/codex-hook-post-compact-lock.test.ts +46 -0
  202. package/packages/omo-codex/plugin/components/rules/test/codex-hook-post-compact-process.test.ts +83 -0
  203. package/packages/omo-codex/plugin/components/rules/test/codex-hook.test.ts +667 -0
  204. package/packages/omo-codex/plugin/components/rules/test/engine.test.ts +192 -0
  205. package/packages/omo-codex/plugin/components/rules/test/finder.test.ts +102 -0
  206. package/packages/omo-codex/plugin/components/rules/test/formatter.test.ts +168 -0
  207. package/packages/omo-codex/plugin/components/rules/test/hook-output.test.ts +42 -0
  208. package/packages/omo-codex/plugin/components/rules/test/matcher.test.ts +206 -0
  209. package/packages/omo-codex/plugin/components/rules/test/package-smoke.test.ts +151 -0
  210. package/packages/omo-codex/plugin/components/rules/test/persistent-cache.test.ts +63 -0
  211. package/packages/omo-codex/plugin/components/rules/test/post-compact-budget.test.ts +172 -0
  212. package/packages/omo-codex/plugin/components/rules/test/post-compact-test-fixture.ts +196 -0
  213. package/packages/omo-codex/plugin/components/rules/test/scanner.test.ts +63 -0
  214. package/packages/omo-codex/plugin/components/rules/test/tool-paths.test.ts +198 -0
  215. package/packages/omo-codex/plugin/components/rules/tsconfig.build.json +12 -0
  216. package/packages/omo-codex/plugin/components/rules/tsconfig.json +27 -0
  217. package/packages/omo-codex/plugin/components/rules/vitest.config.ts +8 -0
  218. package/packages/omo-codex/plugin/components/start-work-continuation/.gitattributes +13 -0
  219. package/packages/omo-codex/plugin/components/start-work-continuation/AGENTS.md +43 -0
  220. package/packages/omo-codex/plugin/components/start-work-continuation/CHANGELOG.md +5 -0
  221. package/packages/omo-codex/plugin/components/start-work-continuation/LICENSE +21 -0
  222. package/packages/omo-codex/plugin/components/start-work-continuation/NOTICE +5 -0
  223. package/packages/omo-codex/plugin/components/start-work-continuation/README.md +55 -0
  224. package/packages/omo-codex/plugin/components/start-work-continuation/biome.json +48 -0
  225. package/packages/omo-codex/plugin/components/start-work-continuation/directive.md +51 -0
  226. package/packages/omo-codex/plugin/components/start-work-continuation/hooks/hooks.json +28 -0
  227. package/packages/omo-codex/plugin/components/start-work-continuation/package.json +53 -0
  228. package/packages/omo-codex/plugin/components/start-work-continuation/src/boulder-reader.ts +167 -0
  229. package/packages/omo-codex/plugin/components/start-work-continuation/src/cli.ts +52 -0
  230. package/packages/omo-codex/plugin/components/start-work-continuation/src/codex-hook.ts +66 -0
  231. package/packages/omo-codex/plugin/components/start-work-continuation/src/directive.ts +6 -0
  232. package/packages/omo-codex/plugin/components/start-work-continuation/src/index.ts +5 -0
  233. package/packages/omo-codex/plugin/components/start-work-continuation/src/types.ts +23 -0
  234. package/packages/omo-codex/plugin/components/start-work-continuation/test/boulder-reader.test.ts +63 -0
  235. package/packages/omo-codex/plugin/components/start-work-continuation/test/cli.test.ts +124 -0
  236. package/packages/omo-codex/plugin/components/start-work-continuation/test/codex-hook.test.ts +160 -0
  237. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/boulder-completed.json +19 -0
  238. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/boulder-mixed-platforms.json +27 -0
  239. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/boulder-single-codex-work.json +19 -0
  240. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/plan-all-done.md +5 -0
  241. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/plan-with-nested-checkboxes.md +11 -0
  242. package/packages/omo-codex/plugin/components/start-work-continuation/test/fixtures/plan-with-unchecked.md +6 -0
  243. package/packages/omo-codex/plugin/components/start-work-continuation/tsconfig.build.json +12 -0
  244. package/packages/omo-codex/plugin/components/start-work-continuation/tsconfig.json +27 -0
  245. package/packages/omo-codex/plugin/components/start-work-continuation/vitest.config.ts +10 -0
  246. package/packages/omo-codex/plugin/components/telemetry/AGENTS.md +37 -0
  247. package/packages/omo-codex/plugin/components/telemetry/README.md +102 -0
  248. package/packages/omo-codex/plugin/components/telemetry/biome.json +48 -0
  249. package/packages/omo-codex/plugin/components/telemetry/hooks/hooks.json +16 -0
  250. package/packages/omo-codex/plugin/components/telemetry/package.json +56 -0
  251. package/packages/omo-codex/plugin/components/telemetry/src/atomic-write.ts +22 -0
  252. package/packages/omo-codex/plugin/components/telemetry/src/cli.ts +69 -0
  253. package/packages/omo-codex/plugin/components/telemetry/src/codex-hook.ts +49 -0
  254. package/packages/omo-codex/plugin/components/telemetry/src/data-path.ts +45 -0
  255. package/packages/omo-codex/plugin/components/telemetry/src/env-flags.ts +43 -0
  256. package/packages/omo-codex/plugin/components/telemetry/src/posthog-activity-state.ts +81 -0
  257. package/packages/omo-codex/plugin/components/telemetry/src/posthog.ts +165 -0
  258. package/packages/omo-codex/plugin/components/telemetry/src/product-identity.ts +35 -0
  259. package/packages/omo-codex/plugin/components/telemetry/test/codex-hook.test.ts +270 -0
  260. package/packages/omo-codex/plugin/components/telemetry/tsconfig.build.json +12 -0
  261. package/packages/omo-codex/plugin/components/telemetry/tsconfig.json +27 -0
  262. package/packages/omo-codex/plugin/components/telemetry/vitest.config.ts +8 -0
  263. package/packages/omo-codex/plugin/components/ultrawork/AGENTS.md +41 -0
  264. package/packages/omo-codex/plugin/components/ultrawork/CHANGELOG.md +25 -0
  265. package/packages/omo-codex/plugin/components/ultrawork/LICENSE +21 -0
  266. package/packages/omo-codex/plugin/components/ultrawork/NOTICE +5 -0
  267. package/packages/omo-codex/plugin/components/ultrawork/README.md +60 -0
  268. package/packages/omo-codex/plugin/components/ultrawork/agents/codex-ultrawork-reviewer.toml +17 -0
  269. package/packages/omo-codex/plugin/components/ultrawork/agents/explorer.toml +82 -0
  270. package/packages/omo-codex/plugin/components/ultrawork/agents/librarian.toml +221 -0
  271. package/packages/omo-codex/plugin/components/ultrawork/agents/metis.toml +65 -0
  272. package/packages/omo-codex/plugin/components/ultrawork/agents/momus.toml +69 -0
  273. package/packages/omo-codex/plugin/components/ultrawork/agents/plan.toml +163 -0
  274. package/packages/omo-codex/plugin/components/ultrawork/biome.json +48 -0
  275. package/packages/omo-codex/plugin/components/ultrawork/directive.md +264 -0
  276. package/packages/omo-codex/plugin/components/ultrawork/hooks/hooks.json +16 -0
  277. package/packages/omo-codex/plugin/components/ultrawork/package.json +54 -0
  278. package/packages/omo-codex/plugin/components/ultrawork/src/cli.ts +50 -0
  279. package/packages/omo-codex/plugin/components/ultrawork/src/codex-hook.ts +84 -0
  280. package/packages/omo-codex/plugin/components/ultrawork/src/directive.ts +3 -0
  281. package/packages/omo-codex/plugin/components/ultrawork/test/codex-hook.test.ts +252 -0
  282. package/packages/omo-codex/plugin/components/ultrawork/test/package-smoke.test.ts +78 -0
  283. package/packages/omo-codex/plugin/components/ultrawork/tsconfig.build.json +12 -0
  284. package/packages/omo-codex/plugin/components/ultrawork/tsconfig.json +27 -0
  285. package/packages/omo-codex/plugin/components/ulw-loop/.gitattributes +13 -0
  286. package/packages/omo-codex/plugin/components/ulw-loop/AGENTS.md +48 -0
  287. package/packages/omo-codex/plugin/components/ulw-loop/CHANGELOG.md +7 -0
  288. package/packages/omo-codex/plugin/components/ulw-loop/LICENSE +21 -0
  289. package/packages/omo-codex/plugin/components/ulw-loop/NOTICE +6 -0
  290. package/packages/omo-codex/plugin/components/ulw-loop/README.md +74 -0
  291. package/packages/omo-codex/plugin/components/ulw-loop/biome.json +48 -0
  292. package/packages/omo-codex/plugin/components/ulw-loop/hooks/hooks.json +29 -0
  293. package/packages/omo-codex/plugin/components/ulw-loop/package.json +55 -0
  294. package/packages/omo-codex/plugin/components/ulw-loop/skills/ulw-loop/.gitkeep +0 -0
  295. package/packages/omo-codex/plugin/components/ulw-loop/skills/ulw-loop/SKILL.md +222 -0
  296. package/packages/omo-codex/plugin/components/ulw-loop/skills/ulw-loop/agents/openai.yaml +6 -0
  297. package/packages/omo-codex/plugin/components/ulw-loop/src/.gitkeep +0 -0
  298. package/packages/omo-codex/plugin/components/ulw-loop/src/checkpoint.ts +155 -0
  299. package/packages/omo-codex/plugin/components/ulw-loop/src/cli-arg-parser.ts +95 -0
  300. package/packages/omo-codex/plugin/components/ulw-loop/src/cli-commands.ts +156 -0
  301. package/packages/omo-codex/plugin/components/ulw-loop/src/cli-output.ts +63 -0
  302. package/packages/omo-codex/plugin/components/ulw-loop/src/cli-steering.ts +94 -0
  303. package/packages/omo-codex/plugin/components/ulw-loop/src/cli.ts +40 -0
  304. package/packages/omo-codex/plugin/components/ulw-loop/src/codex-goal-instruction.ts +129 -0
  305. package/packages/omo-codex/plugin/components/ulw-loop/src/codex-goal-snapshot.ts +139 -0
  306. package/packages/omo-codex/plugin/components/ulw-loop/src/codex-hook.ts +177 -0
  307. package/packages/omo-codex/plugin/components/ulw-loop/src/evidence.ts +122 -0
  308. package/packages/omo-codex/plugin/components/ulw-loop/src/goal-status.ts +88 -0
  309. package/packages/omo-codex/plugin/components/ulw-loop/src/paths.ts +73 -0
  310. package/packages/omo-codex/plugin/components/ulw-loop/src/plan-crud.ts +113 -0
  311. package/packages/omo-codex/plugin/components/ulw-loop/src/plan-io.ts +124 -0
  312. package/packages/omo-codex/plugin/components/ulw-loop/src/quality-gate.ts +102 -0
  313. package/packages/omo-codex/plugin/components/ulw-loop/src/review-blockers.ts +81 -0
  314. package/packages/omo-codex/plugin/components/ulw-loop/src/steering.ts +270 -0
  315. package/packages/omo-codex/plugin/components/ulw-loop/src/types.ts +277 -0
  316. package/packages/omo-codex/plugin/components/ulw-loop/test/checkpoint.test.ts +213 -0
  317. package/packages/omo-codex/plugin/components/ulw-loop/test/cli-commands.test.ts +375 -0
  318. package/packages/omo-codex/plugin/components/ulw-loop/test/cli-helpers.test.ts +250 -0
  319. package/packages/omo-codex/plugin/components/ulw-loop/test/cli-steering.test.ts +407 -0
  320. package/packages/omo-codex/plugin/components/ulw-loop/test/codex-goal-instruction.test.ts +169 -0
  321. package/packages/omo-codex/plugin/components/ulw-loop/test/codex-goal-snapshot.test.ts +156 -0
  322. package/packages/omo-codex/plugin/components/ulw-loop/test/codex-hook.test.ts +275 -0
  323. package/packages/omo-codex/plugin/components/ulw-loop/test/evidence-criteria-gate.test.ts +100 -0
  324. package/packages/omo-codex/plugin/components/ulw-loop/test/evidence.test.ts +263 -0
  325. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/.gitkeep +0 -0
  326. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/codex-goal-snapshot.json +1 -0
  327. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/sample-brief.md +5 -0
  328. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/sample-plan.json +108 -0
  329. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/sample-quality-gate.json +18 -0
  330. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/steering-proposal.json +8 -0
  331. package/packages/omo-codex/plugin/components/ulw-loop/test/fixtures/user-prompt-submit.json +10 -0
  332. package/packages/omo-codex/plugin/components/ulw-loop/test/goal-status.test.ts +327 -0
  333. package/packages/omo-codex/plugin/components/ulw-loop/test/package-smoke.test.ts +164 -0
  334. package/packages/omo-codex/plugin/components/ulw-loop/test/paths.test.ts +62 -0
  335. package/packages/omo-codex/plugin/components/ulw-loop/test/plan-crud.test.ts +256 -0
  336. package/packages/omo-codex/plugin/components/ulw-loop/test/plan-io.test.ts +239 -0
  337. package/packages/omo-codex/plugin/components/ulw-loop/test/quality-gate.test.ts +203 -0
  338. package/packages/omo-codex/plugin/components/ulw-loop/test/review-blockers.test.ts +180 -0
  339. package/packages/omo-codex/plugin/components/ulw-loop/test/steering.test.ts +353 -0
  340. package/packages/omo-codex/plugin/components/ulw-loop/test/types.test.ts +79 -0
  341. package/packages/omo-codex/plugin/components/ulw-loop/tsconfig.build.json +12 -0
  342. package/packages/omo-codex/plugin/components/ulw-loop/tsconfig.json +27 -0
  343. package/packages/omo-codex/plugin/components/ulw-loop/vitest.config.ts +10 -0
  344. package/packages/omo-codex/plugin/hooks/hooks.json +138 -0
  345. package/packages/omo-codex/plugin/package-lock.json +1750 -0
  346. package/packages/omo-codex/plugin/package.json +26 -0
  347. package/packages/omo-codex/plugin/scripts/build-bundled-mcp-runtimes.mjs +50 -0
  348. package/packages/omo-codex/plugin/scripts/build-components.mjs +23 -0
  349. package/packages/omo-codex/plugin/scripts/hook-status-message.mjs +46 -0
  350. package/packages/omo-codex/plugin/scripts/sync-skills.mjs +75 -0
  351. package/packages/omo-codex/plugin/skills/comment-checker/SKILL.md +16 -0
  352. package/packages/omo-codex/plugin/skills/debugging/SKILL.md +116 -0
  353. package/packages/omo-codex/plugin/skills/debugging/references/methodology/00-setup.md +108 -0
  354. package/packages/omo-codex/plugin/skills/debugging/references/methodology/02-investigate.md +130 -0
  355. package/packages/omo-codex/plugin/skills/debugging/references/methodology/04-oracle-triple.md +136 -0
  356. package/packages/omo-codex/plugin/skills/debugging/references/methodology/05-escalate.md +69 -0
  357. package/packages/omo-codex/plugin/skills/debugging/references/methodology/06-fix.md +116 -0
  358. package/packages/omo-codex/plugin/skills/debugging/references/methodology/08-qa.md +94 -0
  359. package/packages/omo-codex/plugin/skills/debugging/references/methodology/09-cleanup.md +164 -0
  360. package/packages/omo-codex/plugin/skills/debugging/references/methodology/partial-runtime-evidence.md +229 -0
  361. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/bundled-js-binary.md +415 -0
  362. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/go.md +252 -0
  363. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/native-binary.md +484 -0
  364. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/node.md +260 -0
  365. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/python.md +248 -0
  366. package/packages/omo-codex/plugin/skills/debugging/references/runtimes/rust.md +234 -0
  367. package/packages/omo-codex/plugin/skills/debugging/references/tools/ghidra.md +212 -0
  368. package/packages/omo-codex/plugin/skills/debugging/references/tools/playwright-cli.md +194 -0
  369. package/packages/omo-codex/plugin/skills/debugging/references/tools/pwndbg.md +263 -0
  370. package/packages/omo-codex/plugin/skills/debugging/references/tools/pwntools.md +265 -0
  371. package/packages/omo-codex/plugin/skills/frontend-ui-ux/SKILL.md +77 -0
  372. package/packages/omo-codex/plugin/skills/init-deep/SKILL.md +325 -0
  373. package/packages/omo-codex/plugin/skills/lsp/SKILL.md +35 -0
  374. package/packages/omo-codex/plugin/skills/programming/SKILL.md +463 -0
  375. package/packages/omo-codex/plugin/skills/programming/references/go/README.md +90 -0
  376. package/packages/omo-codex/plugin/skills/programming/references/go/backend-stack.md +641 -0
  377. package/packages/omo-codex/plugin/skills/programming/references/go/bootstrap.md +328 -0
  378. package/packages/omo-codex/plugin/skills/programming/references/go/bubbletea-v2.md +360 -0
  379. package/packages/omo-codex/plugin/skills/programming/references/go/cobra-stack.md +468 -0
  380. package/packages/omo-codex/plugin/skills/programming/references/go/concurrency.md +362 -0
  381. package/packages/omo-codex/plugin/skills/programming/references/go/data-modeling.md +329 -0
  382. package/packages/omo-codex/plugin/skills/programming/references/go/error-handling.md +359 -0
  383. package/packages/omo-codex/plugin/skills/programming/references/go/golangci-strict.md +236 -0
  384. package/packages/omo-codex/plugin/skills/programming/references/go/grpc-connect.md +375 -0
  385. package/packages/omo-codex/plugin/skills/programming/references/go/libraries.md +337 -0
  386. package/packages/omo-codex/plugin/skills/programming/references/go/one-liners.md +202 -0
  387. package/packages/omo-codex/plugin/skills/programming/references/go/sqlc-pgx.md +471 -0
  388. package/packages/omo-codex/plugin/skills/programming/references/go/testing.md +467 -0
  389. package/packages/omo-codex/plugin/skills/programming/references/go/type-patterns.md +298 -0
  390. package/packages/omo-codex/plugin/skills/programming/references/python/README.md +314 -0
  391. package/packages/omo-codex/plugin/skills/programming/references/python/async-anyio.md +442 -0
  392. package/packages/omo-codex/plugin/skills/programming/references/python/data-modeling.md +233 -0
  393. package/packages/omo-codex/plugin/skills/programming/references/python/data-processing.md +133 -0
  394. package/packages/omo-codex/plugin/skills/programming/references/python/error-handling.md +218 -0
  395. package/packages/omo-codex/plugin/skills/programming/references/python/fastapi-stack.md +316 -0
  396. package/packages/omo-codex/plugin/skills/programming/references/python/httpx2-optimization.md +360 -0
  397. package/packages/omo-codex/plugin/skills/programming/references/python/libraries.md +307 -0
  398. package/packages/omo-codex/plugin/skills/programming/references/python/one-liners.md +268 -0
  399. package/packages/omo-codex/plugin/skills/programming/references/python/orjson-stack.md +378 -0
  400. package/packages/omo-codex/plugin/skills/programming/references/python/pydantic-ai.md +285 -0
  401. package/packages/omo-codex/plugin/skills/programming/references/python/pyproject-strict.md +232 -0
  402. package/packages/omo-codex/plugin/skills/programming/references/python/textual-tui.md +201 -0
  403. package/packages/omo-codex/plugin/skills/programming/references/python/type-patterns.md +176 -0
  404. package/packages/omo-codex/plugin/skills/programming/references/rust/README.md +317 -0
  405. package/packages/omo-codex/plugin/skills/programming/references/rust/async-tokio.md +299 -0
  406. package/packages/omo-codex/plugin/skills/programming/references/rust/axum-stack.md +467 -0
  407. package/packages/omo-codex/plugin/skills/programming/references/rust/cargo-strict.md +317 -0
  408. package/packages/omo-codex/plugin/skills/programming/references/rust/clap-stack.md +409 -0
  409. package/packages/omo-codex/plugin/skills/programming/references/rust/concurrency.md +375 -0
  410. package/packages/omo-codex/plugin/skills/programming/references/rust/libraries.md +439 -0
  411. package/packages/omo-codex/plugin/skills/programming/references/rust/one-liners.md +291 -0
  412. package/packages/omo-codex/plugin/skills/programming/references/rust/proptest-insta.md +429 -0
  413. package/packages/omo-codex/plugin/skills/programming/references/rust/type-state.md +354 -0
  414. package/packages/omo-codex/plugin/skills/programming/references/rust/unsafe-discipline.md +250 -0
  415. package/packages/omo-codex/plugin/skills/programming/references/rust/zero-cost-safety.md +527 -0
  416. package/packages/omo-codex/plugin/skills/programming/references/rust-ub/README.md +289 -0
  417. package/packages/omo-codex/plugin/skills/programming/references/rust-ub/miri-sanitizers-loom.md +411 -0
  418. package/packages/omo-codex/plugin/skills/programming/references/rust-ub/ub-taxonomy.md +269 -0
  419. package/packages/omo-codex/plugin/skills/programming/references/typescript/README.md +195 -0
  420. package/packages/omo-codex/plugin/skills/programming/references/typescript/backend-hono.md +672 -0
  421. package/packages/omo-codex/plugin/skills/programming/references/typescript/bootstrap.md +199 -0
  422. package/packages/omo-codex/plugin/skills/programming/references/typescript/data-modeling.md +202 -0
  423. package/packages/omo-codex/plugin/skills/programming/references/typescript/error-handling.md +169 -0
  424. package/packages/omo-codex/plugin/skills/programming/references/typescript/tsconfig-strict.md +152 -0
  425. package/packages/omo-codex/plugin/skills/programming/references/typescript/type-patterns.md +196 -0
  426. package/packages/omo-codex/plugin/skills/programming/scripts/go/check-no-excuse-rules.sh +173 -0
  427. package/packages/omo-codex/plugin/skills/programming/scripts/go/new-project.py +138 -0
  428. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/.editorconfig +13 -0
  429. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/.golangci.yml +95 -0
  430. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/AGENTS.md.tmpl +24 -0
  431. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/README.md.tmpl +12 -0
  432. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/Taskfile.yml +40 -0
  433. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/ci.yml +37 -0
  434. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/config.go +24 -0
  435. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/gitignore +15 -0
  436. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/main.go.tmpl +22 -0
  437. package/packages/omo-codex/plugin/skills/programming/scripts/go/templates/run.go +15 -0
  438. package/packages/omo-codex/plugin/skills/programming/scripts/python/check-no-excuse-rules.py +687 -0
  439. package/packages/omo-codex/plugin/skills/programming/scripts/python/new-project.py +172 -0
  440. package/packages/omo-codex/plugin/skills/programming/scripts/python/new-script.py +116 -0
  441. package/packages/omo-codex/plugin/skills/programming/scripts/rust/check-no-excuse-rules.py +296 -0
  442. package/packages/omo-codex/plugin/skills/programming/scripts/rust/check-no-excuse-rules.sh +158 -0
  443. package/packages/omo-codex/plugin/skills/programming/scripts/rust/new-project.py +175 -0
  444. package/packages/omo-codex/plugin/skills/programming/scripts/typescript/check-no-excuse-rules.ts +282 -0
  445. package/packages/omo-codex/plugin/skills/programming/scripts/typescript/new-project.ts +177 -0
  446. package/packages/omo-codex/plugin/skills/refactor/SKILL.md +779 -0
  447. package/packages/omo-codex/plugin/skills/remove-ai-slops/SKILL.md +333 -0
  448. package/packages/omo-codex/plugin/skills/review-work/SKILL.md +549 -0
  449. package/packages/omo-codex/plugin/skills/rules/SKILL.md +34 -0
  450. package/packages/omo-codex/plugin/skills/start-work/SKILL.md +129 -0
  451. package/packages/omo-codex/plugin/skills/ulw-loop/.gitkeep +0 -0
  452. package/packages/omo-codex/plugin/skills/ulw-loop/SKILL.md +222 -0
  453. package/packages/omo-codex/plugin/skills/ulw-loop/agents/openai.yaml +6 -0
  454. package/packages/omo-codex/plugin/skills/ulw-plan/SKILL.md +399 -0
  455. package/packages/omo-codex/plugin/test/aggregate.test.mjs +330 -0
  456. package/packages/omo-codex/plugin/test/component-bin-names.test.mjs +66 -0
  457. package/packages/omo-codex/plugin/test/hook-status-message.test.mjs +150 -0
  458. package/packages/omo-codex/plugin/test/sync-skills.test.mjs +199 -0
  459. package/packages/omo-codex/scripts/install/agents.mjs +84 -0
  460. package/packages/omo-codex/scripts/install/cache.mjs +245 -0
  461. package/packages/omo-codex/scripts/install/command-shim.mjs +1 -0
  462. package/packages/omo-codex/scripts/install/config.mjs +229 -0
  463. package/packages/omo-codex/scripts/install/hook-trust.mjs +84 -0
  464. package/packages/omo-codex/scripts/install/legacy-bins.mjs +57 -0
  465. package/packages/omo-codex/scripts/install/marketplace.mjs +104 -0
  466. package/packages/omo-codex/scripts/install/mcp-runtime-cache.mjs +77 -0
  467. package/packages/omo-codex/scripts/install/multi-agent-v2-config.mjs +32 -0
  468. package/packages/omo-codex/scripts/install/process.mjs +19 -0
  469. package/packages/omo-codex/scripts/install/snapshot.mjs +54 -0
  470. package/packages/omo-codex/scripts/install/toml-editor.mjs +47 -0
  471. package/packages/omo-codex/scripts/install/utils.mjs +15 -0
  472. package/packages/omo-codex/scripts/install-agent-links.test.mjs +104 -0
  473. package/packages/omo-codex/scripts/install-bin-links.test.mjs +123 -0
  474. package/packages/omo-codex/scripts/install-cache-copy.test.mjs +30 -0
  475. package/packages/omo-codex/scripts/install-config.test.mjs +118 -0
  476. package/packages/omo-codex/scripts/install-local.mjs +192 -0
  477. package/packages/omo-codex/scripts/install-local.test.mjs +379 -0
  478. package/packages/omo-codex/scripts/install-mcp-runtime.test.mjs +173 -0
  479. package/packages/omo-codex/scripts/install-test-fixtures.mjs +58 -0
  480. package/packages/omo-codex/scripts/sync-telemetry-component.mjs +115 -0
  481. package/packages/omo-codex/scripts/sync-telemetry-component.test.mjs +94 -0
  482. package/packages/shared-skills/index.mjs +5 -0
  483. package/packages/shared-skills/package.json +14 -0
  484. package/packages/shared-skills/skills/debugging/SKILL.md +116 -0
  485. package/packages/shared-skills/skills/debugging/references/methodology/00-setup.md +108 -0
  486. package/packages/shared-skills/skills/debugging/references/methodology/02-investigate.md +130 -0
  487. package/packages/shared-skills/skills/debugging/references/methodology/04-oracle-triple.md +136 -0
  488. package/packages/shared-skills/skills/debugging/references/methodology/05-escalate.md +69 -0
  489. package/packages/shared-skills/skills/debugging/references/methodology/06-fix.md +116 -0
  490. package/packages/shared-skills/skills/debugging/references/methodology/08-qa.md +94 -0
  491. package/packages/shared-skills/skills/debugging/references/methodology/09-cleanup.md +164 -0
  492. package/packages/shared-skills/skills/debugging/references/methodology/partial-runtime-evidence.md +229 -0
  493. package/packages/shared-skills/skills/debugging/references/runtimes/bundled-js-binary.md +415 -0
  494. package/packages/shared-skills/skills/debugging/references/runtimes/go.md +252 -0
  495. package/packages/shared-skills/skills/debugging/references/runtimes/native-binary.md +484 -0
  496. package/packages/shared-skills/skills/debugging/references/runtimes/node.md +260 -0
  497. package/packages/shared-skills/skills/debugging/references/runtimes/python.md +248 -0
  498. package/packages/shared-skills/skills/debugging/references/runtimes/rust.md +234 -0
  499. package/packages/shared-skills/skills/debugging/references/tools/ghidra.md +212 -0
  500. package/packages/shared-skills/skills/debugging/references/tools/playwright-cli.md +194 -0
  501. package/packages/shared-skills/skills/debugging/references/tools/pwndbg.md +263 -0
  502. package/packages/shared-skills/skills/debugging/references/tools/pwntools.md +265 -0
  503. package/packages/shared-skills/skills/frontend-ui-ux/SKILL.md +77 -0
  504. package/packages/shared-skills/skills/init-deep/SKILL.md +309 -0
  505. package/packages/shared-skills/skills/programming/SKILL.md +463 -0
  506. package/packages/shared-skills/skills/programming/references/go/README.md +90 -0
  507. package/packages/shared-skills/skills/programming/references/go/backend-stack.md +641 -0
  508. package/packages/shared-skills/skills/programming/references/go/bootstrap.md +328 -0
  509. package/packages/shared-skills/skills/programming/references/go/bubbletea-v2.md +360 -0
  510. package/packages/shared-skills/skills/programming/references/go/cobra-stack.md +468 -0
  511. package/packages/shared-skills/skills/programming/references/go/concurrency.md +362 -0
  512. package/packages/shared-skills/skills/programming/references/go/data-modeling.md +329 -0
  513. package/packages/shared-skills/skills/programming/references/go/error-handling.md +359 -0
  514. package/packages/shared-skills/skills/programming/references/go/golangci-strict.md +236 -0
  515. package/packages/shared-skills/skills/programming/references/go/grpc-connect.md +375 -0
  516. package/packages/shared-skills/skills/programming/references/go/libraries.md +337 -0
  517. package/packages/shared-skills/skills/programming/references/go/one-liners.md +202 -0
  518. package/packages/shared-skills/skills/programming/references/go/sqlc-pgx.md +471 -0
  519. package/packages/shared-skills/skills/programming/references/go/testing.md +467 -0
  520. package/packages/shared-skills/skills/programming/references/go/type-patterns.md +298 -0
  521. package/packages/shared-skills/skills/programming/references/python/README.md +314 -0
  522. package/packages/shared-skills/skills/programming/references/python/async-anyio.md +442 -0
  523. package/packages/shared-skills/skills/programming/references/python/data-modeling.md +233 -0
  524. package/packages/shared-skills/skills/programming/references/python/data-processing.md +133 -0
  525. package/packages/shared-skills/skills/programming/references/python/error-handling.md +218 -0
  526. package/packages/shared-skills/skills/programming/references/python/fastapi-stack.md +316 -0
  527. package/packages/shared-skills/skills/programming/references/python/httpx2-optimization.md +360 -0
  528. package/packages/shared-skills/skills/programming/references/python/libraries.md +307 -0
  529. package/packages/shared-skills/skills/programming/references/python/one-liners.md +268 -0
  530. package/packages/shared-skills/skills/programming/references/python/orjson-stack.md +378 -0
  531. package/packages/shared-skills/skills/programming/references/python/pydantic-ai.md +285 -0
  532. package/packages/shared-skills/skills/programming/references/python/pyproject-strict.md +232 -0
  533. package/packages/shared-skills/skills/programming/references/python/textual-tui.md +201 -0
  534. package/packages/shared-skills/skills/programming/references/python/type-patterns.md +176 -0
  535. package/packages/shared-skills/skills/programming/references/rust/README.md +317 -0
  536. package/packages/shared-skills/skills/programming/references/rust/async-tokio.md +299 -0
  537. package/packages/shared-skills/skills/programming/references/rust/axum-stack.md +467 -0
  538. package/packages/shared-skills/skills/programming/references/rust/cargo-strict.md +317 -0
  539. package/packages/shared-skills/skills/programming/references/rust/clap-stack.md +409 -0
  540. package/packages/shared-skills/skills/programming/references/rust/concurrency.md +375 -0
  541. package/packages/shared-skills/skills/programming/references/rust/libraries.md +439 -0
  542. package/packages/shared-skills/skills/programming/references/rust/one-liners.md +291 -0
  543. package/packages/shared-skills/skills/programming/references/rust/proptest-insta.md +429 -0
  544. package/packages/shared-skills/skills/programming/references/rust/type-state.md +354 -0
  545. package/packages/shared-skills/skills/programming/references/rust/unsafe-discipline.md +250 -0
  546. package/packages/shared-skills/skills/programming/references/rust/zero-cost-safety.md +527 -0
  547. package/packages/shared-skills/skills/programming/references/rust-ub/README.md +289 -0
  548. package/packages/shared-skills/skills/programming/references/rust-ub/miri-sanitizers-loom.md +411 -0
  549. package/packages/shared-skills/skills/programming/references/rust-ub/ub-taxonomy.md +269 -0
  550. package/packages/shared-skills/skills/programming/references/typescript/README.md +195 -0
  551. package/packages/shared-skills/skills/programming/references/typescript/backend-hono.md +672 -0
  552. package/packages/shared-skills/skills/programming/references/typescript/bootstrap.md +199 -0
  553. package/packages/shared-skills/skills/programming/references/typescript/data-modeling.md +202 -0
  554. package/packages/shared-skills/skills/programming/references/typescript/error-handling.md +169 -0
  555. package/packages/shared-skills/skills/programming/references/typescript/tsconfig-strict.md +152 -0
  556. package/packages/shared-skills/skills/programming/references/typescript/type-patterns.md +196 -0
  557. package/packages/shared-skills/skills/programming/scripts/go/check-no-excuse-rules.sh +173 -0
  558. package/packages/shared-skills/skills/programming/scripts/go/new-project.py +138 -0
  559. package/packages/shared-skills/skills/programming/scripts/go/templates/.editorconfig +13 -0
  560. package/packages/shared-skills/skills/programming/scripts/go/templates/.golangci.yml +95 -0
  561. package/packages/shared-skills/skills/programming/scripts/go/templates/AGENTS.md.tmpl +24 -0
  562. package/packages/shared-skills/skills/programming/scripts/go/templates/README.md.tmpl +12 -0
  563. package/packages/shared-skills/skills/programming/scripts/go/templates/Taskfile.yml +40 -0
  564. package/packages/shared-skills/skills/programming/scripts/go/templates/ci.yml +37 -0
  565. package/packages/shared-skills/skills/programming/scripts/go/templates/config.go +24 -0
  566. package/packages/shared-skills/skills/programming/scripts/go/templates/gitignore +15 -0
  567. package/packages/shared-skills/skills/programming/scripts/go/templates/main.go.tmpl +22 -0
  568. package/packages/shared-skills/skills/programming/scripts/go/templates/run.go +15 -0
  569. package/packages/shared-skills/skills/programming/scripts/python/check-no-excuse-rules.py +687 -0
  570. package/packages/shared-skills/skills/programming/scripts/python/new-project.py +172 -0
  571. package/packages/shared-skills/skills/programming/scripts/python/new-script.py +116 -0
  572. package/packages/shared-skills/skills/programming/scripts/rust/check-no-excuse-rules.py +296 -0
  573. package/packages/shared-skills/skills/programming/scripts/rust/check-no-excuse-rules.sh +158 -0
  574. package/packages/shared-skills/skills/programming/scripts/rust/new-project.py +175 -0
  575. package/packages/shared-skills/skills/programming/scripts/typescript/check-no-excuse-rules.ts +282 -0
  576. package/packages/shared-skills/skills/programming/scripts/typescript/new-project.ts +177 -0
  577. package/packages/shared-skills/skills/refactor/SKILL.md +763 -0
  578. package/packages/shared-skills/skills/remove-ai-slops/SKILL.md +317 -0
  579. package/packages/shared-skills/skills/review-work/SKILL.md +549 -0
  580. package/packages/shared-skills/skills/start-work/SKILL.md +129 -0
  581. package/packages/shared-skills/skills/ulw-plan/SKILL.md +383 -0
  582. package/postinstall.mjs +6 -2
  583. package/dist/features/builtin-commands/templates/init-deep.d.ts +0 -1
  584. package/dist/features/builtin-skills/skills/ai-slop-remover.d.ts +0 -2
@@ -0,0 +1,229 @@
1
+ import { mkdir, readFile, writeFile } from "node:fs/promises";
2
+ import { dirname } from "node:path";
3
+
4
+ import { ensureCodexMultiAgentV2Config } from "./multi-agent-v2-config.mjs";
5
+ import { appendBlock, findTomlSection, replaceOrInsertSetting } from "./toml-editor.mjs";
6
+ import { exists } from "./utils.mjs";
7
+
8
+ const LEGACY_CODEX_PLUGIN_MARKETPLACE = ["code", "yeongyu", "codex", "plugins"].join("-");
9
+ const SISYPHUS_LEGACY_MARKETPLACES = ["lazycodex", LEGACY_CODEX_PLUGIN_MARKETPLACE];
10
+ const MANAGED_CODEX_AGENT_NAMES = [
11
+ "codex-ultrawork-reviewer",
12
+ "explorer",
13
+ "librarian",
14
+ "metis",
15
+ "momus",
16
+ "plan",
17
+ ];
18
+
19
+ export async function updateCodexConfig({
20
+ configPath,
21
+ repoRoot,
22
+ marketplaceName,
23
+ marketplaceSource = defaultMarketplaceSource(marketplaceName, repoRoot),
24
+ pluginNames,
25
+ trustedHookStates = [],
26
+ agentConfigs = [],
27
+ }) {
28
+ await mkdir(dirname(configPath), { recursive: true });
29
+ let config = "";
30
+ if (await exists(configPath)) config = await readFile(configPath, "utf8");
31
+
32
+ for (const legacyMarketplaceName of legacyMarketplaceNames(marketplaceName)) {
33
+ config = removeMarketplaceBlock(config, legacyMarketplaceName);
34
+ config = removeStaleMarketplacePluginBlocks(config, legacyMarketplaceName, new Set());
35
+ config = removeStaleMarketplaceHookStateBlocks(config, legacyMarketplaceName, new Set());
36
+ }
37
+ config = removeStaleMarketplacePluginBlocks(config, marketplaceName, new Set(pluginNames));
38
+ config = removeStaleMarketplaceHookStateBlocks(config, marketplaceName, new Set(pluginNames));
39
+ config = removeStaleManagedAgentBlocks(config, new Set(agentConfigs.map((agentConfig) => agentConfig.name)));
40
+ config = ensureFeatureEnabled(config, "plugins");
41
+ config = ensureFeatureEnabled(config, "plugin_hooks");
42
+ config = ensureCodexMultiAgentV2Config(config);
43
+ config = ensureMarketplaceBlock(config, marketplaceName, marketplaceSource);
44
+ for (const pluginName of pluginNames) {
45
+ config = ensurePluginEnabled(config, `${pluginName}@${marketplaceName}`);
46
+ }
47
+ for (const state of trustedHookStates) {
48
+ config = ensureHookTrusted(config, state.key, state.trustedHash);
49
+ }
50
+ for (const agentConfig of agentConfigs) {
51
+ config = ensureAgentConfig(config, agentConfig);
52
+ }
53
+
54
+ await writeFile(configPath, config.trimEnd() + "\n");
55
+ }
56
+
57
+ function legacyMarketplaceNames(marketplaceName) {
58
+ return marketplaceName === "sisyphuslabs" ? SISYPHUS_LEGACY_MARKETPLACES : [];
59
+ }
60
+
61
+ function removeMarketplaceBlock(config, marketplaceName) {
62
+ return removeTomlSections(config, (header) => header === `marketplaces.${marketplaceName}`);
63
+ }
64
+
65
+ function defaultMarketplaceSource(marketplaceName, repoRoot) {
66
+ return {
67
+ sourceType: "local",
68
+ source: repoRoot,
69
+ };
70
+ }
71
+
72
+ function removeStaleMarketplacePluginBlocks(config, marketplaceName, keepPluginNames) {
73
+ return removeTomlSections(config, (header) => {
74
+ const pluginKey = parsePluginHeaderKey(header);
75
+ if (pluginKey === null) return false;
76
+ const suffix = `@${marketplaceName}`;
77
+ if (!pluginKey.endsWith(suffix)) return false;
78
+ return !keepPluginNames.has(pluginKey.slice(0, -suffix.length));
79
+ });
80
+ }
81
+
82
+ function removeStaleMarketplaceHookStateBlocks(config, marketplaceName, keepPluginNames) {
83
+ return removeTomlSections(config, (header) => {
84
+ const prefix = "hooks.state.";
85
+ if (!header.startsWith(prefix)) return false;
86
+ const hookKey = parseJsonString(header.slice(prefix.length));
87
+ if (hookKey === null) return false;
88
+ const separator = hookKey.indexOf(":");
89
+ if (separator === -1) return false;
90
+ const pluginKey = hookKey.slice(0, separator);
91
+ const suffix = `@${marketplaceName}`;
92
+ if (!pluginKey.endsWith(suffix)) return false;
93
+ return !keepPluginNames.has(pluginKey.slice(0, -suffix.length));
94
+ });
95
+ }
96
+
97
+ function removeStaleManagedAgentBlocks(config, keepAgentNames) {
98
+ const managedAgentNames = new Set(MANAGED_CODEX_AGENT_NAMES);
99
+ return splitTomlSections(config)
100
+ .filter((section) => {
101
+ if (section.header === null) return true;
102
+ const agentName = parseAgentHeaderName(section.header);
103
+ if (agentName === null || !managedAgentNames.has(agentName) || keepAgentNames.has(agentName)) return true;
104
+ return !section.text.includes(`config_file = ${JSON.stringify(`./agents/${agentName}.toml`)}`);
105
+ })
106
+ .map((section) => section.text)
107
+ .join("")
108
+ .replace(/\n{3,}/g, "\n\n");
109
+ }
110
+
111
+ function ensureFeatureEnabled(config, featureName) {
112
+ const section = findTomlSection(config, "features");
113
+ if (!section) return appendBlock(config, `[features]\n${featureName} = true\n`);
114
+ return replaceOrInsertSetting(config, section, featureName, "true");
115
+ }
116
+
117
+ function ensureMarketplaceBlock(config, marketplaceName, source) {
118
+ const header = `marketplaces.${marketplaceName}`;
119
+ const block = [
120
+ `[${header}]`,
121
+ `last_updated = "${new Date().toISOString().replace(/\.\d{3}Z$/, "Z")}"`,
122
+ `source_type = ${JSON.stringify(source.sourceType)}`,
123
+ `source = ${JSON.stringify(source.source)}`,
124
+ source.ref === undefined ? null : `ref = ${JSON.stringify(source.ref)}`,
125
+ "",
126
+ ].filter((line) => line !== null).join("\n");
127
+ const section = findTomlSection(config, header);
128
+ if (section) return config.slice(0, section.start) + block + config.slice(section.end);
129
+ return appendBlock(config, block);
130
+ }
131
+
132
+ function ensurePluginEnabled(config, pluginKey) {
133
+ const header = `plugins.${JSON.stringify(pluginKey)}`;
134
+ const section = findTomlSection(config, header);
135
+ if (!section) return appendBlock(config, `[${header}]\nenabled = true\n`);
136
+ return replaceOrInsertSetting(config, section, "enabled", "true");
137
+ }
138
+
139
+ function ensureHookTrusted(config, key, trustedHash) {
140
+ const header = `hooks.state.${JSON.stringify(key)}`;
141
+ const section = findTomlSection(config, header);
142
+ if (!section) return appendBlock(config, `[${header}]\ntrusted_hash = ${JSON.stringify(trustedHash)}\n`);
143
+ return replaceOrInsertSetting(config, section, "trusted_hash", JSON.stringify(trustedHash));
144
+ }
145
+
146
+ function ensureAgentConfig(config, agentConfig) {
147
+ const header = `agents.${tomlKeySegment(agentConfig.name)}`;
148
+ const section = findTomlSection(config, header);
149
+ const configFile = JSON.stringify(agentConfig.configFile);
150
+ if (!section) return appendBlock(config, `[${header}]\nconfig_file = ${configFile}\n`);
151
+ return replaceOrInsertSetting(config, section, "config_file", configFile);
152
+ }
153
+
154
+ function tomlKeySegment(value) {
155
+ return /^[A-Za-z0-9_-]+$/.test(value) ? value : JSON.stringify(value);
156
+ }
157
+
158
+ function removeTomlSections(config, shouldRemove) {
159
+ return splitTomlSections(config)
160
+ .filter((section) => section.header === null || !shouldRemove(section.header))
161
+ .map((section) => section.text)
162
+ .join("")
163
+ .replace(/\n{3,}/g, "\n\n");
164
+ }
165
+
166
+ function splitTomlSections(config) {
167
+ const lines = config.match(/[^\n]*\n?|$/g) ?? [];
168
+ const sections = [];
169
+ let current = { header: null, text: "" };
170
+ for (const line of lines) {
171
+ if (line.length === 0) break;
172
+ const header = parseTomlHeader(line);
173
+ if (header !== null) {
174
+ if (current.text.length > 0) sections.push(current);
175
+ current = { header, text: line };
176
+ } else {
177
+ current.text += line;
178
+ }
179
+ }
180
+ if (current.text.length > 0) sections.push(current);
181
+ return sections;
182
+ }
183
+
184
+ function parseTomlHeader(line) {
185
+ const trimmed = line.trim();
186
+ if (!trimmed.startsWith("[") || !trimmed.endsWith("]")) return null;
187
+ if (trimmed.startsWith("[[")) return null;
188
+ return trimmed.slice(1, -1);
189
+ }
190
+
191
+ function parsePluginHeaderKey(header) {
192
+ const prefix = "plugins.";
193
+ if (!header.startsWith(prefix)) return null;
194
+ return parseLeadingJsonString(header.slice(prefix.length));
195
+ }
196
+
197
+ function parseAgentHeaderName(header) {
198
+ const prefix = "agents.";
199
+ if (!header.startsWith(prefix)) return null;
200
+ const key = header.slice(prefix.length);
201
+ return key.startsWith('"') ? parseLeadingJsonString(key) : key;
202
+ }
203
+
204
+ function parseLeadingJsonString(value) {
205
+ if (!value.startsWith('"')) return parseJsonString(value);
206
+ let escaped = false;
207
+ for (let index = 1; index < value.length; index += 1) {
208
+ const char = value[index];
209
+ if (escaped) {
210
+ escaped = false;
211
+ continue;
212
+ }
213
+ if (char === "\\") {
214
+ escaped = true;
215
+ continue;
216
+ }
217
+ if (char === '"') return parseJsonString(value.slice(0, index + 1));
218
+ }
219
+ return null;
220
+ }
221
+
222
+ function parseJsonString(value) {
223
+ try {
224
+ const parsed = JSON.parse(value);
225
+ return typeof parsed === "string" ? parsed : null;
226
+ } catch {
227
+ return null;
228
+ }
229
+ }
@@ -0,0 +1,84 @@
1
+ import { createHash } from "node:crypto";
2
+ import { readFile } from "node:fs/promises";
3
+ import { join } from "node:path";
4
+
5
+ import { exists, isRecord } from "./utils.mjs";
6
+
7
+ const EVENT_LABELS = new Map([
8
+ ["PreToolUse", "pre_tool_use"],
9
+ ["PermissionRequest", "permission_request"],
10
+ ["PostToolUse", "post_tool_use"],
11
+ ["PreCompact", "pre_compact"],
12
+ ["PostCompact", "post_compact"],
13
+ ["SessionStart", "session_start"],
14
+ ["UserPromptSubmit", "user_prompt_submit"],
15
+ ["SubagentStart", "subagent_start"],
16
+ ["SubagentStop", "subagent_stop"],
17
+ ["Stop", "stop"],
18
+ ]);
19
+
20
+ export async function trustedHookStatesForPlugin({ marketplaceName, pluginName, pluginRoot }) {
21
+ const manifestPath = join(pluginRoot, ".codex-plugin", "plugin.json");
22
+ if (!(await exists(manifestPath))) return [];
23
+ const manifest = JSON.parse(await readFile(manifestPath, "utf8"));
24
+ if (!isRecord(manifest) || typeof manifest.hooks !== "string") return [];
25
+
26
+ const hooksPath = join(pluginRoot, manifest.hooks);
27
+ if (!(await exists(hooksPath))) return [];
28
+ const parsed = JSON.parse(await readFile(hooksPath, "utf8"));
29
+ if (!isRecord(parsed) || !isRecord(parsed.hooks)) return [];
30
+
31
+ const keySource = `${pluginName}@${marketplaceName}:${stripDotSlash(manifest.hooks)}`;
32
+ const states = [];
33
+ for (const [eventName, groups] of Object.entries(parsed.hooks)) {
34
+ if (!Array.isArray(groups)) continue;
35
+ const eventLabel = EVENT_LABELS.get(eventName);
36
+ if (eventLabel === undefined) continue;
37
+ for (const [groupIndex, group] of groups.entries()) {
38
+ if (!isRecord(group) || !Array.isArray(group.hooks)) continue;
39
+ for (const [handlerIndex, handler] of group.hooks.entries()) {
40
+ if (!isRecord(handler) || handler.type !== "command") continue;
41
+ if (handler.async === true) continue;
42
+ if (typeof handler.command !== "string" || handler.command.trim() === "") continue;
43
+ const key = `${keySource}:${eventLabel}:${groupIndex}:${handlerIndex}`;
44
+ states.push({
45
+ key,
46
+ trustedHash: commandHookHash(eventLabel, group.matcher, handler),
47
+ });
48
+ }
49
+ }
50
+ }
51
+ return states;
52
+ }
53
+
54
+ function commandHookHash(eventName, matcher, handler) {
55
+ const command = handler.command;
56
+ const timeout = Math.max(Number(handler.timeout ?? 600), 1);
57
+ const normalizedHandler = {
58
+ type: "command",
59
+ command,
60
+ timeout,
61
+ async: false,
62
+ };
63
+ if (typeof handler.statusMessage === "string") normalizedHandler.statusMessage = handler.statusMessage;
64
+ const identity = {
65
+ event_name: eventName,
66
+ hooks: [normalizedHandler],
67
+ };
68
+ if (typeof matcher === "string") identity.matcher = matcher;
69
+ return `sha256:${createHash("sha256").update(JSON.stringify(canonicalJson(identity))).digest("hex")}`;
70
+ }
71
+
72
+ function canonicalJson(value) {
73
+ if (Array.isArray(value)) return value.map(canonicalJson);
74
+ if (!isRecord(value)) return value;
75
+ const result = {};
76
+ for (const key of Object.keys(value).sort()) {
77
+ result[key] = canonicalJson(value[key]);
78
+ }
79
+ return result;
80
+ }
81
+
82
+ function stripDotSlash(value) {
83
+ return value.startsWith("./") ? value.slice(2) : value;
84
+ }
@@ -0,0 +1,57 @@
1
+ import { lstat, readFile, readlink, rm } from "node:fs/promises";
2
+ import { join } from "node:path";
3
+
4
+ import { COMMAND_SHIM_MARKER } from "./command-shim.mjs";
5
+
6
+ const LEGACY_CODEX_COMPONENT_BINS = [
7
+ { name: "codex-comment-checker", component: "comment-checker" },
8
+ { name: "codex-rules", component: "rules" },
9
+ { name: "codex-start-work-continuation", component: "start-work-continuation" },
10
+ { name: "codex-telemetry", component: "telemetry" },
11
+ { name: "codex-ultrawork", component: "ultrawork" },
12
+ ];
13
+
14
+ export async function removeLegacyCodexComponentBins(binDir, platform) {
15
+ for (const entry of LEGACY_CODEX_COMPONENT_BINS) {
16
+ const linkPath = join(binDir, platform === "win32" ? `${entry.name}.cmd` : entry.name);
17
+ await removeLegacyCodexComponentBin(linkPath, entry.component, platform);
18
+ }
19
+ }
20
+
21
+ async function removeLegacyCodexComponentBin(linkPath, component, platform) {
22
+ try {
23
+ const stat = await lstat(linkPath);
24
+ if (platform !== "win32") {
25
+ if (!stat.isSymbolicLink()) return;
26
+ const target = await readlink(linkPath);
27
+ if (isManagedLegacyComponentTarget(target, component)) await rm(linkPath, { force: true });
28
+ return;
29
+ }
30
+ if (!stat.isFile()) return;
31
+ const content = await readFile(linkPath, "utf8");
32
+ if (content.includes(COMMAND_SHIM_MARKER)) await rm(linkPath, { force: true });
33
+ } catch (error) {
34
+ if (error instanceof Error && "code" in error && error.code === "ENOENT") return;
35
+ throw error;
36
+ }
37
+ }
38
+
39
+ function isManagedLegacyComponentTarget(target, component) {
40
+ const parts = target.split(/[\\/]+/);
41
+ const suffixStart = parts.length - 4;
42
+ const suffix = parts.slice(-4);
43
+ return (
44
+ suffix[0] === "components" &&
45
+ suffix[1] === component &&
46
+ suffix[2] === "dist" &&
47
+ suffix[3] === "cli.js" &&
48
+ hasPluginCachePrefix(parts, suffixStart)
49
+ );
50
+ }
51
+
52
+ function hasPluginCachePrefix(parts, endExclusive) {
53
+ for (let index = 0; index < endExclusive - 1; index += 1) {
54
+ if (parts[index] === "plugins" && parts[index + 1] === "cache") return true;
55
+ }
56
+ return false;
57
+ }
@@ -0,0 +1,104 @@
1
+ import { readFile } from "node:fs/promises";
2
+ import { join } from "node:path";
3
+
4
+ import { isRecord } from "./utils.mjs";
5
+
6
+ const DEFAULT_MARKETPLACE_PATH = "packages/omo-codex/marketplace.json";
7
+
8
+ export async function readMarketplace(repoRoot, options = {}) {
9
+ const marketplacePath = options.marketplacePath ?? join(repoRoot, DEFAULT_MARKETPLACE_PATH);
10
+ const raw = await readFile(marketplacePath, "utf8");
11
+ const parsed = JSON.parse(raw);
12
+ if (!isRecord(parsed)) throw new Error("marketplace.json must be an object");
13
+ if (typeof parsed.name !== "string" || parsed.name.trim() === "") {
14
+ throw new Error("marketplace.json name must be a non-empty string");
15
+ }
16
+ validatePathSegment(parsed.name, "marketplace name");
17
+ if (!Array.isArray(parsed.plugins)) throw new Error("marketplace.json plugins must be an array");
18
+
19
+ return {
20
+ name: parsed.name,
21
+ plugins: parsed.plugins.map((plugin, index) => normalizeMarketplacePlugin(plugin, index)),
22
+ };
23
+ }
24
+
25
+ export function resolvePluginSource(marketplaceRoot, plugin, options = {}) {
26
+ const sourcePath = localSourcePath(options.pathOverride ?? plugin.source);
27
+ const relativePath = sourcePath.slice(2);
28
+ return join(marketplaceRoot, ...relativePath.split(/[\\/]/));
29
+ }
30
+
31
+ export async function readPluginManifest(pluginRoot) {
32
+ const raw = await readFile(join(pluginRoot, ".codex-plugin", "plugin.json"), "utf8");
33
+ const parsed = JSON.parse(raw);
34
+ if (!isRecord(parsed)) throw new Error(`${pluginRoot} plugin.json must be an object`);
35
+ if (typeof parsed.name !== "string" || parsed.name.trim() === "") {
36
+ throw new Error(`${pluginRoot} plugin.json name must be a non-empty string`);
37
+ }
38
+ const manifest = { name: parsed.name };
39
+ if (parsed.version !== undefined) {
40
+ if (typeof parsed.version !== "string" || parsed.version.trim() === "") {
41
+ throw new Error(`${pluginRoot} plugin.json version must be a non-empty string`);
42
+ }
43
+ manifest.version = parsed.version.trim();
44
+ }
45
+ return manifest;
46
+ }
47
+
48
+ export function validatePathSegment(value, label) {
49
+ if (!/^[A-Za-z0-9._+-]+$/.test(value)) {
50
+ throw new Error(`${label} contains unsupported characters: ${value}`);
51
+ }
52
+ if (value === "." || value === "..") {
53
+ throw new Error(`${label} must not be a path traversal segment`);
54
+ }
55
+ }
56
+
57
+ function normalizeMarketplacePlugin(plugin, index) {
58
+ if (!isRecord(plugin)) throw new Error(`marketplace plugin ${index} must be an object`);
59
+ if (typeof plugin.name !== "string" || plugin.name.trim() === "") {
60
+ throw new Error(`marketplace plugin ${index} name must be a non-empty string`);
61
+ }
62
+ validatePathSegment(plugin.name, "plugin name");
63
+ if (plugin.source === undefined || typeof plugin.source === "string") {
64
+ if (typeof plugin.source === "string") validateLocalSourcePath(plugin.source);
65
+ return {
66
+ name: plugin.name,
67
+ source: plugin.source,
68
+ };
69
+ }
70
+ if (isRecord(plugin.source) && plugin.source.source === "local" && typeof plugin.source.path === "string") {
71
+ validateLocalSourcePath(plugin.source.path);
72
+ return {
73
+ name: plugin.name,
74
+ source: { source: "local", path: plugin.source.path },
75
+ };
76
+ }
77
+ throw new Error("local plugin source must be a string path or { source: \"local\", path } object");
78
+ }
79
+
80
+ function localSourcePath(source) {
81
+ if (typeof source === "string") return validateLocalSourcePath(source);
82
+ if (
83
+ isRecord(source) &&
84
+ source.source === "local" &&
85
+ typeof source.path === "string"
86
+ ) {
87
+ return validateLocalSourcePath(source.path);
88
+ }
89
+ throw new Error("local plugin source must be a string path or { source: \"local\", path } object");
90
+ }
91
+
92
+ function validateLocalSourcePath(path) {
93
+ if (!path.startsWith("./")) {
94
+ throw new Error("local plugin source path must start with ./");
95
+ }
96
+ const relative = path.slice(2);
97
+ if (relative.length === 0) throw new Error("local plugin source path must not be empty");
98
+ for (const part of relative.split(/[\\/]/)) {
99
+ if (part === "" || part === "." || part === "..") {
100
+ throw new Error("local plugin source path must stay within the marketplace root");
101
+ }
102
+ }
103
+ return path;
104
+ }
@@ -0,0 +1,77 @@
1
+ import { existsSync } from "node:fs";
2
+ import { cp } from "node:fs/promises";
3
+ import { basename, dirname, isAbsolute, join, relative, resolve } from "node:path";
4
+
5
+ export function createCachedMcpRuntimeArgRewriter({ copyDist = cp } = {}) {
6
+ const copiedDistRoots = new Map();
7
+ return async function rewriteCachedMcpRuntimeArg({ arg, pluginRoot, serverName, sourceRoot }) {
8
+ return rewriteCachedMcpRuntimeArgWithCache({ arg, pluginRoot, serverName, sourceRoot }, { copiedDistRoots, copyDist });
9
+ };
10
+ }
11
+
12
+ export async function rewriteCachedMcpRuntimeArg(args) {
13
+ return createCachedMcpRuntimeArgRewriter()(args);
14
+ }
15
+
16
+ async function rewriteCachedMcpRuntimeArgWithCache({ arg, pluginRoot, serverName, sourceRoot }, { copiedDistRoots, copyDist }) {
17
+ if (typeof arg !== "string" || (!arg.startsWith("./") && !arg.startsWith("../"))) return arg;
18
+ const fallback = resolveCachedRuntimePath(pluginRoot, sourceRoot, arg);
19
+ const targetPath = resolve(pluginRoot, arg);
20
+ const runtimePath = isPathInside(targetPath, pluginRoot) ? targetPath : resolve(sourceRoot, arg);
21
+ const packageRoot = resolveExternalMcpPackageRoot(runtimePath, sourceRoot);
22
+ if (packageRoot === undefined) return fallback;
23
+ const distRoot = join(packageRoot, "dist");
24
+ const distPath = relative(distRoot, runtimePath);
25
+ if (distPath.startsWith("..") || isAbsolute(distPath)) return fallback;
26
+ const cachedRoot = join(pluginRoot, "mcp", safePathSegment(serverName));
27
+ const cacheKey = `${distRoot}\0${cachedRoot}`;
28
+ let copyPromise = copiedDistRoots.get(cacheKey);
29
+ if (copyPromise === undefined) {
30
+ copyPromise = copyDist(distRoot, join(cachedRoot, "dist"), { recursive: true });
31
+ copiedDistRoots.set(cacheKey, copyPromise);
32
+ }
33
+ await copyPromise;
34
+ return join(cachedRoot, "dist", distPath);
35
+ }
36
+
37
+ function resolveExternalMcpPackageRoot(runtimePath, sourceRoot) {
38
+ const packagesRoot = findPackagesRoot(sourceRoot);
39
+ if (packagesRoot === undefined) return undefined;
40
+ if (!isPathInside(runtimePath, packagesRoot)) return undefined;
41
+ let packageRoot = dirname(runtimePath);
42
+ while (packageRoot !== packagesRoot) {
43
+ if (existsSync(join(packageRoot, "package.json")) && isPathInside(runtimePath, join(packageRoot, "dist"))) {
44
+ return packageRoot;
45
+ }
46
+ const parent = dirname(packageRoot);
47
+ if (parent === packageRoot) return undefined;
48
+ packageRoot = parent;
49
+ }
50
+ return undefined;
51
+ }
52
+
53
+ function findPackagesRoot(path) {
54
+ let current = resolve(path);
55
+ for (let index = 0; index < 8; index++) {
56
+ if (basename(current) === "packages") return current;
57
+ const parent = dirname(current);
58
+ if (parent === current) return undefined;
59
+ current = parent;
60
+ }
61
+ return undefined;
62
+ }
63
+
64
+ function resolveCachedRuntimePath(pluginRoot, sourceRoot, runtimePath) {
65
+ const targetPath = resolve(pluginRoot, runtimePath);
66
+ if (isPathInside(targetPath, pluginRoot)) return targetPath;
67
+ return resolve(sourceRoot, runtimePath);
68
+ }
69
+
70
+ function isPathInside(candidatePath, rootPath) {
71
+ const pathFromRoot = relative(rootPath, candidatePath);
72
+ return pathFromRoot === "" || (!pathFromRoot.startsWith("..") && !isAbsolute(pathFromRoot));
73
+ }
74
+
75
+ function safePathSegment(value) {
76
+ return value.replace(/[^A-Za-z0-9._-]/g, "_");
77
+ }
@@ -0,0 +1,32 @@
1
+ import { appendBlock, findTomlSection, removeSetting, replaceOrInsertSetting } from "./toml-editor.mjs";
2
+
3
+ const CODEX_MULTI_AGENT_V2_HEADER = "features.multi_agent_v2";
4
+ const CODEX_MULTI_AGENT_V2_MAX_CONCURRENT_THREADS_PER_SESSION = 10000;
5
+
6
+ export function ensureCodexMultiAgentV2Config(config) {
7
+ const normalizedConfig = removeFeatureFlagSetting(config, "multi_agent_v2");
8
+ const section = findTomlSection(normalizedConfig, CODEX_MULTI_AGENT_V2_HEADER);
9
+ const maxThreadsValue = CODEX_MULTI_AGENT_V2_MAX_CONCURRENT_THREADS_PER_SESSION.toString();
10
+ if (!section) {
11
+ return appendBlock(
12
+ normalizedConfig,
13
+ `[${CODEX_MULTI_AGENT_V2_HEADER}]\nenabled = true\nmax_concurrent_threads_per_session = ${maxThreadsValue}\n`,
14
+ );
15
+ }
16
+
17
+ const enabledConfig = replaceOrInsertSetting(normalizedConfig, section, "enabled", "true");
18
+ const updatedSection = findTomlSection(enabledConfig, CODEX_MULTI_AGENT_V2_HEADER);
19
+ if (!updatedSection) {
20
+ return appendBlock(
21
+ enabledConfig,
22
+ `[${CODEX_MULTI_AGENT_V2_HEADER}]\nenabled = true\nmax_concurrent_threads_per_session = ${maxThreadsValue}\n`,
23
+ );
24
+ }
25
+ return replaceOrInsertSetting(enabledConfig, updatedSection, "max_concurrent_threads_per_session", maxThreadsValue);
26
+ }
27
+
28
+ function removeFeatureFlagSetting(config, featureName) {
29
+ const section = findTomlSection(config, "features");
30
+ if (!section) return config;
31
+ return removeSetting(config, section, featureName);
32
+ }
@@ -0,0 +1,19 @@
1
+ import { spawn } from "node:child_process";
2
+
3
+ export async function defaultRunCommand(command, args, options) {
4
+ await new Promise((resolvePromise, reject) => {
5
+ const child = spawn(command, args, {
6
+ cwd: options.cwd,
7
+ stdio: "inherit",
8
+ });
9
+ child.once("error", reject);
10
+ child.once("exit", (code, signal) => {
11
+ if (code === 0) {
12
+ resolvePromise();
13
+ return;
14
+ }
15
+ const suffix = signal ? `signal ${signal}` : `exit code ${code}`;
16
+ reject(new Error(`${command} ${args.join(" ")} failed in ${options.cwd} with ${suffix}`));
17
+ });
18
+ });
19
+ }
@@ -0,0 +1,54 @@
1
+ import { cp, mkdir, rename, rm, writeFile } from "node:fs/promises";
2
+ import { join, sep } from "node:path";
3
+
4
+ import { rewriteCachedMcpManifest } from "./cache.mjs";
5
+
6
+ const INSTALLED_MARKETPLACES_DIR = ".tmp/marketplaces";
7
+
8
+ export async function writeInstalledMarketplaceSnapshot({ codexHome, marketplace, plugins }) {
9
+ const marketplaceRoot = installedMarketplaceRoot(codexHome, marketplace.name);
10
+ await mkdir(marketplaceRoot, { recursive: true });
11
+ await writeMarketplaceManifest(marketplaceRoot, marketplace);
12
+
13
+ const snapshotPlugins = [];
14
+ for (const plugin of plugins) {
15
+ snapshotPlugins.push(await writeSnapshotPlugin(marketplaceRoot, plugin));
16
+ }
17
+ return snapshotPlugins;
18
+ }
19
+
20
+ export function installedMarketplaceRoot(codexHome, marketplaceName) {
21
+ return join(codexHome, INSTALLED_MARKETPLACES_DIR, marketplaceName);
22
+ }
23
+
24
+ async function writeMarketplaceManifest(marketplaceRoot, marketplace) {
25
+ const manifestDir = join(marketplaceRoot, ".agents", "plugins");
26
+ await mkdir(manifestDir, { recursive: true });
27
+ const tempPath = join(manifestDir, `.marketplace-${process.pid}-${Date.now()}.json.tmp`);
28
+ await writeFile(tempPath, `${JSON.stringify(marketplace, null, "\t")}\n`);
29
+ await rename(tempPath, join(manifestDir, "marketplace.json"));
30
+ }
31
+
32
+ async function writeSnapshotPlugin(marketplaceRoot, plugin) {
33
+ const pluginsDir = join(marketplaceRoot, "plugins");
34
+ await mkdir(pluginsDir, { recursive: true });
35
+ const targetPath = join(pluginsDir, plugin.name);
36
+ const tempPath = join(pluginsDir, `.tmp-${plugin.name}-${process.pid}-${Date.now()}`);
37
+ await rm(tempPath, { recursive: true, force: true });
38
+ await cp(plugin.sourcePath, tempPath, {
39
+ recursive: true,
40
+ filter: (source) => shouldCopyMarketplaceSourcePath(source, plugin.sourcePath),
41
+ });
42
+ await rm(targetPath, { recursive: true, force: true });
43
+ await rename(tempPath, targetPath);
44
+ await rewriteCachedMcpManifest(targetPath, plugin.sourcePath);
45
+ return { name: plugin.name, path: targetPath };
46
+ }
47
+
48
+ function shouldCopyMarketplaceSourcePath(path, root) {
49
+ const relative = path === root ? "" : path.slice(root.length + sep.length);
50
+ if (relative === "") return true;
51
+ const parts = relative.split(sep);
52
+ if (parts[parts.length - 1] === "package-lock.json") return false;
53
+ return !parts.some((part) => part === ".git" || part === "node_modules");
54
+ }