agentsys 5.0.3 → 5.1.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 (264) hide show
  1. package/.claude-plugin/marketplace.json +21 -14
  2. package/.claude-plugin/plugin.json +1 -1
  3. package/AGENTS.md +2 -1
  4. package/CHANGELOG.md +18 -0
  5. package/README.md +7 -6
  6. package/adapters/codex/skills/agnix/SKILL.md +0 -1
  7. package/adapters/codex/skills/audit-project/SKILL.md +0 -1
  8. package/adapters/codex/skills/audit-project-agents/SKILL.md +0 -1
  9. package/adapters/codex/skills/audit-project-github/SKILL.md +0 -1
  10. package/adapters/codex/skills/consult/SKILL.md +132 -57
  11. package/adapters/codex/skills/debate/SKILL.md +214 -0
  12. package/adapters/codex/skills/delivery-approval/SKILL.md +0 -1
  13. package/adapters/codex/skills/deslop/SKILL.md +0 -1
  14. package/adapters/codex/skills/drift-detect/SKILL.md +0 -1
  15. package/adapters/codex/skills/enhance/SKILL.md +0 -1
  16. package/adapters/codex/skills/learn/SKILL.md +0 -1
  17. package/adapters/codex/skills/next-task/SKILL.md +0 -1
  18. package/adapters/codex/skills/perf/SKILL.md +0 -1
  19. package/adapters/codex/skills/repo-map/SKILL.md +0 -1
  20. package/adapters/codex/skills/ship/SKILL.md +0 -1
  21. package/adapters/codex/skills/ship-ci-review-loop/SKILL.md +0 -1
  22. package/adapters/codex/skills/ship-deployment/SKILL.md +0 -1
  23. package/adapters/codex/skills/ship-error-handling/SKILL.md +0 -1
  24. package/adapters/codex/skills/sync-docs/SKILL.md +0 -1
  25. package/adapters/opencode/agents/agent-enhancer.md +0 -1
  26. package/adapters/opencode/agents/agnix-agent.md +0 -1
  27. package/adapters/opencode/agents/ci-fixer.md +0 -1
  28. package/adapters/opencode/agents/ci-monitor.md +0 -1
  29. package/adapters/opencode/agents/claudemd-enhancer.md +0 -1
  30. package/adapters/opencode/agents/consult-agent.md +122 -30
  31. package/adapters/opencode/agents/cross-file-enhancer.md +0 -1
  32. package/adapters/opencode/agents/debate-orchestrator.md +169 -0
  33. package/adapters/opencode/agents/delivery-validator.md +0 -1
  34. package/adapters/opencode/agents/deslop-agent.md +0 -1
  35. package/adapters/opencode/agents/docs-enhancer.md +0 -1
  36. package/adapters/opencode/agents/exploration-agent.md +0 -1
  37. package/adapters/opencode/agents/hooks-enhancer.md +0 -1
  38. package/adapters/opencode/agents/implementation-agent.md +0 -1
  39. package/adapters/opencode/agents/learn-agent.md +0 -1
  40. package/adapters/opencode/agents/map-validator.md +0 -1
  41. package/adapters/opencode/agents/perf-analyzer.md +0 -1
  42. package/adapters/opencode/agents/perf-code-paths.md +0 -1
  43. package/adapters/opencode/agents/perf-investigation-logger.md +0 -1
  44. package/adapters/opencode/agents/perf-orchestrator.md +0 -1
  45. package/adapters/opencode/agents/perf-theory-gatherer.md +0 -1
  46. package/adapters/opencode/agents/perf-theory-tester.md +0 -1
  47. package/adapters/opencode/agents/plan-synthesizer.md +0 -1
  48. package/adapters/opencode/agents/planning-agent.md +0 -1
  49. package/adapters/opencode/agents/plugin-enhancer.md +0 -1
  50. package/adapters/opencode/agents/prompt-enhancer.md +0 -1
  51. package/adapters/opencode/agents/simple-fixer.md +0 -1
  52. package/adapters/opencode/agents/skills-enhancer.md +0 -1
  53. package/adapters/opencode/agents/sync-docs-agent.md +0 -1
  54. package/adapters/opencode/agents/task-discoverer.md +0 -1
  55. package/adapters/opencode/agents/test-coverage-checker.md +0 -1
  56. package/adapters/opencode/agents/worktree-manager.md +0 -1
  57. package/adapters/opencode/commands/agnix.md +0 -1
  58. package/adapters/opencode/commands/audit-project-agents.md +0 -1
  59. package/adapters/opencode/commands/audit-project-github.md +0 -1
  60. package/adapters/opencode/commands/audit-project.md +0 -1
  61. package/adapters/opencode/commands/consult.md +133 -57
  62. package/adapters/opencode/commands/debate.md +224 -0
  63. package/adapters/opencode/commands/delivery-approval.md +0 -1
  64. package/adapters/opencode/commands/deslop.md +0 -1
  65. package/adapters/opencode/commands/drift-detect.md +0 -1
  66. package/adapters/opencode/commands/enhance.md +0 -1
  67. package/adapters/opencode/commands/learn.md +0 -1
  68. package/adapters/opencode/commands/next-task.md +0 -1
  69. package/adapters/opencode/commands/perf.md +0 -1
  70. package/adapters/opencode/commands/repo-map.md +0 -1
  71. package/adapters/opencode/commands/ship-ci-review-loop.md +0 -1
  72. package/adapters/opencode/commands/ship-deployment.md +0 -1
  73. package/adapters/opencode/commands/ship-error-handling.md +0 -1
  74. package/adapters/opencode/commands/ship.md +0 -1
  75. package/adapters/opencode/commands/sync-docs.md +0 -1
  76. package/adapters/opencode/skills/agnix/SKILL.md +1 -2
  77. package/adapters/opencode/skills/consult/SKILL.md +33 -23
  78. package/adapters/opencode/skills/debate/SKILL.md +245 -0
  79. package/adapters/opencode/skills/deslop/SKILL.md +1 -2
  80. package/adapters/opencode/skills/discover-tasks/SKILL.md +1 -2
  81. package/adapters/opencode/skills/drift-analysis/SKILL.md +1 -2
  82. package/adapters/opencode/skills/enhance-agent-prompts/SKILL.md +1 -2
  83. package/adapters/opencode/skills/enhance-claude-memory/SKILL.md +1 -2
  84. package/adapters/opencode/skills/enhance-cross-file/SKILL.md +1 -2
  85. package/adapters/opencode/skills/enhance-docs/SKILL.md +1 -2
  86. package/adapters/opencode/skills/enhance-hooks/SKILL.md +1 -2
  87. package/adapters/opencode/skills/enhance-orchestrator/SKILL.md +1 -2
  88. package/adapters/opencode/skills/enhance-plugins/SKILL.md +1 -2
  89. package/adapters/opencode/skills/enhance-prompts/SKILL.md +1 -2
  90. package/adapters/opencode/skills/enhance-skills/SKILL.md +1 -2
  91. package/adapters/opencode/skills/learn/SKILL.md +1 -2
  92. package/adapters/opencode/skills/orchestrate-review/SKILL.md +0 -1
  93. package/adapters/opencode/skills/perf-analyzer/SKILL.md +1 -2
  94. package/adapters/opencode/skills/perf-baseline-manager/SKILL.md +1 -2
  95. package/adapters/opencode/skills/perf-benchmarker/SKILL.md +1 -2
  96. package/adapters/opencode/skills/perf-code-paths/SKILL.md +1 -2
  97. package/adapters/opencode/skills/perf-investigation-logger/SKILL.md +1 -2
  98. package/adapters/opencode/skills/perf-profiler/SKILL.md +1 -2
  99. package/adapters/opencode/skills/perf-theory-gatherer/SKILL.md +1 -2
  100. package/adapters/opencode/skills/perf-theory-tester/SKILL.md +1 -2
  101. package/adapters/opencode/skills/repo-mapping/SKILL.md +1 -2
  102. package/adapters/opencode/skills/sync-docs/SKILL.md +1 -2
  103. package/adapters/opencode/skills/validate-delivery/SKILL.md +1 -2
  104. package/lib/adapter-transforms.js +24 -4
  105. package/package.json +1 -1
  106. package/plugins/agnix/.claude-plugin/plugin.json +1 -1
  107. package/plugins/agnix/skills/agnix/SKILL.md +1 -1
  108. package/plugins/audit-project/.claude-plugin/plugin.json +1 -1
  109. package/plugins/audit-project/lib/adapter-transforms.js +24 -4
  110. package/plugins/consult/.claude-plugin/plugin.json +1 -1
  111. package/plugins/consult/agents/consult-agent.md +122 -29
  112. package/plugins/consult/commands/consult.md +135 -58
  113. package/plugins/consult/skills/consult/SKILL.md +31 -20
  114. package/plugins/debate/.claude-plugin/plugin.json +21 -0
  115. package/plugins/debate/agents/debate-orchestrator.md +175 -0
  116. package/plugins/debate/commands/debate.md +221 -0
  117. package/plugins/debate/lib/adapter-transforms.js +298 -0
  118. package/plugins/debate/lib/collectors/codebase.js +392 -0
  119. package/plugins/debate/lib/collectors/docs-patterns.js +713 -0
  120. package/plugins/debate/lib/collectors/documentation.js +219 -0
  121. package/plugins/debate/lib/collectors/github.js +330 -0
  122. package/plugins/debate/lib/collectors/index.js +126 -0
  123. package/plugins/debate/lib/config/index.js +14 -0
  124. package/plugins/debate/lib/cross-platform/index.js +539 -0
  125. package/plugins/debate/lib/discovery/index.js +352 -0
  126. package/plugins/debate/lib/drift-detect/collectors.js +37 -0
  127. package/plugins/debate/lib/enhance/agent-analyzer.js +421 -0
  128. package/plugins/debate/lib/enhance/agent-patterns.js +571 -0
  129. package/plugins/debate/lib/enhance/auto-suppression.js +622 -0
  130. package/plugins/debate/lib/enhance/benchmark.js +417 -0
  131. package/plugins/debate/lib/enhance/cross-file-analyzer.js +930 -0
  132. package/plugins/debate/lib/enhance/cross-file-patterns.js +370 -0
  133. package/plugins/debate/lib/enhance/docs-analyzer.js +325 -0
  134. package/plugins/debate/lib/enhance/docs-patterns.js +671 -0
  135. package/plugins/debate/lib/enhance/fixer.js +721 -0
  136. package/plugins/debate/lib/enhance/hook-analyzer.js +135 -0
  137. package/plugins/debate/lib/enhance/hook-patterns.js +40 -0
  138. package/plugins/debate/lib/enhance/index.js +127 -0
  139. package/plugins/debate/lib/enhance/plugin-analyzer.js +402 -0
  140. package/plugins/debate/lib/enhance/plugin-patterns.js +326 -0
  141. package/plugins/debate/lib/enhance/projectmemory-analyzer.js +551 -0
  142. package/plugins/debate/lib/enhance/projectmemory-patterns.js +617 -0
  143. package/plugins/debate/lib/enhance/prompt-analyzer.js +457 -0
  144. package/plugins/debate/lib/enhance/prompt-patterns.js +1484 -0
  145. package/plugins/debate/lib/enhance/reporter.js +1348 -0
  146. package/plugins/debate/lib/enhance/security-patterns.js +284 -0
  147. package/plugins/debate/lib/enhance/skill-analyzer.js +182 -0
  148. package/plugins/debate/lib/enhance/skill-patterns.js +147 -0
  149. package/plugins/debate/lib/enhance/suppression.js +352 -0
  150. package/plugins/debate/lib/enhance/tool-patterns.js +373 -0
  151. package/plugins/debate/lib/index.js +270 -0
  152. package/plugins/debate/lib/patterns/cli-enhancers.js +611 -0
  153. package/plugins/debate/lib/patterns/pipeline.js +948 -0
  154. package/plugins/debate/lib/patterns/review-patterns.js +558 -0
  155. package/plugins/debate/lib/patterns/slop-analyzers.js +2305 -0
  156. package/plugins/debate/lib/patterns/slop-patterns.js +1187 -0
  157. package/plugins/debate/lib/perf/analyzer/index.js +22 -0
  158. package/plugins/debate/lib/perf/argument-parser.js +105 -0
  159. package/plugins/debate/lib/perf/baseline-comparator.js +50 -0
  160. package/plugins/debate/lib/perf/baseline-store.js +127 -0
  161. package/plugins/debate/lib/perf/benchmark-runner.js +404 -0
  162. package/plugins/debate/lib/perf/breaking-point-finder.js +52 -0
  163. package/plugins/debate/lib/perf/breaking-point-runner.js +60 -0
  164. package/plugins/debate/lib/perf/checkpoint.js +123 -0
  165. package/plugins/debate/lib/perf/code-paths.js +86 -0
  166. package/plugins/debate/lib/perf/consolidation.js +37 -0
  167. package/plugins/debate/lib/perf/constraint-runner.js +71 -0
  168. package/plugins/debate/lib/perf/experiment-runner.js +32 -0
  169. package/plugins/debate/lib/perf/index.js +41 -0
  170. package/plugins/debate/lib/perf/investigation-state.js +874 -0
  171. package/plugins/debate/lib/perf/optimization-runner.js +79 -0
  172. package/plugins/debate/lib/perf/profilers/go.js +22 -0
  173. package/plugins/debate/lib/perf/profilers/index.js +46 -0
  174. package/plugins/debate/lib/perf/profilers/java.js +23 -0
  175. package/plugins/debate/lib/perf/profilers/node.js +27 -0
  176. package/plugins/debate/lib/perf/profilers/python.js +23 -0
  177. package/plugins/debate/lib/perf/profilers/rust.js +23 -0
  178. package/plugins/debate/lib/perf/profiling-runner.js +75 -0
  179. package/plugins/debate/lib/perf/schemas.js +140 -0
  180. package/plugins/debate/lib/platform/detect-platform.js +413 -0
  181. package/plugins/debate/lib/platform/detection-configs.js +93 -0
  182. package/plugins/debate/lib/platform/state-dir.js +132 -0
  183. package/plugins/debate/lib/platform/verify-tools.js +182 -0
  184. package/plugins/debate/lib/repo-map/cache.js +152 -0
  185. package/plugins/debate/lib/repo-map/concurrency.js +29 -0
  186. package/plugins/debate/lib/repo-map/index.js +222 -0
  187. package/plugins/debate/lib/repo-map/installer.js +212 -0
  188. package/plugins/debate/lib/repo-map/queries/go.js +27 -0
  189. package/plugins/debate/lib/repo-map/queries/index.js +100 -0
  190. package/plugins/debate/lib/repo-map/queries/java.js +38 -0
  191. package/plugins/debate/lib/repo-map/queries/javascript.js +55 -0
  192. package/plugins/debate/lib/repo-map/queries/python.js +24 -0
  193. package/plugins/debate/lib/repo-map/queries/rust.js +73 -0
  194. package/plugins/debate/lib/repo-map/queries/typescript.js +38 -0
  195. package/plugins/debate/lib/repo-map/runner.js +1364 -0
  196. package/plugins/debate/lib/repo-map/updater.js +562 -0
  197. package/plugins/debate/lib/repo-map/usage-analyzer.js +407 -0
  198. package/plugins/debate/lib/schemas/plugin-manifest.schema.json +57 -0
  199. package/plugins/debate/lib/schemas/validator.js +247 -0
  200. package/plugins/debate/lib/sources/custom-handler.js +199 -0
  201. package/plugins/debate/lib/sources/policy-questions.js +246 -0
  202. package/plugins/debate/lib/sources/source-cache.js +165 -0
  203. package/plugins/debate/lib/state/workflow-state.js +576 -0
  204. package/plugins/debate/lib/types/agent-frontmatter.d.ts +134 -0
  205. package/plugins/debate/lib/types/command-frontmatter.d.ts +107 -0
  206. package/plugins/debate/lib/types/hook-frontmatter.d.ts +115 -0
  207. package/plugins/debate/lib/types/index.d.ts +84 -0
  208. package/plugins/debate/lib/types/plugin-manifest.d.ts +102 -0
  209. package/plugins/debate/lib/types/skill-frontmatter.d.ts +89 -0
  210. package/plugins/debate/lib/utils/atomic-write.js +94 -0
  211. package/plugins/debate/lib/utils/cache-manager.js +159 -0
  212. package/plugins/debate/lib/utils/command-parser.js +0 -0
  213. package/plugins/debate/lib/utils/context-optimizer.js +300 -0
  214. package/plugins/debate/lib/utils/deprecation.js +37 -0
  215. package/plugins/debate/lib/utils/shell-escape.js +88 -0
  216. package/plugins/debate/lib/utils/state-helpers.js +61 -0
  217. package/plugins/debate/skills/debate/SKILL.md +264 -0
  218. package/plugins/deslop/.claude-plugin/plugin.json +1 -1
  219. package/plugins/deslop/lib/adapter-transforms.js +24 -4
  220. package/plugins/deslop/skills/deslop/SKILL.md +1 -1
  221. package/plugins/drift-detect/.claude-plugin/plugin.json +1 -1
  222. package/plugins/drift-detect/lib/adapter-transforms.js +24 -4
  223. package/plugins/drift-detect/skills/drift-analysis/SKILL.md +1 -1
  224. package/plugins/enhance/.claude-plugin/plugin.json +1 -1
  225. package/plugins/enhance/lib/adapter-transforms.js +24 -4
  226. package/plugins/enhance/skills/enhance-agent-prompts/SKILL.md +1 -1
  227. package/plugins/enhance/skills/enhance-claude-memory/SKILL.md +1 -1
  228. package/plugins/enhance/skills/enhance-cross-file/SKILL.md +1 -1
  229. package/plugins/enhance/skills/enhance-docs/SKILL.md +1 -1
  230. package/plugins/enhance/skills/enhance-hooks/SKILL.md +1 -1
  231. package/plugins/enhance/skills/enhance-orchestrator/SKILL.md +1 -1
  232. package/plugins/enhance/skills/enhance-plugins/SKILL.md +1 -1
  233. package/plugins/enhance/skills/enhance-prompts/SKILL.md +1 -1
  234. package/plugins/enhance/skills/enhance-skills/SKILL.md +1 -1
  235. package/plugins/learn/.claude-plugin/plugin.json +1 -1
  236. package/plugins/learn/agents/learn-agent.md +1 -1
  237. package/plugins/learn/lib/adapter-transforms.js +24 -4
  238. package/plugins/learn/skills/learn/SKILL.md +1 -1
  239. package/plugins/next-task/.claude-plugin/plugin.json +1 -1
  240. package/plugins/next-task/agents/exploration-agent.md +1 -1
  241. package/plugins/next-task/lib/adapter-transforms.js +24 -4
  242. package/plugins/next-task/skills/discover-tasks/SKILL.md +1 -1
  243. package/plugins/next-task/skills/validate-delivery/SKILL.md +1 -1
  244. package/plugins/perf/.claude-plugin/plugin.json +1 -1
  245. package/plugins/perf/lib/adapter-transforms.js +24 -4
  246. package/plugins/perf/skills/perf-analyzer/SKILL.md +1 -1
  247. package/plugins/perf/skills/perf-baseline-manager/SKILL.md +1 -1
  248. package/plugins/perf/skills/perf-benchmarker/SKILL.md +1 -1
  249. package/plugins/perf/skills/perf-code-paths/SKILL.md +1 -1
  250. package/plugins/perf/skills/perf-investigation-logger/SKILL.md +1 -1
  251. package/plugins/perf/skills/perf-profiler/SKILL.md +1 -1
  252. package/plugins/perf/skills/perf-theory-gatherer/SKILL.md +1 -1
  253. package/plugins/perf/skills/perf-theory-tester/SKILL.md +1 -1
  254. package/plugins/repo-map/.claude-plugin/plugin.json +1 -1
  255. package/plugins/repo-map/lib/adapter-transforms.js +24 -4
  256. package/plugins/ship/.claude-plugin/plugin.json +1 -1
  257. package/plugins/ship/lib/adapter-transforms.js +24 -4
  258. package/plugins/sync-docs/.claude-plugin/plugin.json +1 -1
  259. package/plugins/sync-docs/lib/adapter-transforms.js +24 -4
  260. package/plugins/sync-docs/skills/sync-docs/SKILL.md +1 -1
  261. package/scripts/gen-adapters.js +6 -7
  262. package/scripts/generate-docs.js +4 -2
  263. package/scripts/plugins.txt +1 -0
  264. package/site/content.json +6 -6
@@ -0,0 +1,264 @@
1
+ ---
2
+ name: debate
3
+ description: "Structured AI debate templates and synthesis. Use when orchestrating multi-round debates between AI tools, 'debate topic', 'argue about', 'stress test idea', 'devil advocate'."
4
+ version: 5.1.0
5
+ argument-hint: "[topic] [--proposer=tool] [--challenger=tool] [--rounds=N] [--effort=level]"
6
+ ---
7
+
8
+ # debate
9
+
10
+ Prompt templates, context assembly rules, and synthesis format for structured multi-round debates between AI tools.
11
+
12
+ ## Arguments
13
+
14
+ Parse from `$ARGUMENTS`:
15
+ - **topic**: The debate question/topic (required)
16
+ - **--proposer**: Tool for the proposer role (claude, gemini, codex, opencode, copilot)
17
+ - **--challenger**: Tool for the challenger role (must differ from proposer)
18
+ - **--rounds**: Number of back-and-forth rounds (1-5, default: 2)
19
+ - **--effort**: Thinking effort applied to all tool invocations (low, medium, high, max)
20
+ - **--model-proposer**: Specific model for proposer (optional)
21
+ - **--model-challenger**: Specific model for challenger (optional)
22
+
23
+ ## Universal Rules
24
+
25
+ ALL participants (proposer AND challenger) MUST support claims with specific evidence (file path, code pattern, benchmark, or documented behavior). Unsupported claims from either side will be flagged by the other participant and noted in the verdict. This applies to every round.
26
+
27
+ ## Prompt Templates
28
+
29
+ ### Round 1: Proposer Opening
30
+
31
+ ```
32
+ You are participating in a structured debate as the PROPOSER.
33
+
34
+ Topic: {topic}
35
+
36
+ Your job: Analyze this topic thoroughly and present your position. Take a clear stance. Do not hedge excessively.
37
+
38
+ You MUST support each claim with specific evidence (file path, code pattern, benchmark, or documented behavior). Unsupported claims will be challenged. "I think" or "generally speaking" without evidence is not acceptable.
39
+
40
+ Provide your analysis:
41
+ ```
42
+
43
+ ### Round 1: Challenger Response
44
+
45
+ ```
46
+ You are participating in a structured debate as the CHALLENGER.
47
+
48
+ Topic: {topic}
49
+
50
+ The PROPOSER ({proposer_tool}) argued:
51
+
52
+ ---
53
+ {proposer_round1_response}
54
+ ---
55
+
56
+ Your job: Find weaknesses, blind spots, and flaws in the proposer's argument. You MUST identify at least one genuine flaw or overlooked consideration before agreeing on anything. Propose concrete alternatives where you disagree.
57
+
58
+ Rules:
59
+ - Do NOT say "great point" or validate the proposer's reasoning before critiquing it
60
+ - Lead with what's WRONG or MISSING, then acknowledge what's right
61
+ - If you genuinely agree on a point, explain what RISK remains despite the agreement
62
+ - Propose at least one concrete alternative approach
63
+ - You MUST address at least these categories: correctness, security implications, and developer experience
64
+ - Do NOT agree with ANY claim unless you can cite specific evidence (file path, code pattern, or documented behavior) that supports the agreement. Unsupported agreement is not allowed.
65
+ - If the proposer makes a claim without evidence, call it out: "This claim is unsupported."
66
+
67
+ Provide your challenge:
68
+ ```
69
+
70
+ ### Round 2+: Proposer Defense
71
+
72
+ ```
73
+ You are the PROPOSER in round {round} of a structured debate.
74
+
75
+ Topic: {topic}
76
+
77
+ {context_summary}
78
+
79
+ The CHALLENGER ({challenger_tool}) raised these points in round {previous_round}:
80
+
81
+ ---
82
+ {challenger_previous_response}
83
+ ---
84
+
85
+ Your job: Address each challenge directly. For each point:
86
+ - If they're right, concede explicitly and explain how your position evolves
87
+ - If they're wrong, explain why with specific evidence (file path, code pattern, benchmark, or documented behavior)
88
+ - If it's a tradeoff, acknowledge the tradeoff and explain why you still favor your approach with evidence
89
+
90
+ Every claim you make -- whether concession, rebuttal, or new argument -- MUST cite specific evidence. The challenger will reject unsupported claims.
91
+
92
+ Do NOT simply restate your original position. Your response must show you engaged with the specific challenges raised.
93
+
94
+ Provide your defense:
95
+ ```
96
+
97
+ ### Round 2+: Challenger Follow-up
98
+
99
+ ```
100
+ You are the CHALLENGER in round {round} of a structured debate.
101
+
102
+ Topic: {topic}
103
+
104
+ {context_summary}
105
+
106
+ The PROPOSER ({proposer_tool}) responded to your challenges:
107
+
108
+ ---
109
+ {proposer_previous_response}
110
+ ---
111
+
112
+ IMPORTANT: Do NOT let the proposer reframe your challenges as agreements. If they say "we actually agree" but haven't addressed the substance, reject it. Default to suspicion, not acceptance.
113
+
114
+ Your job: Evaluate the proposer's defense. For each point they addressed:
115
+ - Did they dodge, superficially address, or respond without evidence? Call it out: "This defense is unsupported" or "This dodges the original concern"
116
+ - Did they concede any point? Hold them to it -- they cannot walk it back later without new evidence
117
+ - Are there NEW weaknesses in their revised position?
118
+ - Did they adequately address your concern with specific evidence? Only then acknowledge it, and cite what convinced you
119
+
120
+ You MUST either identify at least one new weakness or unresolved concern, OR explicitly certify a previous concern as genuinely resolved with specific evidence for why you're now satisfied. "I'm convinced because [evidence]" is acceptable. "I agree now" without evidence is not.
121
+ If you see new problems, raise them.
122
+
123
+ Provide your follow-up:
124
+ ```
125
+
126
+ ## Context Assembly
127
+
128
+ ### Rounds 1-2: Full context
129
+
130
+ Include the full text of all prior exchanges in the prompt. Context is small enough (typically under 5000 tokens total).
131
+
132
+ Format for context block:
133
+ ```
134
+ Previous exchanges:
135
+
136
+ Round 1 - Proposer ({proposer_tool}):
137
+ {full response}
138
+
139
+ Round 1 - Challenger ({challenger_tool}):
140
+ {full response}
141
+ ```
142
+
143
+ ### Round 3+: Summarized context
144
+
145
+ For rounds 3 and beyond, replace full exchange text from rounds 1 through N-2 with a summary. Only include the most recent round's responses in full.
146
+
147
+ Format:
148
+ ```
149
+ Summary of rounds 1-{N-2}:
150
+ {summary of key positions, agreements, and open disagreements}
151
+
152
+ Round {N-1} - Proposer ({proposer_tool}):
153
+ {full response}
154
+
155
+ Round {N-1} - Challenger ({challenger_tool}):
156
+ {full response}
157
+ ```
158
+
159
+ The orchestrator agent (opus) generates the summary. Target: 500-800 tokens. MUST preserve:
160
+ - Each side's core position
161
+ - All concessions (verbatim quotes, not paraphrased)
162
+ - All evidence citations that support agreements
163
+ - Points of disagreement (unresolved)
164
+ - Any contradictions between rounds (e.g., proposer concedes in round 1 but walks it back in round 2 -- note both explicitly)
165
+
166
+ ## Synthesis Format
167
+
168
+ After all rounds complete, the orchestrator produces this structured output:
169
+
170
+ ```
171
+ ## Debate Summary
172
+
173
+ **Topic**: {topic}
174
+ **Proposer**: {proposer_tool} ({proposer_model})
175
+ **Challenger**: {challenger_tool} ({challenger_model})
176
+ **Rounds**: {rounds_completed}
177
+ **Rigor**: Structured perspective comparison (prompt-enforced adversarial rules, no deterministic verification)
178
+
179
+ ### Verdict
180
+
181
+ {winner_tool} had the stronger argument because: {specific reasoning citing debate evidence}
182
+
183
+ ### Debate Quality
184
+
185
+ Rate the debate on these dimensions:
186
+ - **Genuine disagreement**: Did the challenger maintain independent positions, or converge toward the proposer? (high/medium/low)
187
+ - **Evidence quality**: Did both sides cite specific examples, or argue from generalities? (high/medium/low)
188
+ - **Challenge depth**: Were the challenges substantive, or surface-level? (high/medium/low)
189
+
190
+ ### Key Agreements
191
+ - {agreed point 1} (evidence: {what supports this agreement})
192
+ - {agreed point 2} (evidence: {what supports this agreement})
193
+
194
+ ### Key Disagreements
195
+ - {point}: {proposer_tool} argues {X}, {challenger_tool} argues {Y}
196
+
197
+ ### Unresolved Questions
198
+ - {question that neither side adequately addressed}
199
+
200
+ ### Recommendation
201
+ {Orchestrator's recommendation - must pick a direction, not "both have merit"}
202
+ ```
203
+
204
+ **Synthesis rules:**
205
+ - The verdict MUST pick a side. "Both approaches have merit" is NOT acceptable.
206
+ - Cite specific arguments from the debate as evidence for the verdict.
207
+ - The recommendation must be actionable - what should the user DO based on this debate.
208
+ - Unresolved questions highlight where the debate fell short, not where both sides are "equally valid."
209
+
210
+ ## State File Schema
211
+
212
+ Save to `{AI_STATE_DIR}/debate/last-debate.json`:
213
+
214
+ ```json
215
+ {
216
+ "id": "debate-{ISO timestamp}-{4 char random hex}",
217
+ "topic": "original topic text",
218
+ "proposer": {"tool": "claude", "model": "opus"},
219
+ "challenger": {"tool": "gemini", "model": "gemini-3-pro"},
220
+ "effort": "high",
221
+ "rounds_completed": 2,
222
+ "max_rounds": 2,
223
+ "status": "completed",
224
+ "exchanges": [
225
+ {"round": 1, "role": "proposer", "tool": "claude", "response": "...", "duration_ms": 8500},
226
+ {"round": 1, "role": "challenger", "tool": "gemini", "response": "...", "duration_ms": 12000},
227
+ {"round": 2, "role": "proposer", "tool": "claude", "response": "...", "duration_ms": 9200},
228
+ {"round": 2, "role": "challenger", "tool": "gemini", "response": "...", "duration_ms": 11000}
229
+ ],
230
+ "verdict": {
231
+ "winner": "claude",
232
+ "reasoning": "...",
233
+ "agreements": ["..."],
234
+ "disagreements": ["..."],
235
+ "recommendation": "..."
236
+ },
237
+ "timestamp": "{ISO 8601 timestamp}"
238
+ }
239
+ ```
240
+
241
+ Platform state directory:
242
+ - Claude Code: `.claude/`
243
+ - OpenCode: `.opencode/`
244
+ - Codex CLI: `.codex/`
245
+
246
+ ## Error Handling
247
+
248
+ | Error | Action |
249
+ |-------|--------|
250
+ | Proposer fails round 1 | Abort debate. Cannot proceed without opening position. |
251
+ | Challenger fails round 1 | Show proposer's position with note: "[WARN] Challenger failed. Showing proposer's uncontested position." |
252
+ | Any tool fails mid-debate | Synthesize from completed rounds. Note incomplete round in output. |
253
+ | All rounds timeout | "[ERROR] Debate failed: all tool invocations timed out." |
254
+
255
+ ## Consult Skill Integration
256
+
257
+ Each tool invocation uses the existing `consult` skill from the consult plugin. The orchestrator invokes it as:
258
+
259
+ ```
260
+ Skill: consult
261
+ Args: "{debate prompt with context}" --tool={tool} --effort={effort} --model={model}
262
+ ```
263
+
264
+ The consult skill handles: provider command building, safe question passing (temp file), output parsing, and secret redaction. The debate skill does NOT duplicate this logic.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "deslop",
3
- "version": "5.0.3",
3
+ "version": "5.1.0",
4
4
  "description": "AI slop cleanup with minimal diffs and behavior preservation",
5
5
  "author": {
6
6
  "name": "Avi Fenesh",
@@ -18,10 +18,30 @@ function transformBodyForOpenCode(content, repoRoot) {
18
18
  content = content.replace(/\$\{CLAUDE_PLUGIN_ROOT\}/g, '${PLUGIN_ROOT}');
19
19
  content = content.replace(/\$CLAUDE_PLUGIN_ROOT/g, '$PLUGIN_ROOT');
20
20
 
21
- content = content.replace(/\.claude\//g, '.opencode/');
22
- content = content.replace(/\.claude'/g, ".opencode'");
23
- content = content.replace(/\.claude"/g, '.opencode"');
24
- content = content.replace(/\.claude`/g, '.opencode`');
21
+ // Replace .claude/ paths with .opencode/ but preserve platform documentation lists
22
+ // that enumerate all three platforms (Claude Code: .claude/, OpenCode: .opencode/, Codex: .codex/)
23
+ // Also preserve {AI_STATE_DIR} references which are platform-agnostic
24
+ content = content.replace(/\.claude\//g, (match, offset) => {
25
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
26
+ // Skip if inside a platform enumeration (e.g., "Claude Code: `.claude/`")
27
+ if (/Claude Code:/.test(context)) return match;
28
+ return '.opencode/';
29
+ });
30
+ content = content.replace(/\.claude'/g, (match, offset) => {
31
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
32
+ if (/Claude Code:/.test(context)) return match;
33
+ return ".opencode'";
34
+ });
35
+ content = content.replace(/\.claude"/g, (match, offset) => {
36
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
37
+ if (/Claude Code:/.test(context)) return match;
38
+ return '.opencode"';
39
+ });
40
+ content = content.replace(/\.claude`/g, (match, offset) => {
41
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
42
+ if (/Claude Code:/.test(context)) return match;
43
+ return '.opencode`';
44
+ });
25
45
 
26
46
  const plugins = discovery.discoverPlugins(repoRoot);
27
47
  if (plugins.length > 0) {
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: deslop
3
3
  description: "Use when user wants to clean AI slop from code. Use for cleanup, remove debug statements, find ghost code, repo hygiene."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[report|apply] [--scope=all|diff|path] [--thoroughness=quick|normal|deep]"
6
6
  ---
7
7
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "drift-detect",
3
- "version": "5.0.3",
3
+ "version": "5.1.0",
4
4
  "description": "Deep repository analysis to realign project plans with actual code reality - discovers drift, gaps, and produces prioritized reconstruction plans",
5
5
  "author": {
6
6
  "name": "Avi Fenesh",
@@ -18,10 +18,30 @@ function transformBodyForOpenCode(content, repoRoot) {
18
18
  content = content.replace(/\$\{CLAUDE_PLUGIN_ROOT\}/g, '${PLUGIN_ROOT}');
19
19
  content = content.replace(/\$CLAUDE_PLUGIN_ROOT/g, '$PLUGIN_ROOT');
20
20
 
21
- content = content.replace(/\.claude\//g, '.opencode/');
22
- content = content.replace(/\.claude'/g, ".opencode'");
23
- content = content.replace(/\.claude"/g, '.opencode"');
24
- content = content.replace(/\.claude`/g, '.opencode`');
21
+ // Replace .claude/ paths with .opencode/ but preserve platform documentation lists
22
+ // that enumerate all three platforms (Claude Code: .claude/, OpenCode: .opencode/, Codex: .codex/)
23
+ // Also preserve {AI_STATE_DIR} references which are platform-agnostic
24
+ content = content.replace(/\.claude\//g, (match, offset) => {
25
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
26
+ // Skip if inside a platform enumeration (e.g., "Claude Code: `.claude/`")
27
+ if (/Claude Code:/.test(context)) return match;
28
+ return '.opencode/';
29
+ });
30
+ content = content.replace(/\.claude'/g, (match, offset) => {
31
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
32
+ if (/Claude Code:/.test(context)) return match;
33
+ return ".opencode'";
34
+ });
35
+ content = content.replace(/\.claude"/g, (match, offset) => {
36
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
37
+ if (/Claude Code:/.test(context)) return match;
38
+ return '.opencode"';
39
+ });
40
+ content = content.replace(/\.claude`/g, (match, offset) => {
41
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
42
+ if (/Claude Code:/.test(context)) return match;
43
+ return '.opencode`';
44
+ });
25
45
 
26
46
  const plugins = discovery.discoverPlugins(repoRoot);
27
47
  if (plugins.length > 0) {
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: drift-analysis
3
3
  description: Use when the user asks about plan drift, reality check, comparing docs to code, project state analysis, roadmap alignment, implementation gaps, or needs guidance on identifying discrepancies between documented plans and actual implementation state.
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  ---
6
6
 
7
7
  # Drift Analysis
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "enhance",
3
- "version": "5.0.3",
3
+ "version": "5.1.0",
4
4
  "description": "Plugin structure and tool use analyzer - validates plugin.json, MCP tools, and security patterns",
5
5
  "author": {
6
6
  "name": "Avi Fenesh",
@@ -18,10 +18,30 @@ function transformBodyForOpenCode(content, repoRoot) {
18
18
  content = content.replace(/\$\{CLAUDE_PLUGIN_ROOT\}/g, '${PLUGIN_ROOT}');
19
19
  content = content.replace(/\$CLAUDE_PLUGIN_ROOT/g, '$PLUGIN_ROOT');
20
20
 
21
- content = content.replace(/\.claude\//g, '.opencode/');
22
- content = content.replace(/\.claude'/g, ".opencode'");
23
- content = content.replace(/\.claude"/g, '.opencode"');
24
- content = content.replace(/\.claude`/g, '.opencode`');
21
+ // Replace .claude/ paths with .opencode/ but preserve platform documentation lists
22
+ // that enumerate all three platforms (Claude Code: .claude/, OpenCode: .opencode/, Codex: .codex/)
23
+ // Also preserve {AI_STATE_DIR} references which are platform-agnostic
24
+ content = content.replace(/\.claude\//g, (match, offset) => {
25
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
26
+ // Skip if inside a platform enumeration (e.g., "Claude Code: `.claude/`")
27
+ if (/Claude Code:/.test(context)) return match;
28
+ return '.opencode/';
29
+ });
30
+ content = content.replace(/\.claude'/g, (match, offset) => {
31
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
32
+ if (/Claude Code:/.test(context)) return match;
33
+ return ".opencode'";
34
+ });
35
+ content = content.replace(/\.claude"/g, (match, offset) => {
36
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
37
+ if (/Claude Code:/.test(context)) return match;
38
+ return '.opencode"';
39
+ });
40
+ content = content.replace(/\.claude`/g, (match, offset) => {
41
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
42
+ if (/Claude Code:/.test(context)) return match;
43
+ return '.opencode`';
44
+ });
25
45
 
26
46
  const plugins = discovery.discoverPlugins(repoRoot);
27
47
  if (plugins.length > 0) {
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-agent-prompts
3
3
  description: "Use when improving agent prompts, frontmatter, and tool restrictions."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix] [--verbose]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-claude-memory
3
3
  description: "Use when improving CLAUDE.md or AGENTS.md project memory files."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  ---
6
6
 
7
7
  # enhance-claude-memory
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-cross-file
3
3
  description: "Use when checking cross-file consistency: tools vs frontmatter, agent references, duplicate rules, contradictions."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-docs
3
3
  description: "Use when improving documentation structure, accuracy, and RAG readiness."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix] [--ai]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-hooks
3
3
  description: "Use when reviewing hooks for safety, timeouts, and correct frontmatter."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-orchestrator
3
3
  description: "Use when coordinating multiple enhancers for /enhance command. Runs analyzers in parallel and produces unified report."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--apply] [--focus=TYPE]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-plugins
3
3
  description: "Use when analyzing plugin structures, MCP tools, and plugin security patterns."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-prompts
3
3
  description: "Use when improving general prompts for structure, examples, and constraints."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix]"
6
6
  ---
7
7
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: enhance-skills
3
3
  description: "Use when reviewing SKILL.md files for structure and trigger quality."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[path] [--fix]"
6
6
  ---
7
7
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "learn",
3
- "version": "5.0.3",
3
+ "version": "5.1.0",
4
4
  "description": "Research any topic online and create comprehensive learning guides with RAG-optimized indexes",
5
5
  "author": {
6
6
  "name": "Avi Fenesh",
@@ -9,7 +9,7 @@ tools:
9
9
  - Write
10
10
  - Glob
11
11
  - Grep
12
- model: opus
12
+ model: sonnet
13
13
  ---
14
14
 
15
15
  # Learn Agent
@@ -18,10 +18,30 @@ function transformBodyForOpenCode(content, repoRoot) {
18
18
  content = content.replace(/\$\{CLAUDE_PLUGIN_ROOT\}/g, '${PLUGIN_ROOT}');
19
19
  content = content.replace(/\$CLAUDE_PLUGIN_ROOT/g, '$PLUGIN_ROOT');
20
20
 
21
- content = content.replace(/\.claude\//g, '.opencode/');
22
- content = content.replace(/\.claude'/g, ".opencode'");
23
- content = content.replace(/\.claude"/g, '.opencode"');
24
- content = content.replace(/\.claude`/g, '.opencode`');
21
+ // Replace .claude/ paths with .opencode/ but preserve platform documentation lists
22
+ // that enumerate all three platforms (Claude Code: .claude/, OpenCode: .opencode/, Codex: .codex/)
23
+ // Also preserve {AI_STATE_DIR} references which are platform-agnostic
24
+ content = content.replace(/\.claude\//g, (match, offset) => {
25
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
26
+ // Skip if inside a platform enumeration (e.g., "Claude Code: `.claude/`")
27
+ if (/Claude Code:/.test(context)) return match;
28
+ return '.opencode/';
29
+ });
30
+ content = content.replace(/\.claude'/g, (match, offset) => {
31
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
32
+ if (/Claude Code:/.test(context)) return match;
33
+ return ".opencode'";
34
+ });
35
+ content = content.replace(/\.claude"/g, (match, offset) => {
36
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
37
+ if (/Claude Code:/.test(context)) return match;
38
+ return '.opencode"';
39
+ });
40
+ content = content.replace(/\.claude`/g, (match, offset) => {
41
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
42
+ if (/Claude Code:/.test(context)) return match;
43
+ return '.opencode`';
44
+ });
25
45
 
26
46
  const plugins = discovery.discoverPlugins(repoRoot);
27
47
  if (plugins.length > 0) {
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: learn
3
3
  description: "Research any topic online and create learning guides. Use when user asks to 'learn about', 'research topic', 'create learning guide', 'build knowledge base', or 'study subject'."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  argument-hint: "[topic] [--depth=brief|medium|deep]"
6
6
  ---
7
7
 
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "next-task",
3
- "version": "5.0.3",
3
+ "version": "5.1.0",
4
4
  "description": "Master workflow orchestrator with autonomous task-to-production automation, quality gates, and multi-agent review",
5
5
  "author": {
6
6
  "name": "Avi Fenesh",
@@ -8,7 +8,7 @@ tools:
8
8
  - Bash(git:*)
9
9
  - LSP
10
10
  - Task
11
- model: opus
11
+ model: sonnet
12
12
  ---
13
13
 
14
14
  # Exploration Agent
@@ -18,10 +18,30 @@ function transformBodyForOpenCode(content, repoRoot) {
18
18
  content = content.replace(/\$\{CLAUDE_PLUGIN_ROOT\}/g, '${PLUGIN_ROOT}');
19
19
  content = content.replace(/\$CLAUDE_PLUGIN_ROOT/g, '$PLUGIN_ROOT');
20
20
 
21
- content = content.replace(/\.claude\//g, '.opencode/');
22
- content = content.replace(/\.claude'/g, ".opencode'");
23
- content = content.replace(/\.claude"/g, '.opencode"');
24
- content = content.replace(/\.claude`/g, '.opencode`');
21
+ // Replace .claude/ paths with .opencode/ but preserve platform documentation lists
22
+ // that enumerate all three platforms (Claude Code: .claude/, OpenCode: .opencode/, Codex: .codex/)
23
+ // Also preserve {AI_STATE_DIR} references which are platform-agnostic
24
+ content = content.replace(/\.claude\//g, (match, offset) => {
25
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
26
+ // Skip if inside a platform enumeration (e.g., "Claude Code: `.claude/`")
27
+ if (/Claude Code:/.test(context)) return match;
28
+ return '.opencode/';
29
+ });
30
+ content = content.replace(/\.claude'/g, (match, offset) => {
31
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
32
+ if (/Claude Code:/.test(context)) return match;
33
+ return ".opencode'";
34
+ });
35
+ content = content.replace(/\.claude"/g, (match, offset) => {
36
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
37
+ if (/Claude Code:/.test(context)) return match;
38
+ return '.opencode"';
39
+ });
40
+ content = content.replace(/\.claude`/g, (match, offset) => {
41
+ const context = content.substring(Math.max(0, offset - 60), offset + match.length + 10);
42
+ if (/Claude Code:/.test(context)) return match;
43
+ return '.opencode`';
44
+ });
25
45
 
26
46
  const plugins = discovery.discoverPlugins(repoRoot);
27
47
  if (plugins.length > 0) {
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: discover-tasks
3
3
  description: "Use when user asks to \"discover tasks\", \"find next task\", or \"prioritize issues\". Discovers and ranks tasks from GitHub, GitLab, local files, and custom sources."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  ---
6
6
 
7
7
  # discover-tasks
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: validate-delivery
3
3
  description: "Use when user asks to \"validate delivery\", \"check readiness\", or \"verify completion\". Runs tests, build, and requirement checks with pass/fail instructions."
4
- version: 5.0.3
4
+ version: 5.1.0
5
5
  ---
6
6
 
7
7
  # validate-delivery