@bohuyeshan/openagent-labforge-core 3.11.5 → 3.13.0

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 (272) hide show
  1. package/README.ja.md +130 -343
  2. package/README.ko.md +128 -337
  3. package/README.md +229 -584
  4. package/README.ru.md +131 -364
  5. package/README.zh-cn.md +231 -547
  6. package/bin/openagent-labforge.js +95 -9
  7. package/bin/platform.test.ts +20 -21
  8. package/dist/agents/article-writer.d.ts +7 -0
  9. package/dist/agents/atlas/default.d.ts +1 -1
  10. package/dist/agents/atlas/gemini.d.ts +1 -1
  11. package/dist/agents/atlas/gpt.d.ts +1 -1
  12. package/dist/agents/bio-methodologist.d.ts +1 -1
  13. package/dist/agents/bio-orchestrator.d.ts +7 -0
  14. package/dist/agents/bio-skill-guidance.d.ts +1 -0
  15. package/dist/agents/builtin-agents/general-agents.d.ts +0 -1
  16. package/dist/agents/builtin-agents/sisyphus-agent.d.ts +16 -0
  17. package/dist/agents/dynamic-agent-prompt-builder.d.ts +0 -2
  18. package/dist/agents/engineering-capability.d.ts +7 -0
  19. package/dist/agents/env-context.d.ts +1 -1
  20. package/dist/agents/github-scout.d.ts +7 -0
  21. package/dist/agents/index.d.ts +0 -1
  22. package/dist/agents/metis.d.ts +1 -1
  23. package/dist/agents/momus.d.ts +1 -1
  24. package/dist/agents/prometheus/behavioral-summary.d.ts +1 -1
  25. package/dist/agents/prometheus/gemini.d.ts +1 -1
  26. package/dist/agents/prometheus/gpt.d.ts +1 -1
  27. package/dist/agents/prometheus/interview-mode.d.ts +1 -1
  28. package/dist/agents/prometheus/plan-generation.d.ts +1 -1
  29. package/dist/agents/prometheus/plan-template.d.ts +1 -1
  30. package/dist/agents/prometheus/system-prompt.d.ts +1 -1
  31. package/dist/agents/scientific-writer.d.ts +7 -0
  32. package/dist/agents/sisyphus-junior/gpt-5-3-codex.d.ts +1 -1
  33. package/dist/agents/sisyphus-junior/gpt-5-4.d.ts +1 -1
  34. package/dist/agents/sisyphus-junior/gpt.d.ts +1 -1
  35. package/dist/agents/tech-scout.d.ts +7 -0
  36. package/dist/agents/types.d.ts +1 -1
  37. package/dist/agents/wase.d.ts +8 -0
  38. package/dist/agents/wet-lab-designer.d.ts +7 -0
  39. package/dist/agents/writing-style-rules.d.ts +1 -0
  40. package/dist/cli/config-manager/bun-install.d.ts +1 -6
  41. package/dist/cli/config-manager/cleanup-managed-mcp-from-opencode-config.d.ts +2 -0
  42. package/dist/cli/config-manager/cleanup-stale-managed-agents.d.ts +2 -0
  43. package/dist/cli/config-manager/parse-opencode-config-file.d.ts +2 -0
  44. package/dist/cli/config-manager/plugin-name-with-version.d.ts +1 -1
  45. package/dist/cli/config-manager/sync-static-agent-to-opencode-config.d.ts +2 -0
  46. package/dist/cli/config-manager/sync-static-mcp-to-opencode-config.d.ts +2 -0
  47. package/dist/cli/config-manager/write-bootstrap-skill.d.ts +15 -0
  48. package/dist/cli/config-manager.d.ts +5 -0
  49. package/dist/cli/index.js +24986 -15362
  50. package/dist/cli/install-validators.d.ts +0 -1
  51. package/dist/cli/model-fallback-types.d.ts +0 -1
  52. package/dist/cli/run/index.d.ts +0 -1
  53. package/dist/cli/run/types.d.ts +0 -1
  54. package/dist/cli/types.d.ts +0 -3
  55. package/dist/config/schema/agent-names.d.ts +36 -3
  56. package/dist/config/schema/agent-overrides.d.ts +504 -0
  57. package/dist/config/schema/background-task.d.ts +0 -2
  58. package/dist/config/schema/experimental.d.ts +5 -0
  59. package/dist/config/schema/git-master.d.ts +0 -1
  60. package/dist/config/schema/hooks.d.ts +0 -2
  61. package/dist/config/schema/mcp-policy.d.ts +1 -0
  62. package/dist/config/schema/oh-my-opencode-config.d.ts +526 -54
  63. package/dist/config/schema.d.ts +0 -1
  64. package/dist/create-hooks.d.ts +0 -13
  65. package/dist/features/background-agent/compaction-aware-message-resolver.d.ts +1 -16
  66. package/dist/features/background-agent/constants.d.ts +2 -1
  67. package/dist/features/background-agent/manager.d.ts +5 -20
  68. package/dist/features/background-agent/process-cleanup.d.ts +1 -1
  69. package/dist/features/background-agent/task-history.d.ts +0 -1
  70. package/dist/features/background-agent/task-poller.d.ts +0 -1
  71. package/dist/features/background-agent/types.d.ts +0 -4
  72. package/dist/features/builtin-commands/commands.d.ts +4 -1
  73. package/dist/features/builtin-skills/skills/bio-methods.d.ts +2 -0
  74. package/dist/features/builtin-skills/skills/bio-pipeline.d.ts +2 -0
  75. package/dist/features/builtin-skills/skills/bio-tools.d.ts +2 -0
  76. package/dist/features/builtin-skills/skills/bio-visualization.d.ts +2 -0
  77. package/dist/features/builtin-skills/skills/cell-annotation.d.ts +2 -0
  78. package/dist/features/builtin-skills/skills/differential-expression.d.ts +2 -0
  79. package/dist/features/builtin-skills/skills/geo-query.d.ts +2 -0
  80. package/dist/features/builtin-skills/skills/index.d.ts +14 -0
  81. package/dist/features/builtin-skills/skills/paper-evidence.d.ts +2 -0
  82. package/dist/features/builtin-skills/skills/pubmed-search.d.ts +2 -0
  83. package/dist/features/builtin-skills/skills/scrna-preprocessing.d.ts +2 -0
  84. package/dist/features/builtin-skills/skills/sequence-analysis.d.ts +2 -0
  85. package/dist/features/builtin-skills/skills/structural-biology.d.ts +2 -0
  86. package/dist/features/builtin-skills/skills/vector-design.d.ts +2 -0
  87. package/dist/features/builtin-skills/skills/wet-lab-design.d.ts +2 -0
  88. package/dist/features/claude-code-agent-loader/loader.d.ts +3 -3
  89. package/dist/features/claude-code-agent-loader/types.d.ts +1 -8
  90. package/dist/features/claude-code-mcp-loader/configure-allowed-env-vars.d.ts +5 -0
  91. package/dist/features/claude-code-mcp-loader/index.d.ts +1 -0
  92. package/dist/features/claude-code-mcp-loader/types.d.ts +3 -0
  93. package/dist/features/claude-code-plugin-loader/agent-loader.d.ts +2 -2
  94. package/dist/features/claude-code-plugin-loader/loader.d.ts +2 -2
  95. package/dist/features/claude-code-plugin-loader/types.d.ts +1 -1
  96. package/dist/features/claude-code-session-state/state.d.ts +5 -0
  97. package/dist/features/opencode-skill-loader/git-master-template-injection.d.ts +1 -1
  98. package/dist/features/opencode-skill-loader/project-skill-directory-discovery.d.ts +1 -0
  99. package/dist/features/opencode-skill-loader/skill-metadata-validator.d.ts +8 -0
  100. package/dist/features/skill-mcp-manager/types.d.ts +0 -4
  101. package/dist/features/tmux-subagent/index.d.ts +0 -1
  102. package/dist/features/tmux-subagent/manager.d.ts +0 -5
  103. package/dist/features/tmux-subagent/types.d.ts +0 -2
  104. package/dist/hooks/atlas/tool-execute-after.d.ts +0 -2
  105. package/dist/hooks/atlas/types.d.ts +0 -2
  106. package/dist/hooks/atlas/verification-reminders.d.ts +0 -4
  107. package/dist/hooks/auto-slash-command/hook.d.ts +0 -7
  108. package/dist/hooks/auto-update-checker/checker.d.ts +1 -3
  109. package/dist/hooks/auto-update-checker/constants.d.ts +2 -2
  110. package/dist/hooks/comment-checker/downloader.d.ts +1 -1
  111. package/dist/hooks/compaction-context-injector/hook.d.ts +1 -5
  112. package/dist/hooks/context-window-monitor.d.ts +5 -2
  113. package/dist/hooks/index.d.ts +0 -2
  114. package/dist/hooks/keyword-detector/detector.d.ts +1 -1
  115. package/dist/hooks/keyword-detector/hook.d.ts +2 -2
  116. package/dist/hooks/keyword-detector/index.d.ts +1 -0
  117. package/dist/hooks/keyword-detector/semantic-hint.d.ts +4 -0
  118. package/dist/hooks/keyword-detector/ultrawork/autonomous.d.ts +8 -0
  119. package/dist/hooks/preemptive-compaction.d.ts +5 -2
  120. package/dist/hooks/runtime-fallback/hook.d.ts +3 -2
  121. package/dist/hooks/runtime-fallback/message-update-handler.d.ts +2 -1
  122. package/dist/hooks/runtime-fallback/types.d.ts +3 -56
  123. package/dist/hooks/session-notification-scheduler.d.ts +3 -5
  124. package/dist/hooks/session-notification.d.ts +0 -2
  125. package/dist/hooks/session-recovery/tool-pairing.d.ts +16 -0
  126. package/dist/hooks/start-work/index.d.ts +1 -1
  127. package/dist/hooks/start-work/worktree-detector.d.ts +0 -7
  128. package/dist/hooks/todo-continuation-enforcer/compaction-guard.d.ts +4 -0
  129. package/dist/hooks/todo-continuation-enforcer/constants.d.ts +6 -5
  130. package/dist/hooks/todo-continuation-enforcer/handler.d.ts +0 -1
  131. package/dist/hooks/todo-continuation-enforcer/idle-event.d.ts +0 -1
  132. package/dist/hooks/todo-continuation-enforcer/resolve-message-info.d.ts +3 -0
  133. package/dist/hooks/todo-continuation-enforcer/session-state.d.ts +1 -1
  134. package/dist/hooks/todo-continuation-enforcer/types.d.ts +8 -3
  135. package/dist/hooks/tool-output-truncator.d.ts +0 -1
  136. package/dist/index.js +56627 -56933
  137. package/dist/mcp/extended.d.ts +4 -2
  138. package/dist/mcp/index.d.ts +2 -1
  139. package/dist/mcp/types.d.ts +2 -3
  140. package/dist/openagent-labforge.schema.json +1362 -83
  141. package/dist/plugin/hooks/create-continuation-hooks.d.ts +1 -2
  142. package/dist/plugin/hooks/create-core-hooks.d.ts +0 -1
  143. package/dist/plugin/hooks/create-session-hooks.d.ts +1 -2
  144. package/dist/plugin/ultrawork-model-override.d.ts +11 -1
  145. package/dist/plugin-dispose.d.ts +12 -10
  146. package/dist/plugin-handlers/agent-config-handler.d.ts +0 -1
  147. package/dist/plugin-handlers/prometheus-agent-config-builder.d.ts +1 -1
  148. package/dist/plugin-state.d.ts +0 -5
  149. package/dist/shared/agent-display-names.d.ts +1 -0
  150. package/dist/shared/data-path.d.ts +1 -1
  151. package/dist/shared/dynamic-truncator.d.ts +7 -4
  152. package/dist/shared/external-plugin-detector.d.ts +7 -0
  153. package/dist/shared/index.d.ts +5 -3
  154. package/dist/shared/jsonc-parser.d.ts +4 -0
  155. package/dist/shared/mcp-local-command-normalizer.d.ts +1 -0
  156. package/dist/shared/migrate-legacy-config-file.d.ts +1 -0
  157. package/dist/shared/model-error-classifier.d.ts +1 -2
  158. package/dist/shared/opencode-command-dirs.d.ts +0 -1
  159. package/dist/shared/plugin-identity.d.ts +2 -3
  160. package/dist/shared/project-discovery-dirs.d.ts +4 -0
  161. package/dist/shared/session-model-state.d.ts +1 -2
  162. package/dist/shared/system-directive.d.ts +5 -6
  163. package/dist/tools/call-omo-agent/background-executor.d.ts +1 -2
  164. package/dist/tools/call-omo-agent/constants.d.ts +2 -2
  165. package/dist/tools/call-omo-agent/sync-executor.d.ts +3 -11
  166. package/dist/tools/call-omo-agent/tools.d.ts +2 -2
  167. package/dist/tools/call-omo-agent/types.d.ts +13 -0
  168. package/dist/tools/delegate-task/constants.d.ts +1 -1
  169. package/dist/tools/delegate-task/model-selection.d.ts +0 -1
  170. package/dist/tools/delegate-task/model-string-parser.d.ts +3 -1
  171. package/dist/tools/delegate-task/parent-context-resolver.d.ts +22 -0
  172. package/dist/tools/lsp/constants.d.ts +0 -1
  173. package/dist/tools/lsp/lsp-client-transport.d.ts +2 -4
  174. package/dist/tools/lsp/lsp-client-wrapper.d.ts +1 -2
  175. package/generated/skills-bundles/catalog.json +1 -1
  176. package/generated/skills-bundles/full/skills/data-analysis/experiment-monitoring/auto-claude__monitor-experiment/SKILL.md +56 -55
  177. package/generated/skills-bundles/full/skills/data-analysis/experiment-ops/auto-claude__run-experiment/SKILL.md +105 -104
  178. package/generated/skills-bundles/full/skills/data-analysis/optimization/auto-claude__dse-loop/SKILL.md +272 -271
  179. package/generated/skills-bundles/full/skills/data-analysis/statistics/auto-claude__analyze-results/SKILL.md +40 -39
  180. package/generated/skills-bundles/full/skills/data-analysis/visualization/auto-claude__paper-figure/SKILL.md +274 -273
  181. package/generated/skills-bundles/full/skills/productivity/visual-design/auto-claude__pixel-art/SKILL.md +131 -130
  182. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-compile/SKILL.md +245 -244
  183. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-plan/SKILL.md +247 -246
  184. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-write/SKILL.md +303 -302
  185. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-write/templates/iclr2026.tex +84 -84
  186. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-write/templates/icml2025.tex +87 -87
  187. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-write/templates/math_commands.tex +48 -48
  188. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-write/templates/neurips2025.tex +80 -80
  189. package/generated/skills-bundles/full/skills/research/document-authoring/auto-claude__paper-writing/SKILL.md +31 -31
  190. package/generated/skills-bundles/full/skills/research/literature-and-web-search/auto-claude__arxiv/SKILL.md +126 -125
  191. package/generated/skills-bundles/full/skills/research/literature-and-web-search/auto-claude__novelty-check/SKILL.md +80 -79
  192. package/generated/skills-bundles/full/skills/research/literature-and-web-search/auto-claude__research-lit/SKILL.md +187 -186
  193. package/generated/skills-bundles/full/skills/research/research-ideation/auto-claude__idea-creator/SKILL.md +11 -11
  194. package/generated/skills-bundles/full/skills/research/research-ideation/auto-claude__idea-discovery/SKILL.md +18 -18
  195. package/generated/skills-bundles/full/skills/research/research-ideation/auto-claude__idea-discovery-robot/SKILL.md +20 -20
  196. package/generated/skills-bundles/full/skills/research/research-ideation/auto-claude__research-pipeline/SKILL.md +15 -15
  197. package/generated/skills-bundles/full/skills/research/theory-writing/auto-claude__proof-writer/SKILL.md +217 -216
  198. package/generated/skills-bundles/paper/skills/data-analysis/experiment-monitoring/auto-claude__monitor-experiment/SKILL.md +56 -55
  199. package/generated/skills-bundles/paper/skills/data-analysis/experiment-ops/auto-claude__run-experiment/SKILL.md +105 -104
  200. package/generated/skills-bundles/paper/skills/data-analysis/optimization/auto-claude__dse-loop/SKILL.md +272 -271
  201. package/generated/skills-bundles/paper/skills/data-analysis/statistics/auto-claude__analyze-results/SKILL.md +40 -39
  202. package/generated/skills-bundles/paper/skills/data-analysis/visualization/auto-claude__paper-figure/SKILL.md +274 -273
  203. package/generated/skills-bundles/paper/skills/productivity/visual-design/auto-claude__pixel-art/SKILL.md +131 -130
  204. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-compile/SKILL.md +245 -244
  205. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-plan/SKILL.md +247 -246
  206. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-write/SKILL.md +303 -302
  207. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-write/templates/iclr2026.tex +84 -84
  208. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-write/templates/icml2025.tex +87 -87
  209. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-write/templates/math_commands.tex +48 -48
  210. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-write/templates/neurips2025.tex +80 -80
  211. package/generated/skills-bundles/paper/skills/research/document-authoring/auto-claude__paper-writing/SKILL.md +31 -31
  212. package/generated/skills-bundles/paper/skills/research/literature-and-web-search/auto-claude__arxiv/SKILL.md +126 -125
  213. package/generated/skills-bundles/paper/skills/research/literature-and-web-search/auto-claude__novelty-check/SKILL.md +80 -79
  214. package/generated/skills-bundles/paper/skills/research/literature-and-web-search/auto-claude__research-lit/SKILL.md +187 -186
  215. package/generated/skills-bundles/paper/skills/research/research-ideation/auto-claude__idea-creator/SKILL.md +11 -11
  216. package/generated/skills-bundles/paper/skills/research/research-ideation/auto-claude__idea-discovery/SKILL.md +18 -18
  217. package/generated/skills-bundles/paper/skills/research/research-ideation/auto-claude__idea-discovery-robot/SKILL.md +20 -20
  218. package/generated/skills-bundles/paper/skills/research/research-ideation/auto-claude__research-pipeline/SKILL.md +15 -15
  219. package/generated/skills-bundles/paper/skills/research/theory-writing/auto-claude__proof-writer/SKILL.md +217 -216
  220. package/package.json +36 -32
  221. package/dist/cli/openai-only-model-catalog.d.ts +0 -3
  222. package/dist/cli/run/model-resolver.d.ts +0 -4
  223. package/dist/config/schema/git-env-prefix.d.ts +0 -5
  224. package/dist/features/background-agent/remove-task-toast-tracking.d.ts +0 -1
  225. package/dist/features/background-agent/subagent-spawn-limits.d.ts +0 -23
  226. package/dist/features/claude-code-agent-loader/claude-model-mapper.d.ts +0 -4
  227. package/dist/features/tmux-subagent/pane-state-parser.d.ts +0 -8
  228. package/dist/features/tmux-subagent/tracked-session-state.d.ts +0 -8
  229. package/dist/hooks/atlas/boulder-session-lineage.d.ts +0 -6
  230. package/dist/hooks/atlas/final-wave-approval-gate.d.ts +0 -4
  231. package/dist/hooks/atlas/idle-event.d.ts +0 -8
  232. package/dist/hooks/atlas/resolve-active-boulder-session.d.ts +0 -11
  233. package/dist/hooks/auto-slash-command/processed-command-store.d.ts +0 -7
  234. package/dist/hooks/auto-update-checker/checker/sync-package-json.d.ts +0 -7
  235. package/dist/hooks/compaction-context-injector/compaction-context-prompt.d.ts +0 -1
  236. package/dist/hooks/compaction-context-injector/constants.d.ts +0 -5
  237. package/dist/hooks/compaction-context-injector/recovery-prompt-config.d.ts +0 -6
  238. package/dist/hooks/compaction-context-injector/recovery.d.ts +0 -6
  239. package/dist/hooks/compaction-context-injector/session-id.d.ts +0 -2
  240. package/dist/hooks/compaction-context-injector/session-prompt-config-resolver.d.ts +0 -16
  241. package/dist/hooks/compaction-context-injector/tail-monitor.d.ts +0 -13
  242. package/dist/hooks/compaction-context-injector/types.d.ts +0 -43
  243. package/dist/hooks/compaction-context-injector/validated-model.d.ts +0 -13
  244. package/dist/hooks/delegate-task-english-directive/hook.d.ts +0 -14
  245. package/dist/hooks/delegate-task-english-directive/index.d.ts +0 -1
  246. package/dist/hooks/gpt-permission-continuation/assistant-message.d.ts +0 -23
  247. package/dist/hooks/gpt-permission-continuation/constants.d.ts +0 -4
  248. package/dist/hooks/gpt-permission-continuation/detector.d.ts +0 -1
  249. package/dist/hooks/gpt-permission-continuation/handler.d.ts +0 -12
  250. package/dist/hooks/gpt-permission-continuation/index.d.ts +0 -13
  251. package/dist/hooks/gpt-permission-continuation/session-state.d.ts +0 -15
  252. package/dist/hooks/ralph-loop/pending-verification-handler.d.ts +0 -16
  253. package/dist/hooks/runtime-fallback/fallback-bootstrap-model.d.ts +0 -10
  254. package/dist/hooks/runtime-fallback/fallback-retry-dispatcher.d.ts +0 -11
  255. package/dist/hooks/runtime-fallback/last-user-retry-parts.d.ts +0 -4
  256. package/dist/hooks/runtime-fallback/retry-model-payload.d.ts +0 -7
  257. package/dist/hooks/runtime-fallback/session-messages.d.ts +0 -9
  258. package/dist/hooks/runtime-fallback/session-status-handler.d.ts +0 -3
  259. package/dist/hooks/runtime-fallback/visible-assistant-response.d.ts +0 -3
  260. package/dist/hooks/session-notification-content.d.ts +0 -30
  261. package/dist/plugin/normalize-tool-arg-schemas.d.ts +0 -2
  262. package/dist/plugin/ultrawork-variant-availability.d.ts +0 -6
  263. package/dist/shared/compaction-agent-config-checkpoint.d.ts +0 -11
  264. package/dist/shared/context-limit-resolver.d.ts +0 -5
  265. package/dist/shared/fallback-chain-from-models.d.ts +0 -3
  266. package/dist/shared/question-denied-session-permission.d.ts +0 -6
  267. package/dist/shared/retry-status-utils.d.ts +0 -2
  268. package/dist/shared/vision-capable-models-cache.d.ts +0 -4
  269. package/dist/tools/delegate-task/cancel-unstable-agent-task.d.ts +0 -2
  270. package/dist/tools/look-at/multimodal-fallback-chain.d.ts +0 -4
  271. package/dist/tools/lsp/directory-diagnostics.d.ts +0 -1
  272. package/dist/tools/lsp/server-path-bases.d.ts +0 -1
@@ -13,22 +13,22 @@ Orchestrate a complete paper writing workflow for: **$ARGUMENTS**
13
13
 
14
14
  ## Overview
15
15
 
16
- This skill chains five sub-skills into a single automated pipeline:
17
-
18
- ```
19
- /paper-plan → /paper-figure → /paper-write → /paper-compile → /ulw-loop
20
- (outline) (plots) (LaTeX) (build PDF) (final QA + Oracle verify)
21
- ```
16
+ This skill chains five sub-skills into a single automated pipeline:
17
+
18
+ ```
19
+ /paper-plan → /paper-figure → /paper-write → /paper-compile → /ulw-loop
20
+ (outline) (plots) (LaTeX) (build PDF) (final QA + Oracle verify)
21
+ ```
22
22
 
23
23
  Each phase builds on the previous one's output. The final deliverable is a polished, reviewed `paper/` directory with LaTeX source and compiled PDF.
24
24
 
25
25
  ## Constants
26
26
 
27
27
  - **VENUE = `ICLR`** — Target venue. Options: `ICLR`, `NeurIPS`, `ICML`. Affects style file, page limit, citation format.
28
- - **REVIEWER_MODEL = `gpt-5.4`** — Model used via Codex MCP for plan review, figure review, and writing review.
29
- - **AUTO_PROCEED = true** — Auto-continue between phases. Set `false` to pause and wait for user approval after each phase.
30
-
31
- > Override inline: `/paper-writing "NARRATIVE_REPORT.md" — venue: NeurIPS`
28
+ - **REVIEWER_MODEL = `gpt-5.4`** — Model used via Codex MCP for plan review, figure review, and writing review.
29
+ - **AUTO_PROCEED = true** — Auto-continue between phases. Set `false` to pause and wait for user approval after each phase.
30
+
31
+ > Override inline: `/paper-writing "NARRATIVE_REPORT.md" — venue: NeurIPS`
32
32
 
33
33
  ## Inputs
34
34
 
@@ -164,25 +164,25 @@ Invoke `/paper-compile` to build the PDF:
164
164
  - Undefined references: 0
165
165
  - Undefined citations: 0
166
166
 
167
- Shall I proceed with the ULTRAWORK final QA?
168
- ```
169
-
170
- ### Phase 5: ULTRAWORK Final QA
171
-
172
- Invoke `/ulw-loop` to do a final evidence-based QA pass:
173
-
174
- ```
175
- /ulw-loop "Final QA for paper/: verify claims vs figures, references, and compile output" --max-iterations=2
176
- ```
177
-
178
- **What this does (recommend 1-2 rounds):**
179
-
180
- - Verify claims vs figures and tables
181
- - Check references, citations, and build artifacts
182
- - Fix inconsistencies, missing evidence, and presentation gaps
183
- - Oracle verifies completion; if not verified, iterate
184
-
185
- **Output:** `paper/main.pdf` plus a `ULTRAWORK_LOG.md` describing evidence and fixes.
167
+ Shall I proceed with the ULTRAWORK final QA?
168
+ ```
169
+
170
+ ### Phase 5: ULTRAWORK Final QA
171
+
172
+ Invoke `/ulw-loop` to do a final evidence-based QA pass:
173
+
174
+ ```
175
+ /ulw-loop "Final QA for paper/: verify claims vs figures, references, and compile output" --max-iterations=2
176
+ ```
177
+
178
+ **What this does (recommend 1-2 rounds):**
179
+
180
+ - Verify claims vs figures and tables
181
+ - Check references, citations, and build artifacts
182
+ - Fix inconsistencies, missing evidence, and presentation gaps
183
+ - Oracle verifies completion; if not verified, iterate
184
+
185
+ **Output:** `paper/main.pdf` plus a `ULTRAWORK_LOG.md` describing evidence and fixes.
186
186
 
187
187
  **Format check** (included in improvement loop Step 8): After final recompilation, auto-detect and fix overfull hboxes (content exceeding margins), verify page count vs venue limit, and ensure compact formatting. Any overfull > 10pt is fixed before generating the final PDF.
188
188
 
@@ -203,11 +203,11 @@ Invoke `/ulw-loop` to do a final evidence-based QA pass:
203
203
  | 2. Figures | ✅ | figures/ ([N] auto + [M] manual) |
204
204
  | 3. LaTeX Writing | ✅ | paper/sections/*.tex ([N] sections, [M] citations) |
205
205
  | 4. Compilation | ✅ | paper/main.pdf ([X] pages) |
206
- | 5. ULTRAWORK QA | ✅ | ULTRAWORK_LOG.md |
206
+ | 5. ULTRAWORK QA | ✅ | ULTRAWORK_LOG.md |
207
207
 
208
208
  ## Deliverables
209
209
  - paper/main.pdf — Final polished paper
210
- - paper/ULTRAWORK_LOG.md — QA log with evidence and fixes
210
+ - paper/ULTRAWORK_LOG.md — QA log with evidence and fixes
211
211
 
212
212
  ## Remaining Issues (if any)
213
213
  - [items from final review that weren't addressed]
@@ -6,128 +6,129 @@ allowed-tools: "Read, Write"
6
6
  metadata:
7
7
  category: "research/literature-and-web-search"
8
8
  ---
9
- # arXiv Paper Search & Download
10
-
11
- Search topic or arXiv paper ID: $ARGUMENTS
12
-
13
- ## Constants
14
-
15
- - **PAPER_DIR** - Local directory to save downloaded PDFs. Default: `papers/` in the current project directory.
16
- - **MAX_RESULTS = 10** - Default number of search results.
17
-
18
- > Overrides (append to arguments):
19
- > - `/arxiv "attention mechanism" - max: 20` - return up to 20 results
20
- > - `/arxiv "2301.07041" - download` - download a specific paper by ID
21
- > - `/arxiv "query" - dir: literature/` - save PDFs to a custom directory
22
- > - `/arxiv "query" - download: all` - download all result PDFs
23
-
24
- ## MCP Requirement (No Script Fallback)
25
-
26
- This skill uses MCP only. Ensure at least one of these is enabled:
27
-
28
- - `paper_search_mcp` (preferred, multi-source)
29
- - `arxiv_mcp` (arXiv-only)
30
-
31
- If MCP tools are missing, enable them in config:
32
-
33
- ```json
34
- {
35
- "mcp_policy": {
36
- "enable": ["paper_search_mcp", "arxiv_mcp"]
37
- }
38
- }
39
- ```
40
-
41
- ## Workflow
42
-
43
- ### Step 1: Parse Arguments
44
-
45
- Parse `$ARGUMENTS` for directives:
46
-
47
- - **Query or ID**: main search term or a bare arXiv ID such as `2301.07041` or `cs/0601001`
48
- - **`- max: N`**: override MAX_RESULTS (e.g., `- max: 20`)
49
- - **`- dir: PATH`**: override PAPER_DIR (e.g., `- dir: literature/`)
50
- - **`- download`**: download the first result's PDF after listing
51
- - **`- download: all`**: download PDFs for all results
52
-
53
- If the argument matches an arXiv ID pattern (`YYMM.NNNNN` or `category/NNNNNNN`), skip the search and go directly to Step 3.
54
-
55
- ### Step 2: Search arXiv (MCP)
56
-
57
- Use MCP tools to search:
58
-
59
- - Prefer `paper_search_mcp` if available (multi-source).
60
- - Otherwise use `arxiv_mcp` (arXiv-only).
61
-
62
- Call the search tool exposed by the MCP server (the exact tool name appears in your MCP tool list). Pass the query and `MAX_RESULTS`.
63
-
64
- Present results as a table:
65
-
66
- ```text
67
- | # | arXiv ID | Title | Authors | Date | Category |
68
- |---|------------|---------------------|----------------|------------|----------|
69
- | 1 | 2301.07041 | Attention Is All... | Vaswani et al. | 2017-06-12 | cs.LG |
70
- ```
71
-
72
- ### Step 3: Fetch Details for a Specific ID (MCP)
73
-
74
- Use the MCP server's fetch/details tool (if provided) to retrieve metadata for a specific arXiv ID.
75
-
76
- Display: title, all authors, categories, full abstract, published date, PDF URL, abstract URL.
77
-
78
- ### Step 4: Download PDFs (MCP)
79
-
80
- When download is requested:
81
-
82
- - Use MCP download/fetch tool if available.
83
- - If the MCP server only returns URLs, create the directory and save the URL list so the user can fetch later.
84
-
85
- If a local file path is returned:
86
-
87
- - Confirm file size > 10 KB (reject smaller files - likely an error HTML page)
88
- - Add a 1-second delay between consecutive downloads to avoid rate limiting
89
- - Report: `Downloaded: papers/2301.07041.pdf (842 KB)`
90
-
91
- ### Step 5: Summarize
92
-
93
- For each paper (downloaded or fetched by API):
94
-
95
- ```markdown
96
- ## [Title]
97
-
98
- - **arXiv**: [ID] - [abs_url]
99
- - **Authors**: [full author list]
100
- - **Date**: [published]
101
- - **Categories**: [cs.LG, cs.AI, ...]
102
- - **Abstract**: [full abstract]
103
- - **Key contributions** (extracted from abstract):
104
- - [contribution 1]
105
- - [contribution 2]
106
- - [contribution 3]
107
- - **Local PDF**: papers/[ID].pdf (if downloaded)
108
- ```
109
-
110
- ### Step 6: Final Output
111
-
112
- Summarize what was done:
113
-
114
- - `Found N papers for "query"`
115
- - `Downloaded: papers/2301.07041.pdf (842 KB)` (for each download)
116
- - Any warnings (rate limit hit, file too small, already exists)
117
-
118
- Suggest follow-up skills:
119
-
120
- ```text
121
- /research-lit "topic" - multi-source review: Zotero + Obsidian + local PDFs + web
122
- /novelty-check "idea" - verify your idea is novel against these papers
123
- ```
124
-
125
- ## Key Rules
126
-
127
- - Always show the arXiv ID prominently - users need it for citations and reproducibility
128
- - Verify downloaded PDFs: file must be > 10 KB; warn and delete if smaller
129
- - Rate limit: wait 1 second between consecutive PDF downloads; retry once after 5 seconds on HTTP 429
130
- - Never overwrite an existing PDF at the same path - skip it and report "already exists"
131
- - Handle both arXiv ID formats: new (`2301.07041`) and old (`cs/0601001`)
132
- - PAPER_DIR is created automatically if it does not exist
133
- - If the arXiv API is unreachable, report the error clearly and suggest using `/research-lit` with `- sources: web` as a fallback
9
+
10
+ # arXiv Paper Search & Download
11
+
12
+ Search topic or arXiv paper ID: $ARGUMENTS
13
+
14
+ ## Constants
15
+
16
+ - **PAPER_DIR** - Local directory to save downloaded PDFs. Default: `papers/` in the current project directory.
17
+ - **MAX_RESULTS = 10** - Default number of search results.
18
+
19
+ > Overrides (append to arguments):
20
+ > - `/arxiv "attention mechanism" - max: 20` - return up to 20 results
21
+ > - `/arxiv "2301.07041" - download` - download a specific paper by ID
22
+ > - `/arxiv "query" - dir: literature/` - save PDFs to a custom directory
23
+ > - `/arxiv "query" - download: all` - download all result PDFs
24
+
25
+ ## MCP Requirement (No Script Fallback)
26
+
27
+ This skill uses MCP only. Ensure at least one of these is enabled:
28
+
29
+ - `paper_search_mcp` (preferred, multi-source)
30
+ - `arxiv_mcp` (arXiv-only)
31
+
32
+ If MCP tools are missing, enable them in config:
33
+
34
+ ```json
35
+ {
36
+ "mcp_policy": {
37
+ "enable": ["paper_search_mcp", "arxiv_mcp"]
38
+ }
39
+ }
40
+ ```
41
+
42
+ ## Workflow
43
+
44
+ ### Step 1: Parse Arguments
45
+
46
+ Parse `$ARGUMENTS` for directives:
47
+
48
+ - **Query or ID**: main search term or a bare arXiv ID such as `2301.07041` or `cs/0601001`
49
+ - **`- max: N`**: override MAX_RESULTS (e.g., `- max: 20`)
50
+ - **`- dir: PATH`**: override PAPER_DIR (e.g., `- dir: literature/`)
51
+ - **`- download`**: download the first result's PDF after listing
52
+ - **`- download: all`**: download PDFs for all results
53
+
54
+ If the argument matches an arXiv ID pattern (`YYMM.NNNNN` or `category/NNNNNNN`), skip the search and go directly to Step 3.
55
+
56
+ ### Step 2: Search arXiv (MCP)
57
+
58
+ Use MCP tools to search:
59
+
60
+ - Prefer `paper_search_mcp` if available (multi-source).
61
+ - Otherwise use `arxiv_mcp` (arXiv-only).
62
+
63
+ Call the search tool exposed by the MCP server (the exact tool name appears in your MCP tool list). Pass the query and `MAX_RESULTS`.
64
+
65
+ Present results as a table:
66
+
67
+ ```text
68
+ | # | arXiv ID | Title | Authors | Date | Category |
69
+ |---|------------|---------------------|----------------|------------|----------|
70
+ | 1 | 2301.07041 | Attention Is All... | Vaswani et al. | 2017-06-12 | cs.LG |
71
+ ```
72
+
73
+ ### Step 3: Fetch Details for a Specific ID (MCP)
74
+
75
+ Use the MCP server's fetch/details tool (if provided) to retrieve metadata for a specific arXiv ID.
76
+
77
+ Display: title, all authors, categories, full abstract, published date, PDF URL, abstract URL.
78
+
79
+ ### Step 4: Download PDFs (MCP)
80
+
81
+ When download is requested:
82
+
83
+ - Use MCP download/fetch tool if available.
84
+ - If the MCP server only returns URLs, create the directory and save the URL list so the user can fetch later.
85
+
86
+ If a local file path is returned:
87
+
88
+ - Confirm file size > 10 KB (reject smaller files - likely an error HTML page)
89
+ - Add a 1-second delay between consecutive downloads to avoid rate limiting
90
+ - Report: `Downloaded: papers/2301.07041.pdf (842 KB)`
91
+
92
+ ### Step 5: Summarize
93
+
94
+ For each paper (downloaded or fetched by API):
95
+
96
+ ```markdown
97
+ ## [Title]
98
+
99
+ - **arXiv**: [ID] - [abs_url]
100
+ - **Authors**: [full author list]
101
+ - **Date**: [published]
102
+ - **Categories**: [cs.LG, cs.AI, ...]
103
+ - **Abstract**: [full abstract]
104
+ - **Key contributions** (extracted from abstract):
105
+ - [contribution 1]
106
+ - [contribution 2]
107
+ - [contribution 3]
108
+ - **Local PDF**: papers/[ID].pdf (if downloaded)
109
+ ```
110
+
111
+ ### Step 6: Final Output
112
+
113
+ Summarize what was done:
114
+
115
+ - `Found N papers for "query"`
116
+ - `Downloaded: papers/2301.07041.pdf (842 KB)` (for each download)
117
+ - Any warnings (rate limit hit, file too small, already exists)
118
+
119
+ Suggest follow-up skills:
120
+
121
+ ```text
122
+ /research-lit "topic" - multi-source review: Zotero + Obsidian + local PDFs + web
123
+ /novelty-check "idea" - verify your idea is novel against these papers
124
+ ```
125
+
126
+ ## Key Rules
127
+
128
+ - Always show the arXiv ID prominently - users need it for citations and reproducibility
129
+ - Verify downloaded PDFs: file must be > 10 KB; warn and delete if smaller
130
+ - Rate limit: wait 1 second between consecutive PDF downloads; retry once after 5 seconds on HTTP 429
131
+ - Never overwrite an existing PDF at the same path - skip it and report "already exists"
132
+ - Handle both arXiv ID formats: new (`2301.07041`) and old (`cs/0601001`)
133
+ - PAPER_DIR is created automatically if it does not exist
134
+ - If the arXiv API is unreachable, report the error clearly and suggest using `/research-lit` with `- sources: web` as a fallback
@@ -6,82 +6,83 @@ allowed-tools: "WebSearch, WebFetch, Grep, Read, Glob, mcp__codex__codex"
6
6
  metadata:
7
7
  category: "research/literature-and-web-search"
8
8
  ---
9
- # Novelty Check Skill
10
-
11
- Check whether a proposed method/idea has already been done in the literature: **$ARGUMENTS**
12
-
13
- ## Constants
14
-
15
- - REVIEWER_MODEL = `gpt-5.4` — Model used via Codex MCP. Must be an OpenAI model (e.g., `gpt-5.4`, `o3`, `gpt-4o`)
16
-
17
- ## Instructions
18
-
19
- Given a method description, systematically verify its novelty:
20
-
21
- ### Phase A: Extract Key Claims
22
- 1. Read the user's method description
23
- 2. Identify 3-5 core technical claims that would need to be novel:
24
- - What is the method?
25
- - What problem does it solve?
26
- - What is the mechanism?
27
- - What makes it different from obvious baselines?
28
-
29
- ### Phase B: Multi-Source Literature Search
30
- For EACH core claim, search using ALL available sources:
31
-
32
- 1. **Web Search** (via `WebSearch`):
33
- - Search arXiv, Google Scholar, Semantic Scholar
34
- - Use specific technical terms from the claim
35
- - Try at least 3 different query formulations per claim
36
- - Include year filters for 2024-2026
37
-
38
- 2. **Known paper databases**: Check against:
39
- - ICLR 2025/2026, NeurIPS 2025, ICML 2025/2026
40
- - Recent arXiv preprints (2025-2026)
41
-
42
- 3. **Read abstracts**: For each potentially overlapping paper, WebFetch its abstract and related work section
43
-
44
- ### Phase C: Cross-Model Verification
45
- Call REVIEWER_MODEL via Codex MCP (`mcp__codex__codex`) with xhigh reasoning:
46
- ```
47
- config: {"model_reasoning_effort": "xhigh"}
48
- ```
49
- Prompt should include:
50
- - The proposed method description
51
- - All papers found in Phase B
52
- - Ask: "Is this method novel? What is the closest prior work? What is the delta?"
53
-
54
- ### Phase D: Novelty Report
55
- Output a structured report:
56
-
57
- ```markdown
58
- ## Novelty Check Report
59
-
60
- ### Proposed Method
61
- [1-2 sentence description]
62
-
63
- ### Core Claims
64
- 1. [Claim 1] — Novelty: HIGH/MEDIUM/LOW — Closest: [paper]
65
- 2. [Claim 2] — Novelty: HIGH/MEDIUM/LOW — Closest: [paper]
66
- ...
67
-
68
- ### Closest Prior Work
69
- | Paper | Year | Venue | Overlap | Key Difference |
70
- |-------|------|-------|---------|----------------|
71
-
72
- ### Overall Novelty Assessment
73
- - Score: X/10
74
- - Recommendation: PROCEED / PROCEED WITH CAUTION / ABANDON
75
- - Key differentiator: [what makes this unique, if anything]
76
- - Risk: [what a reviewer would cite as prior work]
77
-
78
- ### Suggested Positioning
79
- [How to frame the contribution to maximize novelty perception]
80
- ```
81
-
82
- ### Important Rules
83
- - Be BRUTALLY honest — false novelty claims waste months of research time
84
- - "Applying X to Y" is NOT novel unless the application reveals surprising insights
85
- - Check both the method AND the experimental setting for novelty
86
- - If the method is not novel but the FINDING would be, say so explicitly
87
- - Always check the most recent 6 months of arXiv the field moves fast
9
+
10
+ # Novelty Check Skill
11
+
12
+ Check whether a proposed method/idea has already been done in the literature: **$ARGUMENTS**
13
+
14
+ ## Constants
15
+
16
+ - REVIEWER_MODEL = `gpt-5.4` — Model used via Codex MCP. Must be an OpenAI model (e.g., `gpt-5.4`, `o3`, `gpt-4o`)
17
+
18
+ ## Instructions
19
+
20
+ Given a method description, systematically verify its novelty:
21
+
22
+ ### Phase A: Extract Key Claims
23
+ 1. Read the user's method description
24
+ 2. Identify 3-5 core technical claims that would need to be novel:
25
+ - What is the method?
26
+ - What problem does it solve?
27
+ - What is the mechanism?
28
+ - What makes it different from obvious baselines?
29
+
30
+ ### Phase B: Multi-Source Literature Search
31
+ For EACH core claim, search using ALL available sources:
32
+
33
+ 1. **Web Search** (via `WebSearch`):
34
+ - Search arXiv, Google Scholar, Semantic Scholar
35
+ - Use specific technical terms from the claim
36
+ - Try at least 3 different query formulations per claim
37
+ - Include year filters for 2024-2026
38
+
39
+ 2. **Known paper databases**: Check against:
40
+ - ICLR 2025/2026, NeurIPS 2025, ICML 2025/2026
41
+ - Recent arXiv preprints (2025-2026)
42
+
43
+ 3. **Read abstracts**: For each potentially overlapping paper, WebFetch its abstract and related work section
44
+
45
+ ### Phase C: Cross-Model Verification
46
+ Call REVIEWER_MODEL via Codex MCP (`mcp__codex__codex`) with xhigh reasoning:
47
+ ```
48
+ config: {"model_reasoning_effort": "xhigh"}
49
+ ```
50
+ Prompt should include:
51
+ - The proposed method description
52
+ - All papers found in Phase B
53
+ - Ask: "Is this method novel? What is the closest prior work? What is the delta?"
54
+
55
+ ### Phase D: Novelty Report
56
+ Output a structured report:
57
+
58
+ ```markdown
59
+ ## Novelty Check Report
60
+
61
+ ### Proposed Method
62
+ [1-2 sentence description]
63
+
64
+ ### Core Claims
65
+ 1. [Claim 1] — Novelty: HIGH/MEDIUM/LOW — Closest: [paper]
66
+ 2. [Claim 2] — Novelty: HIGH/MEDIUM/LOW — Closest: [paper]
67
+ ...
68
+
69
+ ### Closest Prior Work
70
+ | Paper | Year | Venue | Overlap | Key Difference |
71
+ |-------|------|-------|---------|----------------|
72
+
73
+ ### Overall Novelty Assessment
74
+ - Score: X/10
75
+ - Recommendation: PROCEED / PROCEED WITH CAUTION / ABANDON
76
+ - Key differentiator: [what makes this unique, if anything]
77
+ - Risk: [what a reviewer would cite as prior work]
78
+
79
+ ### Suggested Positioning
80
+ [How to frame the contribution to maximize novelty perception]
81
+ ```
82
+
83
+ ### Important Rules
84
+ - Be BRUTALLY honest false novelty claims waste months of research time
85
+ - "Applying X to Y" is NOT novel unless the application reveals surprising insights
86
+ - Check both the method AND the experimental setting for novelty
87
+ - If the method is not novel but the FINDING would be, say so explicitly
88
+ - Always check the most recent 6 months of arXiv — the field moves fast