@codewalla_india/openspec 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (356) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +225 -0
  3. package/bin/openspec.js +5 -0
  4. package/dist/cli/index.d.ts +10 -0
  5. package/dist/cli/index.js +548 -0
  6. package/dist/commands/change.d.ts +39 -0
  7. package/dist/commands/change.js +279 -0
  8. package/dist/commands/completion.d.ts +72 -0
  9. package/dist/commands/completion.js +264 -0
  10. package/dist/commands/config.d.ts +36 -0
  11. package/dist/commands/config.js +552 -0
  12. package/dist/commands/context.d.ts +3 -0
  13. package/dist/commands/context.js +155 -0
  14. package/dist/commands/doctor.d.ts +8 -0
  15. package/dist/commands/doctor.js +163 -0
  16. package/dist/commands/feedback.d.ts +9 -0
  17. package/dist/commands/feedback.js +183 -0
  18. package/dist/commands/schema.d.ts +6 -0
  19. package/dist/commands/schema.js +869 -0
  20. package/dist/commands/shared-gather.d.ts +14 -0
  21. package/dist/commands/shared-gather.js +31 -0
  22. package/dist/commands/shared-output.d.ts +18 -0
  23. package/dist/commands/shared-output.js +61 -0
  24. package/dist/commands/show.d.ts +19 -0
  25. package/dist/commands/show.js +177 -0
  26. package/dist/commands/spec.d.ts +19 -0
  27. package/dist/commands/spec.js +236 -0
  28. package/dist/commands/store.d.ts +3 -0
  29. package/dist/commands/store.js +547 -0
  30. package/dist/commands/validate.d.ts +26 -0
  31. package/dist/commands/validate.js +330 -0
  32. package/dist/commands/workflow/index.d.ts +17 -0
  33. package/dist/commands/workflow/index.js +12 -0
  34. package/dist/commands/workflow/instructions.d.ts +45 -0
  35. package/dist/commands/workflow/instructions.js +500 -0
  36. package/dist/commands/workflow/new-change.d.ts +20 -0
  37. package/dist/commands/workflow/new-change.js +106 -0
  38. package/dist/commands/workflow/schemas.d.ts +10 -0
  39. package/dist/commands/workflow/schemas.js +34 -0
  40. package/dist/commands/workflow/shared.d.ts +84 -0
  41. package/dist/commands/workflow/shared.js +133 -0
  42. package/dist/commands/workflow/status.d.ts +16 -0
  43. package/dist/commands/workflow/status.js +92 -0
  44. package/dist/commands/workflow/templates.d.ts +16 -0
  45. package/dist/commands/workflow/templates.js +69 -0
  46. package/dist/commands/workset-input.d.ts +19 -0
  47. package/dist/commands/workset-input.js +112 -0
  48. package/dist/commands/workset-prompts.d.ts +12 -0
  49. package/dist/commands/workset-prompts.js +143 -0
  50. package/dist/commands/workset.d.ts +25 -0
  51. package/dist/commands/workset.js +446 -0
  52. package/dist/core/archive.d.ts +22 -0
  53. package/dist/core/archive.js +471 -0
  54. package/dist/core/artifact-graph/graph.d.ts +56 -0
  55. package/dist/core/artifact-graph/graph.js +141 -0
  56. package/dist/core/artifact-graph/index.d.ts +9 -0
  57. package/dist/core/artifact-graph/index.js +14 -0
  58. package/dist/core/artifact-graph/instruction-loader.d.ts +188 -0
  59. package/dist/core/artifact-graph/instruction-loader.js +233 -0
  60. package/dist/core/artifact-graph/outputs.d.ts +14 -0
  61. package/dist/core/artifact-graph/outputs.js +39 -0
  62. package/dist/core/artifact-graph/resolver.d.ts +81 -0
  63. package/dist/core/artifact-graph/resolver.js +257 -0
  64. package/dist/core/artifact-graph/schema.d.ts +13 -0
  65. package/dist/core/artifact-graph/schema.js +108 -0
  66. package/dist/core/artifact-graph/state.d.ts +12 -0
  67. package/dist/core/artifact-graph/state.js +31 -0
  68. package/dist/core/artifact-graph/types.d.ts +40 -0
  69. package/dist/core/artifact-graph/types.js +29 -0
  70. package/dist/core/available-tools.d.ts +17 -0
  71. package/dist/core/available-tools.js +43 -0
  72. package/dist/core/change-metadata/index.d.ts +2 -0
  73. package/dist/core/change-metadata/index.js +2 -0
  74. package/dist/core/change-metadata/schema.d.ts +19 -0
  75. package/dist/core/change-metadata/schema.js +30 -0
  76. package/dist/core/change-status-policy.d.ts +37 -0
  77. package/dist/core/change-status-policy.js +35 -0
  78. package/dist/core/command-generation/adapters/amazon-q.d.ts +13 -0
  79. package/dist/core/command-generation/adapters/amazon-q.js +26 -0
  80. package/dist/core/command-generation/adapters/antigravity.d.ts +13 -0
  81. package/dist/core/command-generation/adapters/antigravity.js +26 -0
  82. package/dist/core/command-generation/adapters/auggie.d.ts +13 -0
  83. package/dist/core/command-generation/adapters/auggie.js +27 -0
  84. package/dist/core/command-generation/adapters/bob.d.ts +14 -0
  85. package/dist/core/command-generation/adapters/bob.js +32 -0
  86. package/dist/core/command-generation/adapters/claude.d.ts +13 -0
  87. package/dist/core/command-generation/adapters/claude.js +37 -0
  88. package/dist/core/command-generation/adapters/cline.d.ts +14 -0
  89. package/dist/core/command-generation/adapters/cline.js +27 -0
  90. package/dist/core/command-generation/adapters/codebuddy.d.ts +13 -0
  91. package/dist/core/command-generation/adapters/codebuddy.js +28 -0
  92. package/dist/core/command-generation/adapters/codex.d.ts +16 -0
  93. package/dist/core/command-generation/adapters/codex.js +39 -0
  94. package/dist/core/command-generation/adapters/continue.d.ts +13 -0
  95. package/dist/core/command-generation/adapters/continue.js +28 -0
  96. package/dist/core/command-generation/adapters/costrict.d.ts +13 -0
  97. package/dist/core/command-generation/adapters/costrict.js +27 -0
  98. package/dist/core/command-generation/adapters/crush.d.ts +13 -0
  99. package/dist/core/command-generation/adapters/crush.js +30 -0
  100. package/dist/core/command-generation/adapters/cursor.d.ts +14 -0
  101. package/dist/core/command-generation/adapters/cursor.js +31 -0
  102. package/dist/core/command-generation/adapters/factory.d.ts +13 -0
  103. package/dist/core/command-generation/adapters/factory.js +27 -0
  104. package/dist/core/command-generation/adapters/gemini.d.ts +13 -0
  105. package/dist/core/command-generation/adapters/gemini.js +26 -0
  106. package/dist/core/command-generation/adapters/github-copilot.d.ts +13 -0
  107. package/dist/core/command-generation/adapters/github-copilot.js +26 -0
  108. package/dist/core/command-generation/adapters/iflow.d.ts +13 -0
  109. package/dist/core/command-generation/adapters/iflow.js +29 -0
  110. package/dist/core/command-generation/adapters/index.d.ts +32 -0
  111. package/dist/core/command-generation/adapters/index.js +32 -0
  112. package/dist/core/command-generation/adapters/junie.d.ts +13 -0
  113. package/dist/core/command-generation/adapters/junie.js +26 -0
  114. package/dist/core/command-generation/adapters/kilocode.d.ts +14 -0
  115. package/dist/core/command-generation/adapters/kilocode.js +23 -0
  116. package/dist/core/command-generation/adapters/kiro.d.ts +13 -0
  117. package/dist/core/command-generation/adapters/kiro.js +26 -0
  118. package/dist/core/command-generation/adapters/lingma.d.ts +13 -0
  119. package/dist/core/command-generation/adapters/lingma.js +30 -0
  120. package/dist/core/command-generation/adapters/opencode.d.ts +13 -0
  121. package/dist/core/command-generation/adapters/opencode.js +29 -0
  122. package/dist/core/command-generation/adapters/pi.d.ts +18 -0
  123. package/dist/core/command-generation/adapters/pi.js +42 -0
  124. package/dist/core/command-generation/adapters/qoder.d.ts +13 -0
  125. package/dist/core/command-generation/adapters/qoder.js +30 -0
  126. package/dist/core/command-generation/adapters/qwen.d.ts +13 -0
  127. package/dist/core/command-generation/adapters/qwen.js +26 -0
  128. package/dist/core/command-generation/adapters/roocode.d.ts +14 -0
  129. package/dist/core/command-generation/adapters/roocode.js +27 -0
  130. package/dist/core/command-generation/adapters/windsurf.d.ts +14 -0
  131. package/dist/core/command-generation/adapters/windsurf.js +38 -0
  132. package/dist/core/command-generation/generator.d.ts +21 -0
  133. package/dist/core/command-generation/generator.js +27 -0
  134. package/dist/core/command-generation/index.d.ts +22 -0
  135. package/dist/core/command-generation/index.js +24 -0
  136. package/dist/core/command-generation/registry.d.ts +36 -0
  137. package/dist/core/command-generation/registry.js +98 -0
  138. package/dist/core/command-generation/types.d.ts +56 -0
  139. package/dist/core/command-generation/types.js +8 -0
  140. package/dist/core/command-generation/yaml.d.ts +22 -0
  141. package/dist/core/command-generation/yaml.js +38 -0
  142. package/dist/core/completions/command-registry.d.ts +3 -0
  143. package/dist/core/completions/command-registry.js +778 -0
  144. package/dist/core/completions/completion-provider.d.ts +71 -0
  145. package/dist/core/completions/completion-provider.js +129 -0
  146. package/dist/core/completions/factory.d.ts +64 -0
  147. package/dist/core/completions/factory.js +75 -0
  148. package/dist/core/completions/generators/bash-generator.d.ts +35 -0
  149. package/dist/core/completions/generators/bash-generator.js +230 -0
  150. package/dist/core/completions/generators/fish-generator.d.ts +32 -0
  151. package/dist/core/completions/generators/fish-generator.js +160 -0
  152. package/dist/core/completions/generators/powershell-generator.d.ts +36 -0
  153. package/dist/core/completions/generators/powershell-generator.js +266 -0
  154. package/dist/core/completions/generators/zsh-generator.d.ts +47 -0
  155. package/dist/core/completions/generators/zsh-generator.js +276 -0
  156. package/dist/core/completions/installers/bash-installer.d.ts +87 -0
  157. package/dist/core/completions/installers/bash-installer.js +321 -0
  158. package/dist/core/completions/installers/fish-installer.d.ts +43 -0
  159. package/dist/core/completions/installers/fish-installer.js +151 -0
  160. package/dist/core/completions/installers/powershell-installer.d.ts +102 -0
  161. package/dist/core/completions/installers/powershell-installer.js +415 -0
  162. package/dist/core/completions/installers/zsh-installer.d.ts +117 -0
  163. package/dist/core/completions/installers/zsh-installer.js +424 -0
  164. package/dist/core/completions/shared-flags.d.ts +13 -0
  165. package/dist/core/completions/shared-flags.js +33 -0
  166. package/dist/core/completions/templates/bash-templates.d.ts +6 -0
  167. package/dist/core/completions/templates/bash-templates.js +30 -0
  168. package/dist/core/completions/templates/fish-templates.d.ts +7 -0
  169. package/dist/core/completions/templates/fish-templates.js +45 -0
  170. package/dist/core/completions/templates/powershell-templates.d.ts +6 -0
  171. package/dist/core/completions/templates/powershell-templates.js +34 -0
  172. package/dist/core/completions/templates/zsh-templates.d.ts +6 -0
  173. package/dist/core/completions/templates/zsh-templates.js +45 -0
  174. package/dist/core/completions/types.d.ts +101 -0
  175. package/dist/core/completions/types.js +2 -0
  176. package/dist/core/comprehension/config.d.ts +20 -0
  177. package/dist/core/comprehension/config.js +23 -0
  178. package/dist/core/comprehension/fingerprint.d.ts +5 -0
  179. package/dist/core/comprehension/fingerprint.js +25 -0
  180. package/dist/core/comprehension/index.d.ts +49 -0
  181. package/dist/core/comprehension/index.js +78 -0
  182. package/dist/core/comprehension/pass-record.d.ts +29 -0
  183. package/dist/core/comprehension/pass-record.js +64 -0
  184. package/dist/core/comprehension/stats.d.ts +18 -0
  185. package/dist/core/comprehension/stats.js +41 -0
  186. package/dist/core/config-prompts.d.ts +9 -0
  187. package/dist/core/config-prompts.js +34 -0
  188. package/dist/core/config-schema.d.ts +87 -0
  189. package/dist/core/config-schema.js +239 -0
  190. package/dist/core/config.d.ts +18 -0
  191. package/dist/core/config.js +39 -0
  192. package/dist/core/converters/json-converter.d.ts +6 -0
  193. package/dist/core/converters/json-converter.js +51 -0
  194. package/dist/core/file-state.d.ts +36 -0
  195. package/dist/core/file-state.js +112 -0
  196. package/dist/core/global-config.d.ts +51 -0
  197. package/dist/core/global-config.js +124 -0
  198. package/dist/core/id.d.ts +17 -0
  199. package/dist/core/id.js +30 -0
  200. package/dist/core/index.d.ts +6 -0
  201. package/dist/core/index.js +7 -0
  202. package/dist/core/init.d.ts +37 -0
  203. package/dist/core/init.js +613 -0
  204. package/dist/core/legacy-cleanup.d.ts +162 -0
  205. package/dist/core/legacy-cleanup.js +514 -0
  206. package/dist/core/list.d.ts +11 -0
  207. package/dist/core/list.js +185 -0
  208. package/dist/core/migration.d.ts +23 -0
  209. package/dist/core/migration.js +108 -0
  210. package/dist/core/openers.d.ts +77 -0
  211. package/dist/core/openers.js +251 -0
  212. package/dist/core/openspec-root.d.ts +45 -0
  213. package/dist/core/openspec-root.js +192 -0
  214. package/dist/core/parsers/change-parser.d.ts +13 -0
  215. package/dist/core/parsers/change-parser.js +197 -0
  216. package/dist/core/parsers/markdown-parser.d.ts +26 -0
  217. package/dist/core/parsers/markdown-parser.js +227 -0
  218. package/dist/core/parsers/requirement-blocks.d.ts +37 -0
  219. package/dist/core/parsers/requirement-blocks.js +201 -0
  220. package/dist/core/parsers/spec-structure.d.ts +9 -0
  221. package/dist/core/parsers/spec-structure.js +88 -0
  222. package/dist/core/planning-home.d.ts +16 -0
  223. package/dist/core/planning-home.js +67 -0
  224. package/dist/core/profile-sync-drift.d.ts +38 -0
  225. package/dist/core/profile-sync-drift.js +200 -0
  226. package/dist/core/profiles.d.ts +26 -0
  227. package/dist/core/profiles.js +40 -0
  228. package/dist/core/project-config.d.ts +120 -0
  229. package/dist/core/project-config.js +406 -0
  230. package/dist/core/references.d.ts +63 -0
  231. package/dist/core/references.js +310 -0
  232. package/dist/core/relationship-health.d.ts +65 -0
  233. package/dist/core/relationship-health.js +64 -0
  234. package/dist/core/root-selection.d.ts +122 -0
  235. package/dist/core/root-selection.js +337 -0
  236. package/dist/core/schemas/base.schema.d.ts +13 -0
  237. package/dist/core/schemas/base.schema.js +13 -0
  238. package/dist/core/schemas/change.schema.d.ts +73 -0
  239. package/dist/core/schemas/change.schema.js +31 -0
  240. package/dist/core/schemas/index.d.ts +4 -0
  241. package/dist/core/schemas/index.js +4 -0
  242. package/dist/core/schemas/spec.schema.d.ts +18 -0
  243. package/dist/core/schemas/spec.schema.js +15 -0
  244. package/dist/core/shared/index.d.ts +8 -0
  245. package/dist/core/shared/index.js +8 -0
  246. package/dist/core/shared/skill-generation.d.ts +49 -0
  247. package/dist/core/shared/skill-generation.js +96 -0
  248. package/dist/core/shared/tool-detection.d.ts +71 -0
  249. package/dist/core/shared/tool-detection.js +158 -0
  250. package/dist/core/specs-apply.d.ts +78 -0
  251. package/dist/core/specs-apply.js +394 -0
  252. package/dist/core/store/errors.d.ts +20 -0
  253. package/dist/core/store/errors.js +22 -0
  254. package/dist/core/store/foundation.d.ts +56 -0
  255. package/dist/core/store/foundation.js +251 -0
  256. package/dist/core/store/git.d.ts +23 -0
  257. package/dist/core/store/git.js +137 -0
  258. package/dist/core/store/index.d.ts +5 -0
  259. package/dist/core/store/index.js +5 -0
  260. package/dist/core/store/operations.d.ts +114 -0
  261. package/dist/core/store/operations.js +783 -0
  262. package/dist/core/store/registry.d.ts +58 -0
  263. package/dist/core/store/registry.js +275 -0
  264. package/dist/core/styles/palette.d.ts +7 -0
  265. package/dist/core/styles/palette.js +8 -0
  266. package/dist/core/templates/index.d.ts +8 -0
  267. package/dist/core/templates/index.js +9 -0
  268. package/dist/core/templates/skill-templates.d.ts +19 -0
  269. package/dist/core/templates/skill-templates.js +18 -0
  270. package/dist/core/templates/types.d.ts +19 -0
  271. package/dist/core/templates/types.js +5 -0
  272. package/dist/core/templates/workflows/apply-change.d.ts +10 -0
  273. package/dist/core/templates/workflows/apply-change.js +337 -0
  274. package/dist/core/templates/workflows/archive-change.d.ts +10 -0
  275. package/dist/core/templates/workflows/archive-change.js +278 -0
  276. package/dist/core/templates/workflows/bulk-archive-change.d.ts +10 -0
  277. package/dist/core/templates/workflows/bulk-archive-change.js +493 -0
  278. package/dist/core/templates/workflows/comprehension-guidance.d.ts +9 -0
  279. package/dist/core/templates/workflows/comprehension-guidance.js +58 -0
  280. package/dist/core/templates/workflows/continue-change.d.ts +10 -0
  281. package/dist/core/templates/workflows/continue-change.js +239 -0
  282. package/dist/core/templates/workflows/explore.d.ts +10 -0
  283. package/dist/core/templates/workflows/explore.js +464 -0
  284. package/dist/core/templates/workflows/feedback.d.ts +9 -0
  285. package/dist/core/templates/workflows/feedback.js +108 -0
  286. package/dist/core/templates/workflows/ff-change.d.ts +10 -0
  287. package/dist/core/templates/workflows/ff-change.js +205 -0
  288. package/dist/core/templates/workflows/mcp-guidance.d.ts +13 -0
  289. package/dist/core/templates/workflows/mcp-guidance.js +116 -0
  290. package/dist/core/templates/workflows/new-change.d.ts +10 -0
  291. package/dist/core/templates/workflows/new-change.js +148 -0
  292. package/dist/core/templates/workflows/onboard.d.ts +10 -0
  293. package/dist/core/templates/workflows/onboard.js +566 -0
  294. package/dist/core/templates/workflows/propose.d.ts +10 -0
  295. package/dist/core/templates/workflows/propose.js +228 -0
  296. package/dist/core/templates/workflows/store-selection.d.ts +8 -0
  297. package/dist/core/templates/workflows/store-selection.js +8 -0
  298. package/dist/core/templates/workflows/sync-specs.d.ts +10 -0
  299. package/dist/core/templates/workflows/sync-specs.js +291 -0
  300. package/dist/core/templates/workflows/verify-change.d.ts +10 -0
  301. package/dist/core/templates/workflows/verify-change.js +346 -0
  302. package/dist/core/update.d.ts +82 -0
  303. package/dist/core/update.js +557 -0
  304. package/dist/core/validation/constants.d.ts +34 -0
  305. package/dist/core/validation/constants.js +40 -0
  306. package/dist/core/validation/types.d.ts +18 -0
  307. package/dist/core/validation/types.js +2 -0
  308. package/dist/core/validation/validator.d.ts +44 -0
  309. package/dist/core/validation/validator.js +435 -0
  310. package/dist/core/view.d.ts +8 -0
  311. package/dist/core/view.js +168 -0
  312. package/dist/core/working-set.d.ts +47 -0
  313. package/dist/core/working-set.js +43 -0
  314. package/dist/core/worksets.d.ts +75 -0
  315. package/dist/core/worksets.js +245 -0
  316. package/dist/core/zod-issues.d.ts +4 -0
  317. package/dist/core/zod-issues.js +10 -0
  318. package/dist/index.d.ts +3 -0
  319. package/dist/index.js +3 -0
  320. package/dist/prompts/searchable-multi-select.d.ts +28 -0
  321. package/dist/prompts/searchable-multi-select.js +159 -0
  322. package/dist/telemetry/config.d.ts +38 -0
  323. package/dist/telemetry/config.js +136 -0
  324. package/dist/telemetry/index.d.ts +31 -0
  325. package/dist/telemetry/index.js +164 -0
  326. package/dist/ui/ascii-patterns.d.ts +16 -0
  327. package/dist/ui/ascii-patterns.js +133 -0
  328. package/dist/ui/welcome-screen.d.ts +10 -0
  329. package/dist/ui/welcome-screen.js +146 -0
  330. package/dist/utils/change-metadata.d.ts +55 -0
  331. package/dist/utils/change-metadata.js +141 -0
  332. package/dist/utils/change-utils.d.ts +71 -0
  333. package/dist/utils/change-utils.js +138 -0
  334. package/dist/utils/command-references.d.ts +18 -0
  335. package/dist/utils/command-references.js +20 -0
  336. package/dist/utils/file-system.d.ts +41 -0
  337. package/dist/utils/file-system.js +320 -0
  338. package/dist/utils/index.d.ts +6 -0
  339. package/dist/utils/index.js +9 -0
  340. package/dist/utils/interactive.d.ts +18 -0
  341. package/dist/utils/interactive.js +21 -0
  342. package/dist/utils/item-discovery.d.ts +4 -0
  343. package/dist/utils/item-discovery.js +72 -0
  344. package/dist/utils/match.d.ts +3 -0
  345. package/dist/utils/match.js +22 -0
  346. package/dist/utils/shell-detection.d.ts +20 -0
  347. package/dist/utils/shell-detection.js +41 -0
  348. package/dist/utils/task-progress.d.ts +8 -0
  349. package/dist/utils/task-progress.js +36 -0
  350. package/package.json +84 -0
  351. package/schemas/spec-driven/schema.yaml +153 -0
  352. package/schemas/spec-driven/templates/design.md +19 -0
  353. package/schemas/spec-driven/templates/proposal.md +23 -0
  354. package/schemas/spec-driven/templates/spec.md +8 -0
  355. package/schemas/spec-driven/templates/tasks.md +9 -0
  356. package/scripts/postinstall.js +83 -0
@@ -0,0 +1,493 @@
1
+ import { STORE_SELECTION_GUIDANCE } from './store-selection.js';
2
+ export function getBulkArchiveChangeSkillTemplate() {
3
+ return {
4
+ name: 'openspec-bulk-archive-change',
5
+ description: 'Archive multiple completed changes at once. Use when archiving several parallel changes.',
6
+ instructions: `Archive multiple completed changes in a single operation.
7
+
8
+ This skill allows you to batch-archive changes, handling spec conflicts intelligently by checking the codebase to determine what's actually implemented.
9
+
10
+ ${STORE_SELECTION_GUIDANCE}
11
+
12
+ **Input**: None required (prompts for selection)
13
+
14
+ **Steps**
15
+
16
+ 1. **Get active changes**
17
+
18
+ Run \`openspec list --json\` to get all active changes.
19
+
20
+ If no active changes exist, inform user and stop.
21
+
22
+ 2. **Prompt for change selection**
23
+
24
+ Use **AskUserQuestion tool** with multi-select to let user choose changes:
25
+ - Show each change with its schema
26
+ - Include an option for "All changes"
27
+ - Allow any number of selections (1+ works, 2+ is the typical use case)
28
+
29
+ **IMPORTANT**: Do NOT auto-select. Always let the user choose.
30
+
31
+ 3. **Batch validation - gather status for all selected changes**
32
+
33
+ For each selected change, collect:
34
+
35
+ a. **Artifact status** - Run \`openspec status --change "<name>" --json\`
36
+ - Parse \`schemaName\`, \`artifacts\`, \`planningHome\`, \`changeRoot\`, \`artifactPaths\`, and \`actionContext\`
37
+ - Note which artifacts are \`done\` vs other states
38
+
39
+ b. **Task completion** - Read \`artifactPaths.tasks.existingOutputPaths\` from status JSON
40
+ - Count \`- [ ]\` (incomplete) vs \`- [x]\` (complete)
41
+ - If no tasks file exists, note as "No tasks"
42
+
43
+ c. **Delta specs** - Check \`artifactPaths.specs.existingOutputPaths\` from status JSON
44
+ - List which capability specs exist
45
+ - For each, extract requirement names (lines matching \`### Requirement: <name>\`)
46
+
47
+ 4. **Detect spec conflicts**
48
+
49
+ Build a map of \`capability -> [changes that touch it]\`:
50
+
51
+ \`\`\`
52
+ auth -> [change-a, change-b] <- CONFLICT (2+ changes)
53
+ api -> [change-c] <- OK (only 1 change)
54
+ \`\`\`
55
+
56
+ A conflict exists when 2+ selected changes have delta specs for the same capability.
57
+
58
+ 5. **Resolve conflicts agentically**
59
+
60
+ **For each conflict**, investigate the codebase:
61
+
62
+ a. **Read the delta specs** from each conflicting change to understand what each claims to add/modify
63
+
64
+ b. **Search the codebase** for implementation evidence:
65
+ - Look for code implementing requirements from each delta spec
66
+ - Check for related files, functions, or tests
67
+
68
+ c. **Determine resolution**:
69
+ - If only one change is actually implemented -> sync that one's specs
70
+ - If both implemented -> apply in chronological order (older first, newer overwrites)
71
+ - If neither implemented -> skip spec sync, warn user
72
+
73
+ d. **Record resolution** for each conflict:
74
+ - Which change's specs to apply
75
+ - In what order (if both)
76
+ - Rationale (what was found in codebase)
77
+
78
+ 6. **Show consolidated status table**
79
+
80
+ Display a table summarizing all changes:
81
+
82
+ \`\`\`
83
+ | Change | Artifacts | Tasks | Specs | Conflicts | Status |
84
+ |---------------------|-----------|-------|---------|-----------|--------|
85
+ | schema-management | Done | 5/5 | 2 delta | None | Ready |
86
+ | project-config | Done | 3/3 | 1 delta | None | Ready |
87
+ | add-oauth | Done | 4/4 | 1 delta | auth (!) | Ready* |
88
+ | add-verify-skill | 1 left | 2/5 | None | None | Warn |
89
+ \`\`\`
90
+
91
+ For conflicts, show the resolution:
92
+ \`\`\`
93
+ * Conflict resolution:
94
+ - auth spec: Will apply add-oauth then add-jwt (both implemented, chronological order)
95
+ \`\`\`
96
+
97
+ For incomplete changes, show warnings:
98
+ \`\`\`
99
+ Warnings:
100
+ - add-verify-skill: 1 incomplete artifact, 3 incomplete tasks
101
+ \`\`\`
102
+
103
+ 7. **Confirm batch operation**
104
+
105
+ Use **AskUserQuestion tool** with a single confirmation:
106
+
107
+ - "Archive N changes?" with options based on status
108
+ - Options might include:
109
+ - "Archive all N changes"
110
+ - "Archive only N ready changes (skip incomplete)"
111
+ - "Cancel"
112
+
113
+ If there are incomplete changes, make clear they'll be archived with warnings.
114
+
115
+ 8. **Execute archive for each confirmed change**
116
+
117
+ Process changes in the determined order (respecting conflict resolution):
118
+
119
+ a. **Sync specs** if delta specs exist:
120
+ - Use the openspec-sync-specs approach (agent-driven intelligent merge)
121
+ - For conflicts, apply in resolved order
122
+ - Track if sync was done
123
+
124
+ b. **Perform the archive**:
125
+ \`\`\`bash
126
+ mkdir -p "<planningHome.changesDir>/archive"
127
+ mv "<changeRoot>" "<planningHome.changesDir>/archive/YYYY-MM-DD-<name>"
128
+ \`\`\`
129
+
130
+ c. **Track outcome** for each change:
131
+ - Success: archived successfully
132
+ - Failed: error during archive (record error)
133
+ - Skipped: user chose not to archive (if applicable)
134
+
135
+ 9. **Display summary**
136
+
137
+ Show final results:
138
+
139
+ \`\`\`
140
+ ## Bulk Archive Complete
141
+
142
+ Archived 3 changes:
143
+ - schema-management-cli -> archive/2026-01-19-schema-management-cli/
144
+ - project-config -> archive/2026-01-19-project-config/
145
+ - add-oauth -> archive/2026-01-19-add-oauth/
146
+
147
+ Skipped 1 change:
148
+ - add-verify-skill (user chose not to archive incomplete)
149
+
150
+ Spec sync summary:
151
+ - 4 delta specs synced to main specs
152
+ - 1 conflict resolved (auth: applied both in chronological order)
153
+ \`\`\`
154
+
155
+ If any failures:
156
+ \`\`\`
157
+ Failed 1 change:
158
+ - some-change: Archive directory already exists
159
+ \`\`\`
160
+
161
+ **Conflict Resolution Examples**
162
+
163
+ Example 1: Only one implemented
164
+ \`\`\`
165
+ Conflict: specs/auth/spec.md touched by [add-oauth, add-jwt]
166
+
167
+ Checking add-oauth:
168
+ - Delta adds "OAuth Provider Integration" requirement
169
+ - Searching codebase... found src/auth/oauth.ts implementing OAuth flow
170
+
171
+ Checking add-jwt:
172
+ - Delta adds "JWT Token Handling" requirement
173
+ - Searching codebase... no JWT implementation found
174
+
175
+ Resolution: Only add-oauth is implemented. Will sync add-oauth specs only.
176
+ \`\`\`
177
+
178
+ Example 2: Both implemented
179
+ \`\`\`
180
+ Conflict: specs/api/spec.md touched by [add-rest-api, add-graphql]
181
+
182
+ Checking add-rest-api (created 2026-01-10):
183
+ - Delta adds "REST Endpoints" requirement
184
+ - Searching codebase... found src/api/rest.ts
185
+
186
+ Checking add-graphql (created 2026-01-15):
187
+ - Delta adds "GraphQL Schema" requirement
188
+ - Searching codebase... found src/api/graphql.ts
189
+
190
+ Resolution: Both implemented. Will apply add-rest-api specs first,
191
+ then add-graphql specs (chronological order, newer takes precedence).
192
+ \`\`\`
193
+
194
+ **Output On Success**
195
+
196
+ \`\`\`
197
+ ## Bulk Archive Complete
198
+
199
+ Archived N changes:
200
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
201
+ - <change-2> -> archive/YYYY-MM-DD-<change-2>/
202
+
203
+ Spec sync summary:
204
+ - N delta specs synced to main specs
205
+ - No conflicts (or: M conflicts resolved)
206
+ \`\`\`
207
+
208
+ **Output On Partial Success**
209
+
210
+ \`\`\`
211
+ ## Bulk Archive Complete (partial)
212
+
213
+ Archived N changes:
214
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
215
+
216
+ Skipped M changes:
217
+ - <change-2> (user chose not to archive incomplete)
218
+
219
+ Failed K changes:
220
+ - <change-3>: Archive directory already exists
221
+ \`\`\`
222
+
223
+ **Output When No Changes**
224
+
225
+ \`\`\`
226
+ ## No Changes to Archive
227
+
228
+ No active changes found. Create a new change to get started.
229
+ \`\`\`
230
+
231
+ **Guardrails**
232
+ - Allow any number of changes (1+ is fine, 2+ is the typical use case)
233
+ - Always prompt for selection, never auto-select
234
+ - Detect spec conflicts early and resolve by checking codebase
235
+ - When both changes are implemented, apply specs in chronological order
236
+ - Skip spec sync only when implementation is missing (warn user)
237
+ - Show clear per-change status before confirming
238
+ - Use single confirmation for entire batch
239
+ - Track and report all outcomes (success/skip/fail)
240
+ - Preserve .openspec.yaml when moving to archive
241
+ - Archive directory target uses current date: YYYY-MM-DD-<name>
242
+ - If archive target exists, fail that change but continue with others`,
243
+ license: 'MIT',
244
+ compatibility: 'Requires openspec CLI.',
245
+ metadata: { author: 'openspec', version: '1.0' },
246
+ };
247
+ }
248
+ export function getOpsxBulkArchiveCommandTemplate() {
249
+ return {
250
+ name: 'OPSX: Bulk Archive',
251
+ description: 'Archive multiple completed changes at once',
252
+ category: 'Workflow',
253
+ tags: ['workflow', 'archive', 'experimental', 'bulk'],
254
+ content: `Archive multiple completed changes in a single operation.
255
+
256
+ This skill allows you to batch-archive changes, handling spec conflicts intelligently by checking the codebase to determine what's actually implemented.
257
+
258
+ ${STORE_SELECTION_GUIDANCE}
259
+
260
+ **Input**: None required (prompts for selection)
261
+
262
+ **Steps**
263
+
264
+ 1. **Get active changes**
265
+
266
+ Run \`openspec list --json\` to get all active changes.
267
+
268
+ If no active changes exist, inform user and stop.
269
+
270
+ 2. **Prompt for change selection**
271
+
272
+ Use **AskUserQuestion tool** with multi-select to let user choose changes:
273
+ - Show each change with its schema
274
+ - Include an option for "All changes"
275
+ - Allow any number of selections (1+ works, 2+ is the typical use case)
276
+
277
+ **IMPORTANT**: Do NOT auto-select. Always let the user choose.
278
+
279
+ 3. **Batch validation - gather status for all selected changes**
280
+
281
+ For each selected change, collect:
282
+
283
+ a. **Artifact status** - Run \`openspec status --change "<name>" --json\`
284
+ - Parse \`schemaName\`, \`artifacts\`, \`planningHome\`, \`changeRoot\`, \`artifactPaths\`, and \`actionContext\`
285
+ - Note which artifacts are \`done\` vs other states
286
+
287
+ b. **Task completion** - Read \`artifactPaths.tasks.existingOutputPaths\` from status JSON
288
+ - Count \`- [ ]\` (incomplete) vs \`- [x]\` (complete)
289
+ - If no tasks file exists, note as "No tasks"
290
+
291
+ c. **Delta specs** - Check \`artifactPaths.specs.existingOutputPaths\` from status JSON
292
+ - List which capability specs exist
293
+ - For each, extract requirement names (lines matching \`### Requirement: <name>\`)
294
+
295
+ 4. **Detect spec conflicts**
296
+
297
+ Build a map of \`capability -> [changes that touch it]\`:
298
+
299
+ \`\`\`
300
+ auth -> [change-a, change-b] <- CONFLICT (2+ changes)
301
+ api -> [change-c] <- OK (only 1 change)
302
+ \`\`\`
303
+
304
+ A conflict exists when 2+ selected changes have delta specs for the same capability.
305
+
306
+ 5. **Resolve conflicts agentically**
307
+
308
+ **For each conflict**, investigate the codebase:
309
+
310
+ a. **Read the delta specs** from each conflicting change to understand what each claims to add/modify
311
+
312
+ b. **Search the codebase** for implementation evidence:
313
+ - Look for code implementing requirements from each delta spec
314
+ - Check for related files, functions, or tests
315
+
316
+ c. **Determine resolution**:
317
+ - If only one change is actually implemented -> sync that one's specs
318
+ - If both implemented -> apply in chronological order (older first, newer overwrites)
319
+ - If neither implemented -> skip spec sync, warn user
320
+
321
+ d. **Record resolution** for each conflict:
322
+ - Which change's specs to apply
323
+ - In what order (if both)
324
+ - Rationale (what was found in codebase)
325
+
326
+ 6. **Show consolidated status table**
327
+
328
+ Display a table summarizing all changes:
329
+
330
+ \`\`\`
331
+ | Change | Artifacts | Tasks | Specs | Conflicts | Status |
332
+ |---------------------|-----------|-------|---------|-----------|--------|
333
+ | schema-management | Done | 5/5 | 2 delta | None | Ready |
334
+ | project-config | Done | 3/3 | 1 delta | None | Ready |
335
+ | add-oauth | Done | 4/4 | 1 delta | auth (!) | Ready* |
336
+ | add-verify-skill | 1 left | 2/5 | None | None | Warn |
337
+ \`\`\`
338
+
339
+ For conflicts, show the resolution:
340
+ \`\`\`
341
+ * Conflict resolution:
342
+ - auth spec: Will apply add-oauth then add-jwt (both implemented, chronological order)
343
+ \`\`\`
344
+
345
+ For incomplete changes, show warnings:
346
+ \`\`\`
347
+ Warnings:
348
+ - add-verify-skill: 1 incomplete artifact, 3 incomplete tasks
349
+ \`\`\`
350
+
351
+ 7. **Confirm batch operation**
352
+
353
+ Use **AskUserQuestion tool** with a single confirmation:
354
+
355
+ - "Archive N changes?" with options based on status
356
+ - Options might include:
357
+ - "Archive all N changes"
358
+ - "Archive only N ready changes (skip incomplete)"
359
+ - "Cancel"
360
+
361
+ If there are incomplete changes, make clear they'll be archived with warnings.
362
+
363
+ 8. **Execute archive for each confirmed change**
364
+
365
+ Process changes in the determined order (respecting conflict resolution):
366
+
367
+ a. **Sync specs** if delta specs exist:
368
+ - Use the openspec-sync-specs approach (agent-driven intelligent merge)
369
+ - For conflicts, apply in resolved order
370
+ - Track if sync was done
371
+
372
+ b. **Perform the archive**:
373
+ \`\`\`bash
374
+ mkdir -p "<planningHome.changesDir>/archive"
375
+ mv "<changeRoot>" "<planningHome.changesDir>/archive/YYYY-MM-DD-<name>"
376
+ \`\`\`
377
+
378
+ c. **Track outcome** for each change:
379
+ - Success: archived successfully
380
+ - Failed: error during archive (record error)
381
+ - Skipped: user chose not to archive (if applicable)
382
+
383
+ 9. **Display summary**
384
+
385
+ Show final results:
386
+
387
+ \`\`\`
388
+ ## Bulk Archive Complete
389
+
390
+ Archived 3 changes:
391
+ - schema-management-cli -> archive/2026-01-19-schema-management-cli/
392
+ - project-config -> archive/2026-01-19-project-config/
393
+ - add-oauth -> archive/2026-01-19-add-oauth/
394
+
395
+ Skipped 1 change:
396
+ - add-verify-skill (user chose not to archive incomplete)
397
+
398
+ Spec sync summary:
399
+ - 4 delta specs synced to main specs
400
+ - 1 conflict resolved (auth: applied both in chronological order)
401
+ \`\`\`
402
+
403
+ If any failures:
404
+ \`\`\`
405
+ Failed 1 change:
406
+ - some-change: Archive directory already exists
407
+ \`\`\`
408
+
409
+ **Conflict Resolution Examples**
410
+
411
+ Example 1: Only one implemented
412
+ \`\`\`
413
+ Conflict: specs/auth/spec.md touched by [add-oauth, add-jwt]
414
+
415
+ Checking add-oauth:
416
+ - Delta adds "OAuth Provider Integration" requirement
417
+ - Searching codebase... found src/auth/oauth.ts implementing OAuth flow
418
+
419
+ Checking add-jwt:
420
+ - Delta adds "JWT Token Handling" requirement
421
+ - Searching codebase... no JWT implementation found
422
+
423
+ Resolution: Only add-oauth is implemented. Will sync add-oauth specs only.
424
+ \`\`\`
425
+
426
+ Example 2: Both implemented
427
+ \`\`\`
428
+ Conflict: specs/api/spec.md touched by [add-rest-api, add-graphql]
429
+
430
+ Checking add-rest-api (created 2026-01-10):
431
+ - Delta adds "REST Endpoints" requirement
432
+ - Searching codebase... found src/api/rest.ts
433
+
434
+ Checking add-graphql (created 2026-01-15):
435
+ - Delta adds "GraphQL Schema" requirement
436
+ - Searching codebase... found src/api/graphql.ts
437
+
438
+ Resolution: Both implemented. Will apply add-rest-api specs first,
439
+ then add-graphql specs (chronological order, newer takes precedence).
440
+ \`\`\`
441
+
442
+ **Output On Success**
443
+
444
+ \`\`\`
445
+ ## Bulk Archive Complete
446
+
447
+ Archived N changes:
448
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
449
+ - <change-2> -> archive/YYYY-MM-DD-<change-2>/
450
+
451
+ Spec sync summary:
452
+ - N delta specs synced to main specs
453
+ - No conflicts (or: M conflicts resolved)
454
+ \`\`\`
455
+
456
+ **Output On Partial Success**
457
+
458
+ \`\`\`
459
+ ## Bulk Archive Complete (partial)
460
+
461
+ Archived N changes:
462
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
463
+
464
+ Skipped M changes:
465
+ - <change-2> (user chose not to archive incomplete)
466
+
467
+ Failed K changes:
468
+ - <change-3>: Archive directory already exists
469
+ \`\`\`
470
+
471
+ **Output When No Changes**
472
+
473
+ \`\`\`
474
+ ## No Changes to Archive
475
+
476
+ No active changes found. Create a new change to get started.
477
+ \`\`\`
478
+
479
+ **Guardrails**
480
+ - Allow any number of changes (1+ is fine, 2+ is the typical use case)
481
+ - Always prompt for selection, never auto-select
482
+ - Detect spec conflicts early and resolve by checking codebase
483
+ - When both changes are implemented, apply specs in chronological order
484
+ - Skip spec sync only when implementation is missing (warn user)
485
+ - Show clear per-change status before confirming
486
+ - Use single confirmation for entire batch
487
+ - Track and report all outcomes (success/skip/fail)
488
+ - Preserve .openspec.yaml when moving to archive
489
+ - Archive directory target uses current date: YYYY-MM-DD-<name>
490
+ - If archive target exists, fail that change but continue with others`
491
+ };
492
+ }
493
+ //# sourceMappingURL=bulk-archive-change.js.map
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Comprehension quiz guidance for apply workflows.
3
+ *
4
+ * Interpolated into apply skill and slash command templates so agents run
5
+ * a spec comprehension gate before implementation.
6
+ */
7
+ export declare const COMPREHENSION_QUIZ_GUIDANCE = "4. **Comprehension quiz (required before implementation)**\n\n After `openspec instructions apply --change \"<name>\" --json`, check comprehension status:\n\n - If `missingComprehension` is true OR `comprehension.required && !comprehension.passed`:\n - Do NOT edit application source code or mark task checkboxes yet\n - Read `contextFiles.specs`, `contextFiles.tasks` (or the `tasks` array in apply JSON), and `contextFiles.design` (design for distractors only)\n - Use `comprehension.questionCount` from the JSON as the number of questions\n\n **Generate questions**\n - Create exactly `comprehension.questionCount` multiple-choice questions\n - Each question MUST map to one of:\n - a `### Requirement:` or `#### Scenario:` from delta specs, OR\n - a pending (unchecked) task from `tasks.md` / the apply `tasks` array\n - When both specs and pending tasks exist, include at least 2 task-based questions and cover the rest from specs/scenarios\n - Do NOT use completed tasks as question sources\n - Each question: 4 options (1 correct from the source item, 3 plausible distractors from other requirements/scenarios/tasks in the change)\n\n **Present and grade**\n - Use the **AskUserQuestion tool** for each question (one at a time)\n - Grade: `score_percent = round(correct / question_count * 100)`\n - Pass when `score_percent >= comprehension.thresholdPercent` (default 80)\n\n **On failure (score below threshold)**\n - Announce score and that a new quiz is required\n - Update `.comprehension-session.yaml` in the change dir with `used_sources` from this attempt\n - Generate a NEW question set using different requirement/scenario/task sources (avoid `used_sources`)\n - Retry until pass\n\n **On pass**\n ```bash\n openspec instructions apply --change \"<name>\" --record-comprehension-pass --score <score> --attempt <n> --question-count <count> --json\n ```\n - Re-run `openspec instructions apply --change \"<name>\" --json`\n - Confirm `state` is `\"ready\"` and `comprehension.passed` is true before continuing\n\n **Output template**\n ```\n ## Applying: <change-name> \u2014 comprehension check\n\n Specs: <requirementCount> requirements, <scenarioCount> scenarios; Tasks: <pendingTaskCount> pending \u2192 <questionCount> questions\n\n Question 1/N: ...\n ...\n \u2713 Comprehension passed (<score>%, attempt <n>)\n ```\n\n Then continue to step 5 (show progress) and implementation.";
8
+ export declare const COMPREHENSION_APPLY_GUARDRAIL = "- NEVER implement code or mark tasks while `missingComprehension` is true\n- NEVER skip the comprehension quiz when the apply JSON requires it\n- If the user asks to skip the quiz, refuse and explain they must pass or set comprehension.enabled: false in openspec/config.yaml";
9
+ //# sourceMappingURL=comprehension-guidance.d.ts.map
@@ -0,0 +1,58 @@
1
+ /**
2
+ * Comprehension quiz guidance for apply workflows.
3
+ *
4
+ * Interpolated into apply skill and slash command templates so agents run
5
+ * a spec comprehension gate before implementation.
6
+ */
7
+ export const COMPREHENSION_QUIZ_GUIDANCE = `4. **Comprehension quiz (required before implementation)**
8
+
9
+ After \`openspec instructions apply --change "<name>" --json\`, check comprehension status:
10
+
11
+ - If \`missingComprehension\` is true OR \`comprehension.required && !comprehension.passed\`:
12
+ - Do NOT edit application source code or mark task checkboxes yet
13
+ - Read \`contextFiles.specs\`, \`contextFiles.tasks\` (or the \`tasks\` array in apply JSON), and \`contextFiles.design\` (design for distractors only)
14
+ - Use \`comprehension.questionCount\` from the JSON as the number of questions
15
+
16
+ **Generate questions**
17
+ - Create exactly \`comprehension.questionCount\` multiple-choice questions
18
+ - Each question MUST map to one of:
19
+ - a \`### Requirement:\` or \`#### Scenario:\` from delta specs, OR
20
+ - a pending (unchecked) task from \`tasks.md\` / the apply \`tasks\` array
21
+ - When both specs and pending tasks exist, include at least 2 task-based questions and cover the rest from specs/scenarios
22
+ - Do NOT use completed tasks as question sources
23
+ - Each question: 4 options (1 correct from the source item, 3 plausible distractors from other requirements/scenarios/tasks in the change)
24
+
25
+ **Present and grade**
26
+ - Use the **AskUserQuestion tool** for each question (one at a time)
27
+ - Grade: \`score_percent = round(correct / question_count * 100)\`
28
+ - Pass when \`score_percent >= comprehension.thresholdPercent\` (default 80)
29
+
30
+ **On failure (score below threshold)**
31
+ - Announce score and that a new quiz is required
32
+ - Update \`.comprehension-session.yaml\` in the change dir with \`used_sources\` from this attempt
33
+ - Generate a NEW question set using different requirement/scenario/task sources (avoid \`used_sources\`)
34
+ - Retry until pass
35
+
36
+ **On pass**
37
+ \`\`\`bash
38
+ openspec instructions apply --change "<name>" --record-comprehension-pass --score <score> --attempt <n> --question-count <count> --json
39
+ \`\`\`
40
+ - Re-run \`openspec instructions apply --change "<name>" --json\`
41
+ - Confirm \`state\` is \`"ready"\` and \`comprehension.passed\` is true before continuing
42
+
43
+ **Output template**
44
+ \`\`\`
45
+ ## Applying: <change-name> — comprehension check
46
+
47
+ Specs: <requirementCount> requirements, <scenarioCount> scenarios; Tasks: <pendingTaskCount> pending → <questionCount> questions
48
+
49
+ Question 1/N: ...
50
+ ...
51
+ ✓ Comprehension passed (<score>%, attempt <n>)
52
+ \`\`\`
53
+
54
+ Then continue to step 5 (show progress) and implementation.`;
55
+ export const COMPREHENSION_APPLY_GUARDRAIL = `- NEVER implement code or mark tasks while \`missingComprehension\` is true
56
+ - NEVER skip the comprehension quiz when the apply JSON requires it
57
+ - If the user asks to skip the quiz, refuse and explain they must pass or set comprehension.enabled: false in openspec/config.yaml`;
58
+ //# sourceMappingURL=comprehension-guidance.js.map
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Skill Template Workflow Modules
3
+ *
4
+ * This file is generated by splitting the legacy monolithic
5
+ * templates file into workflow-focused modules.
6
+ */
7
+ import type { SkillTemplate, CommandTemplate } from '../types.js';
8
+ export declare function getContinueChangeSkillTemplate(): SkillTemplate;
9
+ export declare function getOpsxContinueCommandTemplate(): CommandTemplate;
10
+ //# sourceMappingURL=continue-change.d.ts.map