@ias-ai/zhima-spec 1.3.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 (307) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +206 -0
  3. package/bin/zhima.js +3 -0
  4. package/dist/cli/index.d.ts +2 -0
  5. package/dist/cli/index.js +462 -0
  6. package/dist/commands/change.d.ts +35 -0
  7. package/dist/commands/change.js +277 -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 +611 -0
  12. package/dist/commands/feedback.d.ts +9 -0
  13. package/dist/commands/feedback.js +183 -0
  14. package/dist/commands/schema.d.ts +6 -0
  15. package/dist/commands/schema.js +869 -0
  16. package/dist/commands/show.d.ts +14 -0
  17. package/dist/commands/show.js +132 -0
  18. package/dist/commands/spec.d.ts +15 -0
  19. package/dist/commands/spec.js +225 -0
  20. package/dist/commands/validate.d.ts +24 -0
  21. package/dist/commands/validate.js +294 -0
  22. package/dist/commands/workflow/index.d.ts +17 -0
  23. package/dist/commands/workflow/index.js +12 -0
  24. package/dist/commands/workflow/instructions.d.ts +29 -0
  25. package/dist/commands/workflow/instructions.js +336 -0
  26. package/dist/commands/workflow/new-change.d.ts +13 -0
  27. package/dist/commands/workflow/new-change.js +92 -0
  28. package/dist/commands/workflow/schemas.d.ts +10 -0
  29. package/dist/commands/workflow/schemas.js +34 -0
  30. package/dist/commands/workflow/shared.d.ts +57 -0
  31. package/dist/commands/workflow/shared.js +116 -0
  32. package/dist/commands/workflow/status.d.ts +14 -0
  33. package/dist/commands/workflow/status.js +87 -0
  34. package/dist/commands/workflow/templates.d.ts +16 -0
  35. package/dist/commands/workflow/templates.js +69 -0
  36. package/dist/commands/workspace/open.d.ts +29 -0
  37. package/dist/commands/workspace/open.js +84 -0
  38. package/dist/commands/workspace/operations.d.ts +23 -0
  39. package/dist/commands/workspace/operations.js +475 -0
  40. package/dist/commands/workspace/selection.d.ts +6 -0
  41. package/dist/commands/workspace/selection.js +113 -0
  42. package/dist/commands/workspace/types.d.ts +88 -0
  43. package/dist/commands/workspace/types.js +36 -0
  44. package/dist/commands/workspace.d.ts +6 -0
  45. package/dist/commands/workspace.js +868 -0
  46. package/dist/core/archive.d.ts +11 -0
  47. package/dist/core/archive.js +318 -0
  48. package/dist/core/artifact-graph/graph.d.ts +56 -0
  49. package/dist/core/artifact-graph/graph.js +141 -0
  50. package/dist/core/artifact-graph/index.d.ts +8 -0
  51. package/dist/core/artifact-graph/index.js +14 -0
  52. package/dist/core/artifact-graph/instruction-loader.d.ts +196 -0
  53. package/dist/core/artifact-graph/instruction-loader.js +317 -0
  54. package/dist/core/artifact-graph/outputs.d.ts +14 -0
  55. package/dist/core/artifact-graph/outputs.js +39 -0
  56. package/dist/core/artifact-graph/resolver.d.ts +81 -0
  57. package/dist/core/artifact-graph/resolver.js +257 -0
  58. package/dist/core/artifact-graph/schema.d.ts +13 -0
  59. package/dist/core/artifact-graph/schema.js +108 -0
  60. package/dist/core/artifact-graph/state.d.ts +12 -0
  61. package/dist/core/artifact-graph/state.js +31 -0
  62. package/dist/core/artifact-graph/types.d.ts +47 -0
  63. package/dist/core/artifact-graph/types.js +48 -0
  64. package/dist/core/available-tools.d.ts +17 -0
  65. package/dist/core/available-tools.js +43 -0
  66. package/dist/core/command-generation/adapters/amazon-q.d.ts +13 -0
  67. package/dist/core/command-generation/adapters/amazon-q.js +26 -0
  68. package/dist/core/command-generation/adapters/antigravity.d.ts +13 -0
  69. package/dist/core/command-generation/adapters/antigravity.js +26 -0
  70. package/dist/core/command-generation/adapters/auggie.d.ts +13 -0
  71. package/dist/core/command-generation/adapters/auggie.js +27 -0
  72. package/dist/core/command-generation/adapters/bob.d.ts +14 -0
  73. package/dist/core/command-generation/adapters/bob.js +45 -0
  74. package/dist/core/command-generation/adapters/claude.d.ts +13 -0
  75. package/dist/core/command-generation/adapters/claude.js +50 -0
  76. package/dist/core/command-generation/adapters/cline.d.ts +14 -0
  77. package/dist/core/command-generation/adapters/cline.js +27 -0
  78. package/dist/core/command-generation/adapters/codebuddy.d.ts +13 -0
  79. package/dist/core/command-generation/adapters/codebuddy.js +28 -0
  80. package/dist/core/command-generation/adapters/codex.d.ts +16 -0
  81. package/dist/core/command-generation/adapters/codex.js +39 -0
  82. package/dist/core/command-generation/adapters/continue.d.ts +13 -0
  83. package/dist/core/command-generation/adapters/continue.js +28 -0
  84. package/dist/core/command-generation/adapters/costrict.d.ts +13 -0
  85. package/dist/core/command-generation/adapters/costrict.js +27 -0
  86. package/dist/core/command-generation/adapters/crush.d.ts +13 -0
  87. package/dist/core/command-generation/adapters/crush.js +30 -0
  88. package/dist/core/command-generation/adapters/cursor.d.ts +14 -0
  89. package/dist/core/command-generation/adapters/cursor.js +44 -0
  90. package/dist/core/command-generation/adapters/factory.d.ts +13 -0
  91. package/dist/core/command-generation/adapters/factory.js +27 -0
  92. package/dist/core/command-generation/adapters/gemini.d.ts +13 -0
  93. package/dist/core/command-generation/adapters/gemini.js +26 -0
  94. package/dist/core/command-generation/adapters/github-copilot.d.ts +13 -0
  95. package/dist/core/command-generation/adapters/github-copilot.js +26 -0
  96. package/dist/core/command-generation/adapters/iflow.d.ts +13 -0
  97. package/dist/core/command-generation/adapters/iflow.js +29 -0
  98. package/dist/core/command-generation/adapters/index.d.ts +33 -0
  99. package/dist/core/command-generation/adapters/index.js +33 -0
  100. package/dist/core/command-generation/adapters/junie.d.ts +13 -0
  101. package/dist/core/command-generation/adapters/junie.js +26 -0
  102. package/dist/core/command-generation/adapters/kilocode.d.ts +14 -0
  103. package/dist/core/command-generation/adapters/kilocode.js +23 -0
  104. package/dist/core/command-generation/adapters/kiro.d.ts +13 -0
  105. package/dist/core/command-generation/adapters/kiro.js +26 -0
  106. package/dist/core/command-generation/adapters/lingma.d.ts +13 -0
  107. package/dist/core/command-generation/adapters/lingma.js +30 -0
  108. package/dist/core/command-generation/adapters/opencode.d.ts +13 -0
  109. package/dist/core/command-generation/adapters/opencode.js +29 -0
  110. package/dist/core/command-generation/adapters/pi.d.ts +18 -0
  111. package/dist/core/command-generation/adapters/pi.js +55 -0
  112. package/dist/core/command-generation/adapters/qoder.d.ts +13 -0
  113. package/dist/core/command-generation/adapters/qoder.js +30 -0
  114. package/dist/core/command-generation/adapters/qwen.d.ts +13 -0
  115. package/dist/core/command-generation/adapters/qwen.js +26 -0
  116. package/dist/core/command-generation/adapters/roocode.d.ts +14 -0
  117. package/dist/core/command-generation/adapters/roocode.js +27 -0
  118. package/dist/core/command-generation/adapters/vjsp.d.ts +13 -0
  119. package/dist/core/command-generation/adapters/vjsp.js +27 -0
  120. package/dist/core/command-generation/adapters/windsurf.d.ts +14 -0
  121. package/dist/core/command-generation/adapters/windsurf.js +51 -0
  122. package/dist/core/command-generation/generator.d.ts +21 -0
  123. package/dist/core/command-generation/generator.js +27 -0
  124. package/dist/core/command-generation/index.d.ts +22 -0
  125. package/dist/core/command-generation/index.js +24 -0
  126. package/dist/core/command-generation/registry.d.ts +36 -0
  127. package/dist/core/command-generation/registry.js +98 -0
  128. package/dist/core/command-generation/types.d.ts +56 -0
  129. package/dist/core/command-generation/types.js +8 -0
  130. package/dist/core/completions/command-registry.d.ts +7 -0
  131. package/dist/core/completions/command-registry.js +626 -0
  132. package/dist/core/completions/completion-provider.d.ts +71 -0
  133. package/dist/core/completions/completion-provider.js +129 -0
  134. package/dist/core/completions/factory.d.ts +64 -0
  135. package/dist/core/completions/factory.js +75 -0
  136. package/dist/core/completions/generators/bash-generator.d.ts +35 -0
  137. package/dist/core/completions/generators/bash-generator.js +230 -0
  138. package/dist/core/completions/generators/fish-generator.d.ts +32 -0
  139. package/dist/core/completions/generators/fish-generator.js +160 -0
  140. package/dist/core/completions/generators/powershell-generator.d.ts +36 -0
  141. package/dist/core/completions/generators/powershell-generator.js +266 -0
  142. package/dist/core/completions/generators/zsh-generator.d.ts +47 -0
  143. package/dist/core/completions/generators/zsh-generator.js +274 -0
  144. package/dist/core/completions/installers/bash-installer.d.ts +87 -0
  145. package/dist/core/completions/installers/bash-installer.js +318 -0
  146. package/dist/core/completions/installers/fish-installer.d.ts +43 -0
  147. package/dist/core/completions/installers/fish-installer.js +143 -0
  148. package/dist/core/completions/installers/powershell-installer.d.ts +102 -0
  149. package/dist/core/completions/installers/powershell-installer.js +387 -0
  150. package/dist/core/completions/installers/zsh-installer.d.ts +117 -0
  151. package/dist/core/completions/installers/zsh-installer.js +421 -0
  152. package/dist/core/completions/templates/bash-templates.d.ts +6 -0
  153. package/dist/core/completions/templates/bash-templates.js +30 -0
  154. package/dist/core/completions/templates/fish-templates.d.ts +7 -0
  155. package/dist/core/completions/templates/fish-templates.js +45 -0
  156. package/dist/core/completions/templates/powershell-templates.d.ts +6 -0
  157. package/dist/core/completions/templates/powershell-templates.js +34 -0
  158. package/dist/core/completions/templates/zsh-templates.d.ts +6 -0
  159. package/dist/core/completions/templates/zsh-templates.js +45 -0
  160. package/dist/core/completions/types.d.ts +101 -0
  161. package/dist/core/completions/types.js +2 -0
  162. package/dist/core/config-prompts.d.ts +9 -0
  163. package/dist/core/config-prompts.js +34 -0
  164. package/dist/core/config-schema.d.ts +86 -0
  165. package/dist/core/config-schema.js +213 -0
  166. package/dist/core/config.d.ts +18 -0
  167. package/dist/core/config.js +39 -0
  168. package/dist/core/converters/json-converter.d.ts +6 -0
  169. package/dist/core/converters/json-converter.js +51 -0
  170. package/dist/core/global-config.d.ts +49 -0
  171. package/dist/core/global-config.js +124 -0
  172. package/dist/core/index.d.ts +4 -0
  173. package/dist/core/index.js +5 -0
  174. package/dist/core/init.d.ts +37 -0
  175. package/dist/core/init.js +593 -0
  176. package/dist/core/legacy-cleanup.d.ts +162 -0
  177. package/dist/core/legacy-cleanup.js +514 -0
  178. package/dist/core/list.d.ts +9 -0
  179. package/dist/core/list.js +171 -0
  180. package/dist/core/migration.d.ts +23 -0
  181. package/dist/core/migration.js +108 -0
  182. package/dist/core/parsers/change-parser.d.ts +13 -0
  183. package/dist/core/parsers/change-parser.js +197 -0
  184. package/dist/core/parsers/markdown-parser.d.ts +26 -0
  185. package/dist/core/parsers/markdown-parser.js +227 -0
  186. package/dist/core/parsers/requirement-blocks.d.ts +37 -0
  187. package/dist/core/parsers/requirement-blocks.js +201 -0
  188. package/dist/core/parsers/spec-structure.d.ts +9 -0
  189. package/dist/core/parsers/spec-structure.js +88 -0
  190. package/dist/core/planning-home.d.ts +21 -0
  191. package/dist/core/planning-home.js +124 -0
  192. package/dist/core/profile-sync-drift.d.ts +38 -0
  193. package/dist/core/profile-sync-drift.js +200 -0
  194. package/dist/core/profiles.d.ts +26 -0
  195. package/dist/core/profiles.js +40 -0
  196. package/dist/core/project-config.d.ts +64 -0
  197. package/dist/core/project-config.js +223 -0
  198. package/dist/core/schemas/base.schema.d.ts +13 -0
  199. package/dist/core/schemas/base.schema.js +13 -0
  200. package/dist/core/schemas/change.schema.d.ts +73 -0
  201. package/dist/core/schemas/change.schema.js +31 -0
  202. package/dist/core/schemas/index.d.ts +4 -0
  203. package/dist/core/schemas/index.js +4 -0
  204. package/dist/core/schemas/spec.schema.d.ts +18 -0
  205. package/dist/core/schemas/spec.schema.js +15 -0
  206. package/dist/core/shared/index.d.ts +8 -0
  207. package/dist/core/shared/index.js +8 -0
  208. package/dist/core/shared/skill-generation.d.ts +49 -0
  209. package/dist/core/shared/skill-generation.js +96 -0
  210. package/dist/core/shared/tool-detection.d.ts +71 -0
  211. package/dist/core/shared/tool-detection.js +158 -0
  212. package/dist/core/specs-apply.d.ts +73 -0
  213. package/dist/core/specs-apply.js +392 -0
  214. package/dist/core/styles/palette.d.ts +7 -0
  215. package/dist/core/styles/palette.js +8 -0
  216. package/dist/core/templates/index.d.ts +8 -0
  217. package/dist/core/templates/index.js +9 -0
  218. package/dist/core/templates/skill-templates.d.ts +19 -0
  219. package/dist/core/templates/skill-templates.js +18 -0
  220. package/dist/core/templates/types.d.ts +19 -0
  221. package/dist/core/templates/types.js +5 -0
  222. package/dist/core/templates/workflows/apply-change.d.ts +10 -0
  223. package/dist/core/templates/workflows/apply-change.js +314 -0
  224. package/dist/core/templates/workflows/archive-change.d.ts +10 -0
  225. package/dist/core/templates/workflows/archive-change.js +277 -0
  226. package/dist/core/templates/workflows/bulk-archive-change.d.ts +10 -0
  227. package/dist/core/templates/workflows/bulk-archive-change.js +492 -0
  228. package/dist/core/templates/workflows/continue-change.d.ts +10 -0
  229. package/dist/core/templates/workflows/continue-change.js +234 -0
  230. package/dist/core/templates/workflows/explore.d.ts +10 -0
  231. package/dist/core/templates/workflows/explore.js +459 -0
  232. package/dist/core/templates/workflows/feedback.d.ts +9 -0
  233. package/dist/core/templates/workflows/feedback.js +108 -0
  234. package/dist/core/templates/workflows/ff-change.d.ts +10 -0
  235. package/dist/core/templates/workflows/ff-change.js +200 -0
  236. package/dist/core/templates/workflows/new-change.d.ts +10 -0
  237. package/dist/core/templates/workflows/new-change.js +143 -0
  238. package/dist/core/templates/workflows/onboard.d.ts +10 -0
  239. package/dist/core/templates/workflows/onboard.js +563 -0
  240. package/dist/core/templates/workflows/propose.d.ts +10 -0
  241. package/dist/core/templates/workflows/propose.js +218 -0
  242. package/dist/core/templates/workflows/sync-specs.d.ts +10 -0
  243. package/dist/core/templates/workflows/sync-specs.js +290 -0
  244. package/dist/core/templates/workflows/verify-change.d.ts +10 -0
  245. package/dist/core/templates/workflows/verify-change.js +338 -0
  246. package/dist/core/update.d.ts +82 -0
  247. package/dist/core/update.js +557 -0
  248. package/dist/core/validation/constants.d.ts +34 -0
  249. package/dist/core/validation/constants.js +40 -0
  250. package/dist/core/validation/types.d.ts +18 -0
  251. package/dist/core/validation/types.js +2 -0
  252. package/dist/core/validation/validator.d.ts +33 -0
  253. package/dist/core/validation/validator.js +418 -0
  254. package/dist/core/view.d.ts +8 -0
  255. package/dist/core/view.js +168 -0
  256. package/dist/core/workspace/foundation.d.ts +87 -0
  257. package/dist/core/workspace/foundation.js +379 -0
  258. package/dist/core/workspace/index.d.ts +6 -0
  259. package/dist/core/workspace/index.js +6 -0
  260. package/dist/core/workspace/link-input.d.ts +9 -0
  261. package/dist/core/workspace/link-input.js +32 -0
  262. package/dist/core/workspace/open-surface.d.ts +24 -0
  263. package/dist/core/workspace/open-surface.js +137 -0
  264. package/dist/core/workspace/openers.d.ts +21 -0
  265. package/dist/core/workspace/openers.js +119 -0
  266. package/dist/core/workspace/skills.d.ts +55 -0
  267. package/dist/core/workspace/skills.js +334 -0
  268. package/dist/index.d.ts +3 -0
  269. package/dist/index.js +3 -0
  270. package/dist/prompts/searchable-multi-select.d.ts +28 -0
  271. package/dist/prompts/searchable-multi-select.js +159 -0
  272. package/dist/ui/ascii-patterns.d.ts +16 -0
  273. package/dist/ui/ascii-patterns.js +133 -0
  274. package/dist/ui/welcome-screen.d.ts +10 -0
  275. package/dist/ui/welcome-screen.js +146 -0
  276. package/dist/utils/change-metadata.d.ts +51 -0
  277. package/dist/utils/change-metadata.js +147 -0
  278. package/dist/utils/change-utils.d.ts +71 -0
  279. package/dist/utils/change-utils.js +123 -0
  280. package/dist/utils/command-references.d.ts +18 -0
  281. package/dist/utils/command-references.js +20 -0
  282. package/dist/utils/file-system.d.ts +41 -0
  283. package/dist/utils/file-system.js +301 -0
  284. package/dist/utils/index.d.ts +6 -0
  285. package/dist/utils/index.js +9 -0
  286. package/dist/utils/interactive.d.ts +18 -0
  287. package/dist/utils/interactive.js +21 -0
  288. package/dist/utils/item-discovery.d.ts +4 -0
  289. package/dist/utils/item-discovery.js +72 -0
  290. package/dist/utils/match.d.ts +3 -0
  291. package/dist/utils/match.js +22 -0
  292. package/dist/utils/shell-detection.d.ts +20 -0
  293. package/dist/utils/shell-detection.js +41 -0
  294. package/dist/utils/task-progress.d.ts +8 -0
  295. package/dist/utils/task-progress.js +36 -0
  296. package/package.json +82 -0
  297. package/schemas/spec-driven/schema.yaml +153 -0
  298. package/schemas/spec-driven/templates/design.md +19 -0
  299. package/schemas/spec-driven/templates/proposal.md +23 -0
  300. package/schemas/spec-driven/templates/spec.md +8 -0
  301. package/schemas/spec-driven/templates/tasks.md +9 -0
  302. package/schemas/workspace-planning/schema.yaml +72 -0
  303. package/schemas/workspace-planning/templates/design.md +33 -0
  304. package/schemas/workspace-planning/templates/proposal.md +28 -0
  305. package/schemas/workspace-planning/templates/spec.md +9 -0
  306. package/schemas/workspace-planning/templates/tasks.md +15 -0
  307. package/scripts/postinstall.js +83 -0
@@ -0,0 +1,462 @@
1
+ import { Command } from 'commander';
2
+ import { createRequire } from 'module';
3
+ import ora from 'ora';
4
+ import path from 'path';
5
+ import { promises as fs } from 'fs';
6
+ import { AI_TOOLS } from '../core/config.js';
7
+ import { UpdateCommand } from '../core/update.js';
8
+ import { ListCommand } from '../core/list.js';
9
+ import { ArchiveCommand } from '../core/archive.js';
10
+ import { ViewCommand } from '../core/view.js';
11
+ import { registerSpecCommand } from '../commands/spec.js';
12
+ import { ChangeCommand } from '../commands/change.js';
13
+ import { ValidateCommand } from '../commands/validate.js';
14
+ import { ShowCommand } from '../commands/show.js';
15
+ import { CompletionCommand } from '../commands/completion.js';
16
+ import { FeedbackCommand } from '../commands/feedback.js';
17
+ import { registerConfigCommand } from '../commands/config.js';
18
+ import { registerSchemaCommand } from '../commands/schema.js';
19
+ import { registerWorkspaceCommand, runWorkspaceUpdateForRoot, } from '../commands/workspace.js';
20
+ import { findWorkspaceRoot } from '../core/workspace/index.js';
21
+ import { statusCommand, instructionsCommand, applyInstructionsCommand, templatesCommand, schemasCommand, newChangeCommand, DEFAULT_SCHEMA, } from '../commands/workflow/index.js';
22
+ const program = new Command();
23
+ const require = createRequire(import.meta.url);
24
+ const { version } = require('../../package.json');
25
+ program
26
+ .name('zhima')
27
+ .description('AI-native system development flow')
28
+ .version(version);
29
+ // Global options
30
+ program.option('--no-color', 'Disable color output');
31
+ // Apply global flags before any command runs
32
+ program.hook('preAction', (thisCommand) => {
33
+ const opts = thisCommand.opts();
34
+ if (opts.color === false) {
35
+ process.env.NO_COLOR = '1';
36
+ }
37
+ });
38
+ const availableToolIds = AI_TOOLS.filter((tool) => tool.skillsDir).map((tool) => tool.value);
39
+ const toolsOptionDescription = `Configure AI tools non-interactively. Use "all", "none", or a comma-separated list of: ${availableToolIds.join(', ')}`;
40
+ program
41
+ .command('init [path]')
42
+ .description('Initialize ZhiMa in your project')
43
+ .option('--tools <tools>', toolsOptionDescription)
44
+ .option('--force', 'Auto-cleanup legacy files without prompting')
45
+ .option('--profile <profile>', 'Override global config profile (core or custom)')
46
+ .action(async (targetPath = '.', options) => {
47
+ try {
48
+ // Validate that the path is a valid directory
49
+ const resolvedPath = path.resolve(targetPath);
50
+ try {
51
+ const stats = await fs.stat(resolvedPath);
52
+ if (!stats.isDirectory()) {
53
+ throw new Error(`Path "${targetPath}" is not a directory`);
54
+ }
55
+ }
56
+ catch (error) {
57
+ if (error.code === 'ENOENT') {
58
+ // Directory doesn't exist, but we can create it
59
+ console.log(`Directory "${targetPath}" doesn't exist, it will be created.`);
60
+ }
61
+ else if (error.message && error.message.includes('not a directory')) {
62
+ throw error;
63
+ }
64
+ else {
65
+ throw new Error(`Cannot access path "${targetPath}": ${error.message}`);
66
+ }
67
+ }
68
+ const { InitCommand } = await import('../core/init.js');
69
+ const initCommand = new InitCommand({
70
+ tools: options?.tools,
71
+ force: options?.force,
72
+ profile: options?.profile,
73
+ });
74
+ await initCommand.execute(targetPath);
75
+ }
76
+ catch (error) {
77
+ console.log(); // Empty line for spacing
78
+ ora().fail(`Error: ${error.message}`);
79
+ process.exit(1);
80
+ }
81
+ });
82
+ // Hidden alias: 'experimental' -> 'init' for backwards compatibility
83
+ program
84
+ .command('experimental', { hidden: true })
85
+ .description('Alias for init (deprecated)')
86
+ .option('--tool <tool-id>', 'Target AI tool (maps to --tools)')
87
+ .option('--no-interactive', 'Disable interactive prompts')
88
+ .action(async (options) => {
89
+ try {
90
+ console.log('Note: "zhima experimental" is deprecated. Use "zhima init" instead.');
91
+ const { InitCommand } = await import('../core/init.js');
92
+ const initCommand = new InitCommand({
93
+ tools: options?.tool,
94
+ interactive: options?.noInteractive === true ? false : undefined,
95
+ });
96
+ await initCommand.execute('.');
97
+ }
98
+ catch (error) {
99
+ console.log();
100
+ ora().fail(`Error: ${error.message}`);
101
+ process.exit(1);
102
+ }
103
+ });
104
+ program
105
+ .command('update [path]')
106
+ .description('Update ZhiMa instruction files')
107
+ .option('--force', 'Force update even when tools are up to date')
108
+ .action(async (targetPath = '.', options) => {
109
+ try {
110
+ const resolvedPath = path.resolve(targetPath);
111
+ const workspaceRoot = await findWorkspaceRoot(resolvedPath);
112
+ if (workspaceRoot) {
113
+ await runWorkspaceUpdateForRoot(workspaceRoot, { force: options?.force });
114
+ return;
115
+ }
116
+ const updateCommand = new UpdateCommand({ force: options?.force });
117
+ await updateCommand.execute(resolvedPath);
118
+ }
119
+ catch (error) {
120
+ console.log(); // Empty line for spacing
121
+ ora().fail(`Error: ${error.message}`);
122
+ process.exit(1);
123
+ }
124
+ });
125
+ program
126
+ .command('list')
127
+ .description('List items (changes by default). Use --specs to list specs.')
128
+ .option('--specs', 'List specs instead of changes')
129
+ .option('--changes', 'List changes explicitly (default)')
130
+ .option('--sort <order>', 'Sort order: "recent" (default) or "name"', 'recent')
131
+ .option('--json', 'Output as JSON (for programmatic use)')
132
+ .action(async (options) => {
133
+ try {
134
+ const listCommand = new ListCommand();
135
+ const mode = options?.specs ? 'specs' : 'changes';
136
+ const sort = options?.sort === 'name' ? 'name' : 'recent';
137
+ await listCommand.execute('.', mode, { sort, json: options?.json });
138
+ }
139
+ catch (error) {
140
+ console.log(); // Empty line for spacing
141
+ ora().fail(`Error: ${error.message}`);
142
+ process.exit(1);
143
+ }
144
+ });
145
+ program
146
+ .command('view')
147
+ .description('Display an interactive dashboard of specs and changes')
148
+ .action(async () => {
149
+ try {
150
+ const viewCommand = new ViewCommand();
151
+ await viewCommand.execute('.');
152
+ }
153
+ catch (error) {
154
+ console.log(); // Empty line for spacing
155
+ ora().fail(`Error: ${error.message}`);
156
+ process.exit(1);
157
+ }
158
+ });
159
+ // Change command with subcommands
160
+ const changeCmd = program
161
+ .command('change')
162
+ .description('Manage ZhiMa change proposals');
163
+ // Deprecation notice for noun-based commands
164
+ changeCmd.hook('preAction', () => {
165
+ console.error('Warning: The "zhima change ..." commands are deprecated. Prefer verb-first commands (e.g., "zhima list", "zhima validate --changes").');
166
+ });
167
+ changeCmd
168
+ .command('show [change-name]')
169
+ .description('Show a change proposal in JSON or markdown format')
170
+ .option('--json', 'Output as JSON')
171
+ .option('--deltas-only', 'Show only deltas (JSON only)')
172
+ .option('--requirements-only', 'Alias for --deltas-only (deprecated)')
173
+ .option('--no-interactive', 'Disable interactive prompts')
174
+ .action(async (changeName, options) => {
175
+ try {
176
+ const changeCommand = new ChangeCommand();
177
+ await changeCommand.show(changeName, options);
178
+ }
179
+ catch (error) {
180
+ console.error(`Error: ${error.message}`);
181
+ process.exitCode = 1;
182
+ }
183
+ });
184
+ changeCmd
185
+ .command('list')
186
+ .description('List all active changes (DEPRECATED: use "zhima list" instead)')
187
+ .option('--json', 'Output as JSON')
188
+ .option('--long', 'Show id and title with counts')
189
+ .action(async (options) => {
190
+ try {
191
+ console.error('Warning: "zhima change list" is deprecated. Use "zhima list".');
192
+ const changeCommand = new ChangeCommand();
193
+ await changeCommand.list(options);
194
+ }
195
+ catch (error) {
196
+ console.error(`Error: ${error.message}`);
197
+ process.exitCode = 1;
198
+ }
199
+ });
200
+ changeCmd
201
+ .command('validate [change-name]')
202
+ .description('Validate a change proposal')
203
+ .option('--strict', 'Enable strict validation mode')
204
+ .option('--json', 'Output validation report as JSON')
205
+ .option('--no-interactive', 'Disable interactive prompts')
206
+ .action(async (changeName, options) => {
207
+ try {
208
+ const changeCommand = new ChangeCommand();
209
+ await changeCommand.validate(changeName, options);
210
+ if (typeof process.exitCode === 'number' && process.exitCode !== 0) {
211
+ process.exit(process.exitCode);
212
+ }
213
+ }
214
+ catch (error) {
215
+ console.error(`Error: ${error.message}`);
216
+ process.exitCode = 1;
217
+ }
218
+ });
219
+ program
220
+ .command('archive [change-name]')
221
+ .description('Archive a completed change and update main specs')
222
+ .option('-y, --yes', 'Skip confirmation prompts')
223
+ .option('--skip-specs', 'Skip spec update operations (useful for infrastructure, tooling, or doc-only changes)')
224
+ .option('--no-validate', 'Skip validation (not recommended, requires confirmation)')
225
+ .action(async (changeName, options) => {
226
+ try {
227
+ const archiveCommand = new ArchiveCommand();
228
+ await archiveCommand.execute(changeName, options);
229
+ }
230
+ catch (error) {
231
+ console.log(); // Empty line for spacing
232
+ ora().fail(`Error: ${error.message}`);
233
+ process.exit(1);
234
+ }
235
+ });
236
+ registerSpecCommand(program);
237
+ registerConfigCommand(program);
238
+ registerSchemaCommand(program);
239
+ registerWorkspaceCommand(program);
240
+ // Top-level validate command
241
+ program
242
+ .command('validate [item-name]')
243
+ .description('Validate changes and specs')
244
+ .option('--all', 'Validate all changes and specs')
245
+ .option('--changes', 'Validate all changes')
246
+ .option('--specs', 'Validate all specs')
247
+ .option('--type <type>', 'Specify item type when ambiguous: change|spec')
248
+ .option('--strict', 'Enable strict validation mode')
249
+ .option('--json', 'Output validation results as JSON')
250
+ .option('--concurrency <n>', 'Max concurrent validations (defaults to env ZHIMA_CONCURRENCY or 6)')
251
+ .option('--no-interactive', 'Disable interactive prompts')
252
+ .action(async (itemName, options) => {
253
+ try {
254
+ const validateCommand = new ValidateCommand();
255
+ await validateCommand.execute(itemName, options);
256
+ }
257
+ catch (error) {
258
+ console.log();
259
+ ora().fail(`Error: ${error.message}`);
260
+ process.exit(1);
261
+ }
262
+ });
263
+ // Top-level show command
264
+ program
265
+ .command('show [item-name]')
266
+ .description('Show a change or spec')
267
+ .option('--json', 'Output as JSON')
268
+ .option('--type <type>', 'Specify item type when ambiguous: change|spec')
269
+ .option('--no-interactive', 'Disable interactive prompts')
270
+ // change-only flags
271
+ .option('--deltas-only', 'Show only deltas (JSON only, change)')
272
+ .option('--requirements-only', 'Alias for --deltas-only (deprecated, change)')
273
+ // spec-only flags
274
+ .option('--requirements', 'JSON only: Show only requirements (exclude scenarios)')
275
+ .option('--no-scenarios', 'JSON only: Exclude scenario content')
276
+ .option('-r, --requirement <id>', 'JSON only: Show specific requirement by ID (1-based)')
277
+ // allow unknown options to pass-through to underlying command implementation
278
+ .allowUnknownOption(true)
279
+ .action(async (itemName, options) => {
280
+ try {
281
+ const showCommand = new ShowCommand();
282
+ await showCommand.execute(itemName, options ?? {});
283
+ }
284
+ catch (error) {
285
+ console.log();
286
+ ora().fail(`Error: ${error.message}`);
287
+ process.exit(1);
288
+ }
289
+ });
290
+ // Feedback command
291
+ program
292
+ .command('feedback <message>')
293
+ .description('Submit feedback about ZhiMa')
294
+ .option('--body <text>', 'Detailed description for the feedback')
295
+ .action(async (message, options) => {
296
+ try {
297
+ const feedbackCommand = new FeedbackCommand();
298
+ await feedbackCommand.execute(message, options);
299
+ }
300
+ catch (error) {
301
+ console.log();
302
+ ora().fail(`Error: ${error.message}`);
303
+ process.exit(1);
304
+ }
305
+ });
306
+ // Completion command with subcommands
307
+ const completionCmd = program
308
+ .command('completion')
309
+ .description('Manage shell completions for ZhiMa CLI');
310
+ completionCmd
311
+ .command('generate [shell]')
312
+ .description('Generate completion script for a shell (outputs to stdout)')
313
+ .action(async (shell) => {
314
+ try {
315
+ const completionCommand = new CompletionCommand();
316
+ await completionCommand.generate({ shell });
317
+ }
318
+ catch (error) {
319
+ console.log();
320
+ ora().fail(`Error: ${error.message}`);
321
+ process.exit(1);
322
+ }
323
+ });
324
+ completionCmd
325
+ .command('install [shell]')
326
+ .description('Install completion script for a shell')
327
+ .option('--verbose', 'Show detailed installation output')
328
+ .action(async (shell, options) => {
329
+ try {
330
+ const completionCommand = new CompletionCommand();
331
+ await completionCommand.install({ shell, verbose: options?.verbose });
332
+ }
333
+ catch (error) {
334
+ console.log();
335
+ ora().fail(`Error: ${error.message}`);
336
+ process.exit(1);
337
+ }
338
+ });
339
+ completionCmd
340
+ .command('uninstall [shell]')
341
+ .description('Uninstall completion script for a shell')
342
+ .option('-y, --yes', 'Skip confirmation prompts')
343
+ .action(async (shell, options) => {
344
+ try {
345
+ const completionCommand = new CompletionCommand();
346
+ await completionCommand.uninstall({ shell, yes: options?.yes });
347
+ }
348
+ catch (error) {
349
+ console.log();
350
+ ora().fail(`Error: ${error.message}`);
351
+ process.exit(1);
352
+ }
353
+ });
354
+ // Hidden command for machine-readable completion data
355
+ program
356
+ .command('__complete <type>', { hidden: true })
357
+ .description('Output completion data in machine-readable format (internal use)')
358
+ .action(async (type) => {
359
+ try {
360
+ const completionCommand = new CompletionCommand();
361
+ await completionCommand.complete({ type });
362
+ }
363
+ catch (error) {
364
+ // Silently fail for graceful shell completion experience
365
+ process.exitCode = 1;
366
+ }
367
+ });
368
+ // ═══════════════════════════════════════════════════════════
369
+ // Workflow Commands (formerly experimental)
370
+ // ═══════════════════════════════════════════════════════════
371
+ // Status command
372
+ program
373
+ .command('status')
374
+ .description('Display artifact completion status for a change')
375
+ .option('--change <id>', 'Change name to show status for')
376
+ .option('--schema <name>', 'Schema override (auto-detected from config.yaml)')
377
+ .option('--json', 'Output as JSON')
378
+ .action(async (options) => {
379
+ try {
380
+ await statusCommand(options);
381
+ }
382
+ catch (error) {
383
+ console.log();
384
+ ora().fail(`Error: ${error.message}`);
385
+ process.exit(1);
386
+ }
387
+ });
388
+ // Instructions command
389
+ program
390
+ .command('instructions [artifact]')
391
+ .description('Output enriched instructions for creating an artifact or applying tasks')
392
+ .option('--change <id>', 'Change name')
393
+ .option('--schema <name>', 'Schema override (auto-detected from config.yaml)')
394
+ .option('--json', 'Output as JSON')
395
+ .action(async (artifactId, options) => {
396
+ try {
397
+ // Special case: "apply" is not an artifact, but a command to get apply instructions
398
+ if (artifactId === 'apply') {
399
+ await applyInstructionsCommand(options);
400
+ }
401
+ else {
402
+ await instructionsCommand(artifactId, options);
403
+ }
404
+ }
405
+ catch (error) {
406
+ console.log();
407
+ ora().fail(`Error: ${error.message}`);
408
+ process.exit(1);
409
+ }
410
+ });
411
+ // Templates command
412
+ program
413
+ .command('templates')
414
+ .description('Show resolved template paths for all artifacts in a schema')
415
+ .option('--schema <name>', `Schema to use (default: ${DEFAULT_SCHEMA})`)
416
+ .option('--json', 'Output as JSON mapping artifact IDs to template paths')
417
+ .action(async (options) => {
418
+ try {
419
+ await templatesCommand(options);
420
+ }
421
+ catch (error) {
422
+ console.log();
423
+ ora().fail(`Error: ${error.message}`);
424
+ process.exit(1);
425
+ }
426
+ });
427
+ // Schemas command
428
+ program
429
+ .command('schemas')
430
+ .description('List available workflow schemas with descriptions')
431
+ .option('--json', 'Output as JSON (for agent use)')
432
+ .action(async (options) => {
433
+ try {
434
+ await schemasCommand(options);
435
+ }
436
+ catch (error) {
437
+ console.log();
438
+ ora().fail(`Error: ${error.message}`);
439
+ process.exit(1);
440
+ }
441
+ });
442
+ // New command group with change subcommand
443
+ const newCmd = program.command('new').description('Create new items');
444
+ newCmd
445
+ .command('change <name>')
446
+ .description('Create a new change directory')
447
+ .option('--description <text>', 'Description to add to README.md')
448
+ .option('--goal <text>', 'Workspace product goal to store with the change')
449
+ .option('--areas <names>', 'Comma-separated affected workspace link names')
450
+ .option('--schema <name>', `Workflow schema to use (default: ${DEFAULT_SCHEMA})`)
451
+ .action(async (name, options) => {
452
+ try {
453
+ await newChangeCommand(name, options);
454
+ }
455
+ catch (error) {
456
+ console.log();
457
+ ora().fail(`Error: ${error.message}`);
458
+ process.exit(1);
459
+ }
460
+ });
461
+ program.parse();
462
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,35 @@
1
+ export declare class ChangeCommand {
2
+ private converter;
3
+ constructor();
4
+ /**
5
+ * Show a change proposal.
6
+ * - Text mode: raw markdown passthrough (no filters)
7
+ * - JSON mode: minimal object with deltas; --deltas-only returns same object with filtered deltas
8
+ * Note: --requirements-only is deprecated alias for --deltas-only
9
+ */
10
+ show(changeName?: string, options?: {
11
+ json?: boolean;
12
+ requirementsOnly?: boolean;
13
+ deltasOnly?: boolean;
14
+ noInteractive?: boolean;
15
+ }): Promise<void>;
16
+ /**
17
+ * List active changes.
18
+ * - Text default: IDs only; --long prints minimal details (title, counts)
19
+ * - JSON: array of { id, title, deltaCount, taskStatus }, sorted by id
20
+ */
21
+ list(options?: {
22
+ json?: boolean;
23
+ long?: boolean;
24
+ }): Promise<void>;
25
+ validate(changeName?: string, options?: {
26
+ strict?: boolean;
27
+ json?: boolean;
28
+ noInteractive?: boolean;
29
+ }): Promise<void>;
30
+ private getActiveChanges;
31
+ private extractTitle;
32
+ private countTasks;
33
+ private printNextSteps;
34
+ }
35
+ //# sourceMappingURL=change.d.ts.map