@specverse/engines 4.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 (817) hide show
  1. package/assets/examples/09-api/ai-spec.yaml +194 -0
  2. package/assets/examples/09-api/converted.yaml +95 -0
  3. package/assets/examples/09-api/diagram-architecture.mmd +10 -0
  4. package/assets/examples/09-api/diagram-er.mmd +10 -0
  5. package/assets/examples/09-api/documentation.html +104 -0
  6. package/assets/examples/09-api/documentation.md +95 -0
  7. package/assets/examples/09-api/inferred-spec.yaml +420 -0
  8. package/assets/examples/09-api/openapi.json +61 -0
  9. package/assets/examples/10-api/README.md +216 -0
  10. package/assets/examples/10-api/ai-spec.yaml +194 -0
  11. package/assets/examples/10-api/converted.yaml +96 -0
  12. package/assets/examples/10-api/diagram-architecture.mmd +10 -0
  13. package/assets/examples/10-api/diagram-er.mmd +10 -0
  14. package/assets/examples/10-api/documentation.html +104 -0
  15. package/assets/examples/10-api/documentation.md +95 -0
  16. package/assets/examples/10-api/inferred-spec.yaml +7 -0
  17. package/assets/examples/10-api/metadata.yaml +89 -0
  18. package/assets/examples/10-api/openapi.json +61 -0
  19. package/assets/examples/10-api/package-integration-test.js +177 -0
  20. package/assets/examples/10-api/usage-example.js +323 -0
  21. package/assets/examples/10-api/usage-example.ts +363 -0
  22. package/assets/examples/10-api/workflow-test.js +113 -0
  23. package/assets/examples/manifests/01-simple-default-mappings.yaml +36 -0
  24. package/assets/examples/manifests/02-capability-mappings.yaml +55 -0
  25. package/assets/examples/manifests/03-hybrid-mappings.yaml +109 -0
  26. package/assets/examples/manifests/README.md +245 -0
  27. package/assets/examples/manifests/backend-only.yaml +43 -0
  28. package/assets/examples/manifests/blog-api.md +78 -0
  29. package/assets/examples/manifests/blog-api.specly +79 -0
  30. package/assets/examples/manifests/frontend-only.yaml +27 -0
  31. package/assets/examples/manifests/fullstack-app.yaml +44 -0
  32. package/assets/examples/manifests/fullstack-monorepo.yaml +62 -0
  33. package/assets/examples/validate-examples-with-expected-failures.cjs +328 -0
  34. package/assets/examples/validate-examples.cjs +225 -0
  35. package/assets/examples-decomposed/cloud-native-manifest.example.yaml +8 -0
  36. package/assets/examples-decomposed/cloud-native-manifest.md +379 -0
  37. package/assets/examples-decomposed/cloud-native-manifest.specly +60 -0
  38. package/assets/examples-decomposed/docker-compose-manifest.example.yaml +8 -0
  39. package/assets/examples-decomposed/docker-compose-manifest.md +326 -0
  40. package/assets/examples-decomposed/docker-compose-manifest.specly +40 -0
  41. package/assets/examples-decomposed/kubernetes-deployment-manifest.example.yaml +8 -0
  42. package/assets/examples-decomposed/kubernetes-deployment-manifest.md +237 -0
  43. package/assets/examples-decomposed/kubernetes-deployment-manifest.specly +41 -0
  44. package/assets/examples-inference/inference-engine-demo.example.yaml +8 -0
  45. package/assets/examples-inference/inference-engine-demo.md +574 -0
  46. package/assets/examples-inference/inference-engine-demo.specly +216 -0
  47. package/assets/prompts/MOVED.md +35 -0
  48. package/assets/prompts/SUMMARY-v8-PROMOTION.md +445 -0
  49. package/assets/prompts/core/CHANGELOG.md +158 -0
  50. package/assets/prompts/core/MIGRATION-v6-to-v7.md +379 -0
  51. package/assets/prompts/core/README.md +319 -0
  52. package/assets/prompts/core/base-terminal-prompt.md +201 -0
  53. package/assets/prompts/core/examples/example-usage.ts +140 -0
  54. package/assets/prompts/core/schemas/prompt.schema.json +309 -0
  55. package/assets/prompts/core/schemas/prompt.schema.yaml +229 -0
  56. package/assets/prompts/core/standard/archive/v1/analyse.prompt.yaml +259 -0
  57. package/assets/prompts/core/standard/archive/v1/create.prompt.yaml +302 -0
  58. package/assets/prompts/core/standard/archive/v1/materialise.prompt.yaml +328 -0
  59. package/assets/prompts/core/standard/archive/v1/realize.prompt.yaml +606 -0
  60. package/assets/prompts/core/standard/archive/v2/README.md +110 -0
  61. package/assets/prompts/core/standard/archive/v2/analyse.prompt.yaml +151 -0
  62. package/assets/prompts/core/standard/archive/v2/create.prompt.yaml +151 -0
  63. package/assets/prompts/core/standard/archive/v2/materialise.prompt.yaml +132 -0
  64. package/assets/prompts/core/standard/archive/v2/realize.prompt.yaml +147 -0
  65. package/assets/prompts/core/standard/archive/v3/README.md +279 -0
  66. package/assets/prompts/core/standard/archive/v3/analyse.prompt.yaml +309 -0
  67. package/assets/prompts/core/standard/archive/v3/create.prompt.yaml +351 -0
  68. package/assets/prompts/core/standard/archive/v3/materialise.prompt.yaml +247 -0
  69. package/assets/prompts/core/standard/archive/v3/realize.prompt.yaml +344 -0
  70. package/assets/prompts/core/standard/archive/v4/README.md +79 -0
  71. package/assets/prompts/core/standard/archive/v4/analyse.prompt.yaml +204 -0
  72. package/assets/prompts/core/standard/archive/v4/create.prompt.yaml +185 -0
  73. package/assets/prompts/core/standard/archive/v5/README.md +224 -0
  74. package/assets/prompts/core/standard/archive/v5/analyse.prompt.yaml +209 -0
  75. package/assets/prompts/core/standard/archive/v5/create.prompt.yaml +225 -0
  76. package/assets/prompts/core/standard/archive/v5/materialise.prompt.yaml +242 -0
  77. package/assets/prompts/core/standard/archive/v5/realize.prompt.yaml +336 -0
  78. package/assets/prompts/core/standard/archive/v6/README.md +187 -0
  79. package/assets/prompts/core/standard/archive/v6/analyse.prompt.yaml +219 -0
  80. package/assets/prompts/core/standard/archive/v6/create.prompt.yaml +180 -0
  81. package/assets/prompts/core/standard/archive/v6/materialise.prompt.yaml +203 -0
  82. package/assets/prompts/core/standard/archive/v6/realize.prompt.yaml +215 -0
  83. package/assets/prompts/core/standard/archive/v7/analyse.prompt.nick.yaml +144 -0
  84. package/assets/prompts/core/standard/archive/v7/analyse.prompt.old.yaml +146 -0
  85. package/assets/prompts/core/standard/archive/v7/analyse.prompt.yaml +129 -0
  86. package/assets/prompts/core/standard/archive/v7/create.prompt.yaml +146 -0
  87. package/assets/prompts/core/standard/archive/v7/materialise.prompt.yaml +297 -0
  88. package/assets/prompts/core/standard/archive/v7/realize.prompt.yaml +294 -0
  89. package/assets/prompts/core/standard/archive/v8/README.md +400 -0
  90. package/assets/prompts/core/standard/archive/v8/analyse.prompt.yaml +185 -0
  91. package/assets/prompts/core/standard/archive/v8/create.prompt.yaml +203 -0
  92. package/assets/prompts/core/standard/archive/v8/materialise.prompt.yaml +297 -0
  93. package/assets/prompts/core/standard/archive/v8/realize.prompt.yaml +294 -0
  94. package/assets/prompts/core/standard/default/analyse.prompt.yaml +496 -0
  95. package/assets/prompts/core/standard/default/app-demo.prompt.yaml +213 -0
  96. package/assets/prompts/core/standard/default/create.prompt.yaml +418 -0
  97. package/assets/prompts/core/standard/default/materialise.prompt.yaml +814 -0
  98. package/assets/prompts/core/standard/default/realize.prompt.yaml +574 -0
  99. package/assets/prompts/core/standard/v9/analyse.prompt.yaml +496 -0
  100. package/assets/prompts/core/standard/v9/create.prompt.yaml +418 -0
  101. package/assets/prompts/core/standard/v9/materialise.prompt.yaml +814 -0
  102. package/assets/prompts/core/standard/v9/realize.prompt.yaml +574 -0
  103. package/assets/prompts/templates/api-orchestrator-template.yaml +188 -0
  104. package/assets/prompts/templates/claude-integration-template.md +121 -0
  105. package/assets/prompts/templates/terminal-prompt-template.md +97 -0
  106. package/dist/ai/commands/enhance.d.ts +8 -0
  107. package/dist/ai/commands/enhance.d.ts.map +1 -0
  108. package/dist/ai/commands/enhance.js +155 -0
  109. package/dist/ai/commands/enhance.js.map +1 -0
  110. package/dist/ai/commands/fill.d.ts +8 -0
  111. package/dist/ai/commands/fill.d.ts.map +1 -0
  112. package/dist/ai/commands/fill.js +179 -0
  113. package/dist/ai/commands/fill.js.map +1 -0
  114. package/dist/ai/commands/index.d.ts +11 -0
  115. package/dist/ai/commands/index.d.ts.map +1 -0
  116. package/dist/ai/commands/index.js +11 -0
  117. package/dist/ai/commands/index.js.map +1 -0
  118. package/dist/ai/commands/spec-analyser.d.ts +18 -0
  119. package/dist/ai/commands/spec-analyser.d.ts.map +1 -0
  120. package/dist/ai/commands/spec-analyser.js +175 -0
  121. package/dist/ai/commands/spec-analyser.js.map +1 -0
  122. package/dist/ai/commands/suggest.d.ts +8 -0
  123. package/dist/ai/commands/suggest.d.ts.map +1 -0
  124. package/dist/ai/commands/suggest.js +101 -0
  125. package/dist/ai/commands/suggest.js.map +1 -0
  126. package/dist/ai/commands/template.d.ts +8 -0
  127. package/dist/ai/commands/template.d.ts.map +1 -0
  128. package/dist/ai/commands/template.js +136 -0
  129. package/dist/ai/commands/template.js.map +1 -0
  130. package/dist/ai/config/index.d.ts +71 -0
  131. package/dist/ai/config/index.d.ts.map +1 -0
  132. package/dist/ai/config/index.js +193 -0
  133. package/dist/ai/config/index.js.map +1 -0
  134. package/dist/ai/config-loader.d.ts +31 -0
  135. package/dist/ai/config-loader.d.ts.map +1 -0
  136. package/dist/ai/config-loader.js +66 -0
  137. package/dist/ai/config-loader.js.map +1 -0
  138. package/dist/ai/core/ecosystem-prompt-manager.d.ts +107 -0
  139. package/dist/ai/core/ecosystem-prompt-manager.d.ts.map +1 -0
  140. package/dist/ai/core/ecosystem-prompt-manager.js +462 -0
  141. package/dist/ai/core/ecosystem-prompt-manager.js.map +1 -0
  142. package/dist/ai/examples/basic-usage.d.ts +9 -0
  143. package/dist/ai/examples/basic-usage.d.ts.map +1 -0
  144. package/dist/ai/examples/basic-usage.js +94 -0
  145. package/dist/ai/examples/basic-usage.js.map +1 -0
  146. package/dist/ai/index.d.ts +44 -0
  147. package/dist/ai/index.d.ts.map +1 -0
  148. package/dist/ai/index.js +164 -0
  149. package/dist/ai/index.js.map +1 -0
  150. package/dist/ai/orchestrator/index.d.ts +3 -0
  151. package/dist/ai/orchestrator/index.d.ts.map +1 -0
  152. package/dist/ai/orchestrator/index.js +3 -0
  153. package/dist/ai/orchestrator/index.js.map +1 -0
  154. package/dist/ai/orchestrator/interactive-workflow.d.ts +66 -0
  155. package/dist/ai/orchestrator/interactive-workflow.d.ts.map +1 -0
  156. package/dist/ai/orchestrator/interactive-workflow.js +214 -0
  157. package/dist/ai/orchestrator/interactive-workflow.js.map +1 -0
  158. package/dist/ai/orchestrator/specverse-orchestrator.d.ts +217 -0
  159. package/dist/ai/orchestrator/specverse-orchestrator.d.ts.map +1 -0
  160. package/dist/ai/orchestrator/specverse-orchestrator.js +745 -0
  161. package/dist/ai/orchestrator/specverse-orchestrator.js.map +1 -0
  162. package/dist/ai/prompt-loader.d.ts +24 -0
  163. package/dist/ai/prompt-loader.d.ts.map +1 -0
  164. package/dist/ai/prompt-loader.js +159 -0
  165. package/dist/ai/prompt-loader.js.map +1 -0
  166. package/dist/ai/providers/anthropic-provider.d.ts +38 -0
  167. package/dist/ai/providers/anthropic-provider.d.ts.map +1 -0
  168. package/dist/ai/providers/anthropic-provider.js +235 -0
  169. package/dist/ai/providers/anthropic-provider.js.map +1 -0
  170. package/dist/ai/providers/index.d.ts +6 -0
  171. package/dist/ai/providers/index.d.ts.map +1 -0
  172. package/dist/ai/providers/index.js +6 -0
  173. package/dist/ai/providers/index.js.map +1 -0
  174. package/dist/ai/providers/interactive-provider.d.ts +67 -0
  175. package/dist/ai/providers/interactive-provider.d.ts.map +1 -0
  176. package/dist/ai/providers/interactive-provider.js +337 -0
  177. package/dist/ai/providers/interactive-provider.js.map +1 -0
  178. package/dist/ai/providers/llm-provider.d.ts +127 -0
  179. package/dist/ai/providers/llm-provider.d.ts.map +1 -0
  180. package/dist/ai/providers/llm-provider.js +141 -0
  181. package/dist/ai/providers/llm-provider.js.map +1 -0
  182. package/dist/ai/providers/openai-provider.d.ts +39 -0
  183. package/dist/ai/providers/openai-provider.d.ts.map +1 -0
  184. package/dist/ai/providers/openai-provider.js +193 -0
  185. package/dist/ai/providers/openai-provider.js.map +1 -0
  186. package/dist/ai/providers/provider-factory.d.ts +47 -0
  187. package/dist/ai/providers/provider-factory.d.ts.map +1 -0
  188. package/dist/ai/providers/provider-factory.js +159 -0
  189. package/dist/ai/providers/provider-factory.js.map +1 -0
  190. package/dist/ai/session/claude-executor.d.ts +39 -0
  191. package/dist/ai/session/claude-executor.d.ts.map +1 -0
  192. package/dist/ai/session/claude-executor.js +136 -0
  193. package/dist/ai/session/claude-executor.js.map +1 -0
  194. package/dist/ai/session/session-manager.d.ts +72 -0
  195. package/dist/ai/session/session-manager.d.ts.map +1 -0
  196. package/dist/ai/session/session-manager.js +294 -0
  197. package/dist/ai/session/session-manager.js.map +1 -0
  198. package/dist/ai/session/types.d.ts +152 -0
  199. package/dist/ai/session/types.d.ts.map +1 -0
  200. package/dist/ai/session/types.js +6 -0
  201. package/dist/ai/session/types.js.map +1 -0
  202. package/dist/ai/types/index.d.ts +83 -0
  203. package/dist/ai/types/index.d.ts.map +1 -0
  204. package/dist/ai/types/index.js +5 -0
  205. package/dist/ai/types/index.js.map +1 -0
  206. package/dist/generators/UML-generator.d.ts +64 -0
  207. package/dist/generators/UML-generator.d.ts.map +1 -0
  208. package/dist/generators/UML-generator.js +541 -0
  209. package/dist/generators/UML-generator.js.map +1 -0
  210. package/dist/generators/ai-view-generator.d.ts +391 -0
  211. package/dist/generators/ai-view-generator.d.ts.map +1 -0
  212. package/dist/generators/ai-view-generator.js +907 -0
  213. package/dist/generators/ai-view-generator.js.map +1 -0
  214. package/dist/generators/diagram-engine/core/BaseDiagramPlugin.d.ts +41 -0
  215. package/dist/generators/diagram-engine/core/BaseDiagramPlugin.d.ts.map +1 -0
  216. package/dist/generators/diagram-engine/core/BaseDiagramPlugin.js +64 -0
  217. package/dist/generators/diagram-engine/core/BaseDiagramPlugin.js.map +1 -0
  218. package/dist/generators/diagram-engine/core/DiagramContext.d.ts +155 -0
  219. package/dist/generators/diagram-engine/core/DiagramContext.d.ts.map +1 -0
  220. package/dist/generators/diagram-engine/core/DiagramContext.js +481 -0
  221. package/dist/generators/diagram-engine/core/DiagramContext.js.map +1 -0
  222. package/dist/generators/diagram-engine/core/StyleManager.d.ts +51 -0
  223. package/dist/generators/diagram-engine/core/StyleManager.d.ts.map +1 -0
  224. package/dist/generators/diagram-engine/core/StyleManager.js +227 -0
  225. package/dist/generators/diagram-engine/core/StyleManager.js.map +1 -0
  226. package/dist/generators/diagram-engine/core/UnifiedDiagramGenerator.d.ts +83 -0
  227. package/dist/generators/diagram-engine/core/UnifiedDiagramGenerator.d.ts.map +1 -0
  228. package/dist/generators/diagram-engine/core/UnifiedDiagramGenerator.js +200 -0
  229. package/dist/generators/diagram-engine/core/UnifiedDiagramGenerator.js.map +1 -0
  230. package/dist/generators/diagram-engine/index.d.ts +41 -0
  231. package/dist/generators/diagram-engine/index.d.ts.map +1 -0
  232. package/dist/generators/diagram-engine/index.js +74 -0
  233. package/dist/generators/diagram-engine/index.js.map +1 -0
  234. package/dist/generators/diagram-engine/plugins/architecture/ArchitecturePlugin.d.ts +65 -0
  235. package/dist/generators/diagram-engine/plugins/architecture/ArchitecturePlugin.d.ts.map +1 -0
  236. package/dist/generators/diagram-engine/plugins/architecture/ArchitecturePlugin.js +490 -0
  237. package/dist/generators/diagram-engine/plugins/architecture/ArchitecturePlugin.js.map +1 -0
  238. package/dist/generators/diagram-engine/plugins/class-diagram/ClassDiagramPlugin.d.ts +40 -0
  239. package/dist/generators/diagram-engine/plugins/class-diagram/ClassDiagramPlugin.d.ts.map +1 -0
  240. package/dist/generators/diagram-engine/plugins/class-diagram/ClassDiagramPlugin.js +323 -0
  241. package/dist/generators/diagram-engine/plugins/class-diagram/ClassDiagramPlugin.js.map +1 -0
  242. package/dist/generators/diagram-engine/plugins/deployment/DeploymentPlugin.d.ts +46 -0
  243. package/dist/generators/diagram-engine/plugins/deployment/DeploymentPlugin.d.ts.map +1 -0
  244. package/dist/generators/diagram-engine/plugins/deployment/DeploymentPlugin.js +391 -0
  245. package/dist/generators/diagram-engine/plugins/deployment/DeploymentPlugin.js.map +1 -0
  246. package/dist/generators/diagram-engine/plugins/er-diagram/ERDiagramPlugin.d.ts +57 -0
  247. package/dist/generators/diagram-engine/plugins/er-diagram/ERDiagramPlugin.d.ts.map +1 -0
  248. package/dist/generators/diagram-engine/plugins/er-diagram/ERDiagramPlugin.js +300 -0
  249. package/dist/generators/diagram-engine/plugins/er-diagram/ERDiagramPlugin.js.map +1 -0
  250. package/dist/generators/diagram-engine/plugins/event-flow/EventFlowPlugin.d.ts +70 -0
  251. package/dist/generators/diagram-engine/plugins/event-flow/EventFlowPlugin.d.ts.map +1 -0
  252. package/dist/generators/diagram-engine/plugins/event-flow/EventFlowPlugin.js +955 -0
  253. package/dist/generators/diagram-engine/plugins/event-flow/EventFlowPlugin.js.map +1 -0
  254. package/dist/generators/diagram-engine/plugins/lifecycle/LifecyclePlugin.d.ts +40 -0
  255. package/dist/generators/diagram-engine/plugins/lifecycle/LifecyclePlugin.d.ts.map +1 -0
  256. package/dist/generators/diagram-engine/plugins/lifecycle/LifecyclePlugin.js +183 -0
  257. package/dist/generators/diagram-engine/plugins/lifecycle/LifecyclePlugin.js.map +1 -0
  258. package/dist/generators/diagram-engine/plugins/manifest/ManifestPlugin.d.ts +71 -0
  259. package/dist/generators/diagram-engine/plugins/manifest/ManifestPlugin.d.ts.map +1 -0
  260. package/dist/generators/diagram-engine/plugins/manifest/ManifestPlugin.js +396 -0
  261. package/dist/generators/diagram-engine/plugins/manifest/ManifestPlugin.js.map +1 -0
  262. package/dist/generators/diagram-engine/renderers/MermaidRenderer.d.ts +72 -0
  263. package/dist/generators/diagram-engine/renderers/MermaidRenderer.d.ts.map +1 -0
  264. package/dist/generators/diagram-engine/renderers/MermaidRenderer.js +441 -0
  265. package/dist/generators/diagram-engine/renderers/MermaidRenderer.js.map +1 -0
  266. package/dist/generators/diagram-engine/types/index.d.ts +261 -0
  267. package/dist/generators/diagram-engine/types/index.d.ts.map +1 -0
  268. package/dist/generators/diagram-engine/types/index.js +7 -0
  269. package/dist/generators/diagram-engine/types/index.js.map +1 -0
  270. package/dist/generators/documentation-generator.d.ts +54 -0
  271. package/dist/generators/documentation-generator.d.ts.map +1 -0
  272. package/dist/generators/documentation-generator.js +756 -0
  273. package/dist/generators/documentation-generator.js.map +1 -0
  274. package/dist/generators/index.d.ts +47 -0
  275. package/dist/generators/index.d.ts.map +1 -0
  276. package/dist/generators/index.js +51 -0
  277. package/dist/generators/index.js.map +1 -0
  278. package/dist/index.d.ts +13 -0
  279. package/dist/index.d.ts.map +1 -0
  280. package/dist/index.js +14 -0
  281. package/dist/index.js.map +1 -0
  282. package/dist/inference/comprehensive-engine.d.ts +71 -0
  283. package/dist/inference/comprehensive-engine.d.ts.map +1 -0
  284. package/dist/inference/comprehensive-engine.js +271 -0
  285. package/dist/inference/comprehensive-engine.js.map +1 -0
  286. package/dist/inference/core/context.d.ts +60 -0
  287. package/dist/inference/core/context.d.ts.map +1 -0
  288. package/dist/inference/core/context.js +292 -0
  289. package/dist/inference/core/context.js.map +1 -0
  290. package/dist/inference/core/index.d.ts +14 -0
  291. package/dist/inference/core/index.d.ts.map +1 -0
  292. package/dist/inference/core/index.js +18 -0
  293. package/dist/inference/core/index.js.map +1 -0
  294. package/dist/inference/core/rule-engine.d.ts +52 -0
  295. package/dist/inference/core/rule-engine.d.ts.map +1 -0
  296. package/dist/inference/core/rule-engine.js +1329 -0
  297. package/dist/inference/core/rule-engine.js.map +1 -0
  298. package/dist/inference/core/rule-file-types.d.ts +225 -0
  299. package/dist/inference/core/rule-file-types.d.ts.map +1 -0
  300. package/dist/inference/core/rule-file-types.js +79 -0
  301. package/dist/inference/core/rule-file-types.js.map +1 -0
  302. package/dist/inference/core/rule-loader.d.ts +93 -0
  303. package/dist/inference/core/rule-loader.d.ts.map +1 -0
  304. package/dist/inference/core/rule-loader.js +645 -0
  305. package/dist/inference/core/rule-loader.js.map +1 -0
  306. package/dist/inference/core/specly-converter.d.ts +50 -0
  307. package/dist/inference/core/specly-converter.d.ts.map +1 -0
  308. package/dist/inference/core/specly-converter.js +885 -0
  309. package/dist/inference/core/specly-converter.js.map +1 -0
  310. package/dist/inference/core/types.d.ts +395 -0
  311. package/dist/inference/core/types.d.ts.map +1 -0
  312. package/dist/inference/core/types.js +31 -0
  313. package/dist/inference/core/types.js.map +1 -0
  314. package/dist/inference/deployment/deployment-generator.d.ts +48 -0
  315. package/dist/inference/deployment/deployment-generator.d.ts.map +1 -0
  316. package/dist/inference/deployment/deployment-generator.js +343 -0
  317. package/dist/inference/deployment/deployment-generator.js.map +1 -0
  318. package/dist/inference/deployment/index.d.ts +6 -0
  319. package/dist/inference/deployment/index.d.ts.map +1 -0
  320. package/dist/inference/deployment/index.js +5 -0
  321. package/dist/inference/deployment/index.js.map +1 -0
  322. package/dist/inference/dev-specly-generator.d.ts +19 -0
  323. package/dist/inference/dev-specly-generator.d.ts.map +1 -0
  324. package/dist/inference/dev-specly-generator.js +127 -0
  325. package/dist/inference/dev-specly-generator.js.map +1 -0
  326. package/dist/inference/index.d.ts +29 -0
  327. package/dist/inference/index.d.ts.map +1 -0
  328. package/dist/inference/index.js +170 -0
  329. package/dist/inference/index.js.map +1 -0
  330. package/dist/inference/logical/generators/component-type-resolver.d.ts +82 -0
  331. package/dist/inference/logical/generators/component-type-resolver.d.ts.map +1 -0
  332. package/dist/inference/logical/generators/component-type-resolver.js +151 -0
  333. package/dist/inference/logical/generators/component-type-resolver.js.map +1 -0
  334. package/dist/inference/logical/generators/controller-generator.d.ts +43 -0
  335. package/dist/inference/logical/generators/controller-generator.d.ts.map +1 -0
  336. package/dist/inference/logical/generators/controller-generator.js +303 -0
  337. package/dist/inference/logical/generators/controller-generator.js.map +1 -0
  338. package/dist/inference/logical/generators/event-generator.d.ts +67 -0
  339. package/dist/inference/logical/generators/event-generator.d.ts.map +1 -0
  340. package/dist/inference/logical/generators/event-generator.js +466 -0
  341. package/dist/inference/logical/generators/event-generator.js.map +1 -0
  342. package/dist/inference/logical/generators/promotion-generator.d.ts +32 -0
  343. package/dist/inference/logical/generators/promotion-generator.d.ts.map +1 -0
  344. package/dist/inference/logical/generators/promotion-generator.js +133 -0
  345. package/dist/inference/logical/generators/promotion-generator.js.map +1 -0
  346. package/dist/inference/logical/generators/service-generator.d.ts +51 -0
  347. package/dist/inference/logical/generators/service-generator.d.ts.map +1 -0
  348. package/dist/inference/logical/generators/service-generator.js +268 -0
  349. package/dist/inference/logical/generators/service-generator.js.map +1 -0
  350. package/dist/inference/logical/generators/specialist-view-expander.d.ts +75 -0
  351. package/dist/inference/logical/generators/specialist-view-expander.d.ts.map +1 -0
  352. package/dist/inference/logical/generators/specialist-view-expander.js +182 -0
  353. package/dist/inference/logical/generators/specialist-view-expander.js.map +1 -0
  354. package/dist/inference/logical/generators/view-generator.d.ts +131 -0
  355. package/dist/inference/logical/generators/view-generator.d.ts.map +1 -0
  356. package/dist/inference/logical/generators/view-generator.js +1115 -0
  357. package/dist/inference/logical/generators/view-generator.js.map +1 -0
  358. package/dist/inference/logical/index.d.ts +19 -0
  359. package/dist/inference/logical/index.d.ts.map +1 -0
  360. package/dist/inference/logical/index.js +15 -0
  361. package/dist/inference/logical/index.js.map +1 -0
  362. package/dist/inference/logical/logical-engine.d.ts +68 -0
  363. package/dist/inference/logical/logical-engine.d.ts.map +1 -0
  364. package/dist/inference/logical/logical-engine.js +484 -0
  365. package/dist/inference/logical/logical-engine.js.map +1 -0
  366. package/dist/inference/quint-transpiler.d.ts +64 -0
  367. package/dist/inference/quint-transpiler.d.ts.map +1 -0
  368. package/dist/inference/quint-transpiler.js +433 -0
  369. package/dist/inference/quint-transpiler.js.map +1 -0
  370. package/dist/inference/test-harness.d.ts +41 -0
  371. package/dist/inference/test-harness.d.ts.map +1 -0
  372. package/dist/inference/test-harness.js +357 -0
  373. package/dist/inference/test-harness.js.map +1 -0
  374. package/dist/parser/convention-processor.d.ts +66 -0
  375. package/dist/parser/convention-processor.d.ts.map +1 -0
  376. package/dist/parser/convention-processor.js +349 -0
  377. package/dist/parser/convention-processor.js.map +1 -0
  378. package/dist/parser/import-resolver/cache.d.ts +56 -0
  379. package/dist/parser/import-resolver/cache.d.ts.map +1 -0
  380. package/dist/parser/import-resolver/cache.js +191 -0
  381. package/dist/parser/import-resolver/cache.js.map +1 -0
  382. package/dist/parser/import-resolver/index.d.ts +10 -0
  383. package/dist/parser/import-resolver/index.d.ts.map +1 -0
  384. package/dist/parser/import-resolver/index.js +9 -0
  385. package/dist/parser/import-resolver/index.js.map +1 -0
  386. package/dist/parser/import-resolver/resolver.d.ts +102 -0
  387. package/dist/parser/import-resolver/resolver.d.ts.map +1 -0
  388. package/dist/parser/import-resolver/resolver.js +669 -0
  389. package/dist/parser/import-resolver/resolver.js.map +1 -0
  390. package/dist/parser/import-resolver/types.d.ts +55 -0
  391. package/dist/parser/import-resolver/types.d.ts.map +1 -0
  392. package/dist/parser/import-resolver/types.js +5 -0
  393. package/dist/parser/import-resolver/types.js.map +1 -0
  394. package/dist/parser/index.d.ts +38 -0
  395. package/dist/parser/index.d.ts.map +1 -0
  396. package/dist/parser/index.js +61 -0
  397. package/dist/parser/index.js.map +1 -0
  398. package/dist/parser/namespace-utils.d.ts +61 -0
  399. package/dist/parser/namespace-utils.d.ts.map +1 -0
  400. package/dist/parser/namespace-utils.js +191 -0
  401. package/dist/parser/namespace-utils.js.map +1 -0
  402. package/dist/parser/processors/AbstractProcessor.d.ts +10 -0
  403. package/dist/parser/processors/AbstractProcessor.d.ts.map +1 -0
  404. package/dist/parser/processors/AbstractProcessor.js +11 -0
  405. package/dist/parser/processors/AbstractProcessor.js.map +1 -0
  406. package/dist/parser/processors/AttributeProcessor.d.ts +19 -0
  407. package/dist/parser/processors/AttributeProcessor.d.ts.map +1 -0
  408. package/dist/parser/processors/AttributeProcessor.js +154 -0
  409. package/dist/parser/processors/AttributeProcessor.js.map +1 -0
  410. package/dist/parser/processors/ControllerProcessor.d.ts +9 -0
  411. package/dist/parser/processors/ControllerProcessor.d.ts.map +1 -0
  412. package/dist/parser/processors/ControllerProcessor.js +74 -0
  413. package/dist/parser/processors/ControllerProcessor.js.map +1 -0
  414. package/dist/parser/processors/DeploymentProcessor.d.ts +19 -0
  415. package/dist/parser/processors/DeploymentProcessor.d.ts.map +1 -0
  416. package/dist/parser/processors/DeploymentProcessor.js +244 -0
  417. package/dist/parser/processors/DeploymentProcessor.js.map +1 -0
  418. package/dist/parser/processors/EventProcessor.d.ts +8 -0
  419. package/dist/parser/processors/EventProcessor.d.ts.map +1 -0
  420. package/dist/parser/processors/EventProcessor.js +28 -0
  421. package/dist/parser/processors/EventProcessor.js.map +1 -0
  422. package/dist/parser/processors/ExecutableProcessor.d.ts +21 -0
  423. package/dist/parser/processors/ExecutableProcessor.d.ts.map +1 -0
  424. package/dist/parser/processors/ExecutableProcessor.js +135 -0
  425. package/dist/parser/processors/ExecutableProcessor.js.map +1 -0
  426. package/dist/parser/processors/LifecycleProcessor.d.ts +9 -0
  427. package/dist/parser/processors/LifecycleProcessor.d.ts.map +1 -0
  428. package/dist/parser/processors/LifecycleProcessor.js +41 -0
  429. package/dist/parser/processors/LifecycleProcessor.js.map +1 -0
  430. package/dist/parser/processors/ModelProcessor.d.ts +67 -0
  431. package/dist/parser/processors/ModelProcessor.d.ts.map +1 -0
  432. package/dist/parser/processors/ModelProcessor.js +495 -0
  433. package/dist/parser/processors/ModelProcessor.js.map +1 -0
  434. package/dist/parser/processors/RelationshipProcessor.d.ts +10 -0
  435. package/dist/parser/processors/RelationshipProcessor.d.ts.map +1 -0
  436. package/dist/parser/processors/RelationshipProcessor.js +55 -0
  437. package/dist/parser/processors/RelationshipProcessor.js.map +1 -0
  438. package/dist/parser/processors/ServiceProcessor.d.ts +9 -0
  439. package/dist/parser/processors/ServiceProcessor.d.ts.map +1 -0
  440. package/dist/parser/processors/ServiceProcessor.js +59 -0
  441. package/dist/parser/processors/ServiceProcessor.js.map +1 -0
  442. package/dist/parser/processors/ViewProcessor.d.ts +7 -0
  443. package/dist/parser/processors/ViewProcessor.d.ts.map +1 -0
  444. package/dist/parser/processors/ViewProcessor.js +66 -0
  445. package/dist/parser/processors/ViewProcessor.js.map +1 -0
  446. package/dist/parser/types/ast.d.ts +518 -0
  447. package/dist/parser/types/ast.d.ts.map +1 -0
  448. package/dist/parser/types/ast.js +8 -0
  449. package/dist/parser/types/ast.js.map +1 -0
  450. package/dist/parser/types/views.d.ts +186 -0
  451. package/dist/parser/types/views.d.ts.map +1 -0
  452. package/dist/parser/types/views.js +8 -0
  453. package/dist/parser/types/views.js.map +1 -0
  454. package/dist/parser/unified-parser.d.ts +195 -0
  455. package/dist/parser/unified-parser.d.ts.map +1 -0
  456. package/dist/parser/unified-parser.js +1180 -0
  457. package/dist/parser/unified-parser.js.map +1 -0
  458. package/dist/parser/vitest.config.d.ts +3 -0
  459. package/dist/parser/vitest.config.d.ts.map +1 -0
  460. package/dist/parser/vitest.config.js +27 -0
  461. package/dist/parser/vitest.config.js.map +1 -0
  462. package/dist/realize/engines/code-generator.d.ts +86 -0
  463. package/dist/realize/engines/code-generator.d.ts.map +1 -0
  464. package/dist/realize/engines/code-generator.js +159 -0
  465. package/dist/realize/engines/code-generator.js.map +1 -0
  466. package/dist/realize/engines/engine-registry.d.ts +94 -0
  467. package/dist/realize/engines/engine-registry.d.ts.map +1 -0
  468. package/dist/realize/engines/engine-registry.js +163 -0
  469. package/dist/realize/engines/engine-registry.js.map +1 -0
  470. package/dist/realize/engines/index.d.ts +10 -0
  471. package/dist/realize/engines/index.d.ts.map +1 -0
  472. package/dist/realize/engines/index.js +12 -0
  473. package/dist/realize/engines/index.js.map +1 -0
  474. package/dist/realize/engines/typescript-engine.d.ts +74 -0
  475. package/dist/realize/engines/typescript-engine.d.ts.map +1 -0
  476. package/dist/realize/engines/typescript-engine.js +289 -0
  477. package/dist/realize/engines/typescript-engine.js.map +1 -0
  478. package/dist/realize/generators/index.d.ts +11 -0
  479. package/dist/realize/generators/index.d.ts.map +1 -0
  480. package/dist/realize/generators/index.js +11 -0
  481. package/dist/realize/generators/index.js.map +1 -0
  482. package/dist/realize/index.d.ts +48 -0
  483. package/dist/realize/index.d.ts.map +1 -0
  484. package/dist/realize/index.js +529 -0
  485. package/dist/realize/index.js.map +1 -0
  486. package/dist/realize/library/index.d.ts +12 -0
  487. package/dist/realize/library/index.d.ts.map +1 -0
  488. package/dist/realize/library/index.js +15 -0
  489. package/dist/realize/library/index.js.map +1 -0
  490. package/dist/realize/library/library.d.ts +132 -0
  491. package/dist/realize/library/library.d.ts.map +1 -0
  492. package/dist/realize/library/library.js +343 -0
  493. package/dist/realize/library/library.js.map +1 -0
  494. package/dist/realize/library/loader.d.ts +73 -0
  495. package/dist/realize/library/loader.d.ts.map +1 -0
  496. package/dist/realize/library/loader.js +159 -0
  497. package/dist/realize/library/loader.js.map +1 -0
  498. package/dist/realize/library/resolver.d.ts +104 -0
  499. package/dist/realize/library/resolver.d.ts.map +1 -0
  500. package/dist/realize/library/resolver.js +299 -0
  501. package/dist/realize/library/resolver.js.map +1 -0
  502. package/dist/realize/library/validator.d.ts +65 -0
  503. package/dist/realize/library/validator.d.ts.map +1 -0
  504. package/dist/realize/library/validator.js +203 -0
  505. package/dist/realize/library/validator.js.map +1 -0
  506. package/dist/realize/types/index.d.ts +5 -0
  507. package/dist/realize/types/index.d.ts.map +1 -0
  508. package/dist/realize/types/index.js +5 -0
  509. package/dist/realize/types/index.js.map +1 -0
  510. package/dist/realize/types/instance-factory.d.ts +7 -0
  511. package/dist/realize/types/instance-factory.d.ts.map +1 -0
  512. package/dist/realize/types/instance-factory.js +2 -0
  513. package/dist/realize/types/instance-factory.js.map +1 -0
  514. package/dist/realize/types/unified-mappings.d.ts +163 -0
  515. package/dist/realize/types/unified-mappings.d.ts.map +1 -0
  516. package/dist/realize/types/unified-mappings.js +110 -0
  517. package/dist/realize/types/unified-mappings.js.map +1 -0
  518. package/dist/realize/utils/ai-spec-loader.d.ts +77 -0
  519. package/dist/realize/utils/ai-spec-loader.d.ts.map +1 -0
  520. package/dist/realize/utils/ai-spec-loader.js +142 -0
  521. package/dist/realize/utils/ai-spec-loader.js.map +1 -0
  522. package/dist/realize/utils/index.d.ts +9 -0
  523. package/dist/realize/utils/index.d.ts.map +1 -0
  524. package/dist/realize/utils/index.js +9 -0
  525. package/dist/realize/utils/index.js.map +1 -0
  526. package/dist/realize/utils/manifest-loader.d.ts +107 -0
  527. package/dist/realize/utils/manifest-loader.d.ts.map +1 -0
  528. package/dist/realize/utils/manifest-loader.js +168 -0
  529. package/dist/realize/utils/manifest-loader.js.map +1 -0
  530. package/dist/realize/utils/mapping-migration.d.ts +53 -0
  531. package/dist/realize/utils/mapping-migration.d.ts.map +1 -0
  532. package/dist/realize/utils/mapping-migration.js +194 -0
  533. package/dist/realize/utils/mapping-migration.js.map +1 -0
  534. package/dist/registry/cache/cache-manager.d.ts +132 -0
  535. package/dist/registry/cache/cache-manager.d.ts.map +1 -0
  536. package/dist/registry/cache/cache-manager.js +218 -0
  537. package/dist/registry/cache/cache-manager.js.map +1 -0
  538. package/dist/registry/client/registry-client.d.ts +129 -0
  539. package/dist/registry/client/registry-client.d.ts.map +1 -0
  540. package/dist/registry/client/registry-client.js +317 -0
  541. package/dist/registry/client/registry-client.js.map +1 -0
  542. package/dist/registry/formatters/error-formatter.d.ts +100 -0
  543. package/dist/registry/formatters/error-formatter.d.ts.map +1 -0
  544. package/dist/registry/formatters/error-formatter.js +290 -0
  545. package/dist/registry/formatters/error-formatter.js.map +1 -0
  546. package/dist/registry/formatters/index.d.ts +8 -0
  547. package/dist/registry/formatters/index.d.ts.map +1 -0
  548. package/dist/registry/formatters/index.js +7 -0
  549. package/dist/registry/formatters/index.js.map +1 -0
  550. package/dist/registry/index.d.ts +19 -0
  551. package/dist/registry/index.d.ts.map +1 -0
  552. package/dist/registry/index.js +22 -0
  553. package/dist/registry/index.js.map +1 -0
  554. package/dist/registry/offline/offline-handler.d.ts +150 -0
  555. package/dist/registry/offline/offline-handler.d.ts.map +1 -0
  556. package/dist/registry/offline/offline-handler.js +290 -0
  557. package/dist/registry/offline/offline-handler.js.map +1 -0
  558. package/dist/registry/types/index.d.ts +13 -0
  559. package/dist/registry/types/index.d.ts.map +1 -0
  560. package/dist/registry/types/index.js +11 -0
  561. package/dist/registry/types/index.js.map +1 -0
  562. package/dist/registry/types/registry.d.ts +220 -0
  563. package/dist/registry/types/registry.d.ts.map +1 -0
  564. package/dist/registry/types/registry.js +55 -0
  565. package/dist/registry/types/registry.js.map +1 -0
  566. package/dist/registry/types/validation.d.ts +197 -0
  567. package/dist/registry/types/validation.d.ts.map +1 -0
  568. package/dist/registry/types/validation.js +140 -0
  569. package/dist/registry/types/validation.js.map +1 -0
  570. package/dist/registry/utils/manifest-adapter.d.ts +42 -0
  571. package/dist/registry/utils/manifest-adapter.d.ts.map +1 -0
  572. package/dist/registry/utils/manifest-adapter.js +182 -0
  573. package/dist/registry/utils/manifest-adapter.js.map +1 -0
  574. package/dist/registry/validators/index.d.ts +12 -0
  575. package/dist/registry/validators/index.d.ts.map +1 -0
  576. package/dist/registry/validators/index.js +9 -0
  577. package/dist/registry/validators/index.js.map +1 -0
  578. package/dist/registry/validators/installation-validator.d.ts +75 -0
  579. package/dist/registry/validators/installation-validator.d.ts.map +1 -0
  580. package/dist/registry/validators/installation-validator.js +142 -0
  581. package/dist/registry/validators/installation-validator.js.map +1 -0
  582. package/dist/registry/validators/manifest-validator.d.ts +82 -0
  583. package/dist/registry/validators/manifest-validator.d.ts.map +1 -0
  584. package/dist/registry/validators/manifest-validator.js +213 -0
  585. package/dist/registry/validators/manifest-validator.js.map +1 -0
  586. package/dist/registry/validators/validator.d.ts +113 -0
  587. package/dist/registry/validators/validator.d.ts.map +1 -0
  588. package/dist/registry/validators/validator.js +165 -0
  589. package/dist/registry/validators/validator.js.map +1 -0
  590. package/libs/instance-factories/CURVED-INTERFACE.md +278 -0
  591. package/libs/instance-factories/README.md +73 -0
  592. package/libs/instance-factories/applications/README.md +51 -0
  593. package/libs/instance-factories/applications/generic-app.yaml +52 -0
  594. package/libs/instance-factories/applications/react-app-runtime.yaml +139 -0
  595. package/libs/instance-factories/applications/react-app.yaml +186 -0
  596. package/libs/instance-factories/applications/templates/generic/backend-env-generator.ts +31 -0
  597. package/libs/instance-factories/applications/templates/generic/backend-package-json-generator.ts +84 -0
  598. package/libs/instance-factories/applications/templates/generic/backend-tsconfig-generator.ts +69 -0
  599. package/libs/instance-factories/applications/templates/generic/main-generator.ts +308 -0
  600. package/libs/instance-factories/applications/templates/react/_view-components-source.ts +555 -0
  601. package/libs/instance-factories/applications/templates/react/api-client-generator.ts +436 -0
  602. package/libs/instance-factories/applications/templates/react/api-types-generator.ts +153 -0
  603. package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +94 -0
  604. package/libs/instance-factories/applications/templates/react/env-example-generator.ts +24 -0
  605. package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +106 -0
  606. package/libs/instance-factories/applications/templates/react/gitignore-generator.ts +38 -0
  607. package/libs/instance-factories/applications/templates/react/index-css-generator.ts +14 -0
  608. package/libs/instance-factories/applications/templates/react/index-html-generator.ts +30 -0
  609. package/libs/instance-factories/applications/templates/react/main-tsx-generator.ts +34 -0
  610. package/libs/instance-factories/applications/templates/react/package-json-generator.ts +57 -0
  611. package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +179 -0
  612. package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +1347 -0
  613. package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +150 -0
  614. package/libs/instance-factories/applications/templates/react/runtime-app-tsx-generator.ts +90 -0
  615. package/libs/instance-factories/applications/templates/react/runtime-package-json-generator.ts +61 -0
  616. package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +704 -0
  617. package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +84 -0
  618. package/libs/instance-factories/applications/templates/react/tsconfig-generator.ts +35 -0
  619. package/libs/instance-factories/applications/templates/react/use-api-hooks-generator.ts +121 -0
  620. package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +150 -0
  621. package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +150 -0
  622. package/libs/instance-factories/applications/templates/react/view-form-generator.ts +362 -0
  623. package/libs/instance-factories/applications/templates/react/view-list-generator.ts +98 -0
  624. package/libs/instance-factories/applications/templates/react/view-router-generator.ts +89 -0
  625. package/libs/instance-factories/applications/templates/react/vite-config-generator.ts +49 -0
  626. package/libs/instance-factories/archived/fastify-prisma.yaml +104 -0
  627. package/libs/instance-factories/cli/README.md +43 -0
  628. package/libs/instance-factories/cli/commander-js.yaml +55 -0
  629. package/libs/instance-factories/cli/templates/commander/cli-bin-wrapper-generator.ts +20 -0
  630. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts +12 -0
  631. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts.map +1 -0
  632. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js +115 -0
  633. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js.map +1 -0
  634. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.ts +168 -0
  635. package/libs/instance-factories/cli/templates/commander/command-generator.d.ts +14 -0
  636. package/libs/instance-factories/cli/templates/commander/command-generator.d.ts.map +1 -0
  637. package/libs/instance-factories/cli/templates/commander/command-generator.js +182 -0
  638. package/libs/instance-factories/cli/templates/commander/command-generator.js.map +1 -0
  639. package/libs/instance-factories/cli/templates/commander/command-generator.ts +1036 -0
  640. package/libs/instance-factories/communication/README.md +47 -0
  641. package/libs/instance-factories/communication/event-emitter.yaml +56 -0
  642. package/libs/instance-factories/communication/rabbitmq-events.yaml +87 -0
  643. package/libs/instance-factories/communication/templates/eventemitter/bus-generator.ts +93 -0
  644. package/libs/instance-factories/communication/templates/eventemitter/publisher-generator.ts +117 -0
  645. package/libs/instance-factories/communication/templates/eventemitter/subscriber-generator.ts +101 -0
  646. package/libs/instance-factories/controllers/README.md +42 -0
  647. package/libs/instance-factories/controllers/fastify.yaml +127 -0
  648. package/libs/instance-factories/controllers/templates/fastify/meta-routes-generator.ts +103 -0
  649. package/libs/instance-factories/controllers/templates/fastify/routes-generator.ts +389 -0
  650. package/libs/instance-factories/controllers/templates/fastify/server-generator.ts +76 -0
  651. package/libs/instance-factories/infrastructure/README.md +29 -0
  652. package/libs/instance-factories/infrastructure/docker-k8s.yaml +61 -0
  653. package/libs/instance-factories/infrastructure/templates/docker-k8s/infrastructure-generator.ts +46 -0
  654. package/libs/instance-factories/orms/README.md +54 -0
  655. package/libs/instance-factories/orms/prisma.yaml +89 -0
  656. package/libs/instance-factories/orms/templates/prisma/schema-generator.ts +576 -0
  657. package/libs/instance-factories/orms/templates/prisma/services-generator.ts +408 -0
  658. package/libs/instance-factories/scaffolding/README.md +49 -0
  659. package/libs/instance-factories/scaffolding/generic-scaffold.yaml +65 -0
  660. package/libs/instance-factories/scaffolding/templates/generic/env-example-generator.ts +73 -0
  661. package/libs/instance-factories/scaffolding/templates/generic/env-generator.ts +85 -0
  662. package/libs/instance-factories/scaffolding/templates/generic/gitignore-generator.ts +69 -0
  663. package/libs/instance-factories/scaffolding/templates/generic/package-json-generator.ts +176 -0
  664. package/libs/instance-factories/scaffolding/templates/generic/readme-generator.ts +207 -0
  665. package/libs/instance-factories/scaffolding/templates/generic/tsconfig-generator.ts +78 -0
  666. package/libs/instance-factories/scaffolding/templates/generic/tsconfig-react-generator.ts +41 -0
  667. package/libs/instance-factories/sdks/README.md +28 -0
  668. package/libs/instance-factories/sdks/python-sdk.yaml +66 -0
  669. package/libs/instance-factories/sdks/templates/python/sdk-generator.ts +50 -0
  670. package/libs/instance-factories/sdks/templates/typescript/sdk-generator.ts +49 -0
  671. package/libs/instance-factories/sdks/typescript-sdk.yaml +59 -0
  672. package/libs/instance-factories/services/README.md +55 -0
  673. package/libs/instance-factories/services/prisma-services.yaml +71 -0
  674. package/libs/instance-factories/services/templates/memory/generate-interpreter.ts +25 -0
  675. package/libs/instance-factories/services/templates/memory/step-conventions-memory.ts +465 -0
  676. package/libs/instance-factories/services/templates/prisma/behavior-generator.ts +304 -0
  677. package/libs/instance-factories/services/templates/prisma/controller-generator.ts +532 -0
  678. package/libs/instance-factories/services/templates/prisma/service-generator.ts +334 -0
  679. package/libs/instance-factories/services/templates/prisma/step-conventions.ts +309 -0
  680. package/libs/instance-factories/services/templates/shared-patterns.ts +38 -0
  681. package/libs/instance-factories/shared/path-resolver.ts +111 -0
  682. package/libs/instance-factories/storage/README.md +34 -0
  683. package/libs/instance-factories/storage/mongodb.yaml +79 -0
  684. package/libs/instance-factories/storage/postgresql.yaml +75 -0
  685. package/libs/instance-factories/storage/redis.yaml +79 -0
  686. package/libs/instance-factories/storage/templates/mongodb/config-generator.ts +15 -0
  687. package/libs/instance-factories/storage/templates/mongodb/docker-generator.ts +18 -0
  688. package/libs/instance-factories/storage/templates/postgresql/config-generator.ts +54 -0
  689. package/libs/instance-factories/storage/templates/postgresql/docker-generator.ts +55 -0
  690. package/libs/instance-factories/storage/templates/redis/config-generator.ts +16 -0
  691. package/libs/instance-factories/storage/templates/redis/docker-generator.ts +18 -0
  692. package/libs/instance-factories/test-generation.ts +192 -0
  693. package/libs/instance-factories/testing/README.md +40 -0
  694. package/libs/instance-factories/testing/templates/vitest/tests-generator.ts +51 -0
  695. package/libs/instance-factories/testing/vitest-tests.yaml +63 -0
  696. package/libs/instance-factories/tools/README.md +70 -0
  697. package/libs/instance-factories/tools/mcp.yaml +36 -0
  698. package/libs/instance-factories/tools/templates/mcp/mcp-server-generator.ts +190 -0
  699. package/libs/instance-factories/tools/templates/mcp/static/docs/DEPLOYMENT_GUIDE.md +630 -0
  700. package/libs/instance-factories/tools/templates/mcp/static/docs/HYBRID_RESOURCE_SYSTEM.md +330 -0
  701. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/EXTENSION_DEPLOYMENT.md +552 -0
  702. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/LOCAL_DEPLOYMENT.md +164 -0
  703. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/WEB_DEPLOYMENT.md +247 -0
  704. package/libs/instance-factories/tools/templates/mcp/static/package.json +94 -0
  705. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-enterprise.js +284 -0
  706. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-extension.js +139 -0
  707. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-local.js +74 -0
  708. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-web.js +156 -0
  709. package/libs/instance-factories/tools/templates/mcp/static/scripts/copy-canonical-files.js +41 -0
  710. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-deployments.js +259 -0
  711. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-resources.js +231 -0
  712. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-simple.js +196 -0
  713. package/libs/instance-factories/tools/templates/mcp/static/src/controllers/MCPServerController.ts +293 -0
  714. package/libs/instance-factories/tools/templates/mcp/static/src/events/EventEmitter.ts +90 -0
  715. package/libs/instance-factories/tools/templates/mcp/static/src/index.ts +24 -0
  716. package/libs/instance-factories/tools/templates/mcp/static/src/interfaces/ResourceProvider.ts +15 -0
  717. package/libs/instance-factories/tools/templates/mcp/static/src/models/LibrarySuggestion.ts +106 -0
  718. package/libs/instance-factories/tools/templates/mcp/static/src/models/SpecVerseResource.ts +75 -0
  719. package/libs/instance-factories/tools/templates/mcp/static/src/server/mcp-server.ts +239 -0
  720. package/libs/instance-factories/tools/templates/mcp/static/src/services/CLIProxyService.ts +1501 -0
  721. package/libs/instance-factories/tools/templates/mcp/static/src/services/EmbeddedResourcesAdapter.ts +211 -0
  722. package/libs/instance-factories/tools/templates/mcp/static/src/services/EntityModuleService.ts +308 -0
  723. package/libs/instance-factories/tools/templates/mcp/static/src/services/HybridResourcesProvider.ts +210 -0
  724. package/libs/instance-factories/tools/templates/mcp/static/src/services/LibraryToolsService.ts +356 -0
  725. package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorBridge.ts +522 -0
  726. package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorToolsService.ts +530 -0
  727. package/libs/instance-factories/tools/templates/mcp/static/src/services/PromptToolsService.ts +594 -0
  728. package/libs/instance-factories/tools/templates/mcp/static/src/services/ResourcesProviderService.ts +170 -0
  729. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.init.test.ts +544 -0
  730. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.test.ts +189 -0
  731. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/ResourcesProviderService.test.ts +89 -0
  732. package/libs/instance-factories/tools/templates/mcp/static/src/types/index.ts +110 -0
  733. package/libs/instance-factories/tools/templates/mcp/static/tsconfig.json +28 -0
  734. package/libs/instance-factories/tools/templates/vscode/static/extension.ts +1195 -0
  735. package/libs/instance-factories/tools/templates/vscode/static/language-configuration.json +34 -0
  736. package/libs/instance-factories/tools/templates/vscode/static/schemas/specverse-v3-schema.json +4279 -0
  737. package/libs/instance-factories/tools/templates/vscode/static/syntaxes/specverse.tmLanguage.json +138 -0
  738. package/libs/instance-factories/tools/templates/vscode/static/themes/README.md +74 -0
  739. package/libs/instance-factories/tools/templates/vscode/static/themes/complete-specverse-colors.json +122 -0
  740. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-basic-theme.json +65 -0
  741. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-complete-theme.json +123 -0
  742. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-theme-colors.json +64 -0
  743. package/libs/instance-factories/tools/templates/vscode/vscode-extension-generator.ts +300 -0
  744. package/libs/instance-factories/tools/vscode.yaml +35 -0
  745. package/libs/instance-factories/validation/README.md +38 -0
  746. package/libs/instance-factories/validation/templates/zod/validation-generator.ts +46 -0
  747. package/libs/instance-factories/validation/zod.yaml +56 -0
  748. package/libs/instance-factories/views/README.md +62 -0
  749. package/libs/instance-factories/views/index.d.ts +13 -0
  750. package/libs/instance-factories/views/index.d.ts.map +1 -0
  751. package/libs/instance-factories/views/index.js +18 -0
  752. package/libs/instance-factories/views/index.js.map +1 -0
  753. package/libs/instance-factories/views/index.ts +45 -0
  754. package/libs/instance-factories/views/react-components.yaml +129 -0
  755. package/libs/instance-factories/views/templates/ARCHITECTURE.md +198 -0
  756. package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +869 -0
  757. package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +953 -0
  758. package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +806 -0
  759. package/libs/instance-factories/views/templates/react/app-generator.ts +55 -0
  760. package/libs/instance-factories/views/templates/react/components-generator.ts +887 -0
  761. package/libs/instance-factories/views/templates/react/forms-generator.ts +343 -0
  762. package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +57 -0
  763. package/libs/instance-factories/views/templates/react/hooks-generator.ts +122 -0
  764. package/libs/instance-factories/views/templates/react/index-css-generator.ts +14 -0
  765. package/libs/instance-factories/views/templates/react/index-html-generator.ts +34 -0
  766. package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +29 -0
  767. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +152 -0
  768. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +1 -0
  769. package/libs/instance-factories/views/templates/react/react-component-generator.js +398 -0
  770. package/libs/instance-factories/views/templates/react/react-component-generator.js.map +1 -0
  771. package/libs/instance-factories/views/templates/react/react-component-generator.ts +533 -0
  772. package/libs/instance-factories/views/templates/react/router-generator.ts +197 -0
  773. package/libs/instance-factories/views/templates/react/router-generic-generator.ts +132 -0
  774. package/libs/instance-factories/views/templates/react/shared-utils-generator.ts +188 -0
  775. package/libs/instance-factories/views/templates/react/spec-json-generator.ts +17 -0
  776. package/libs/instance-factories/views/templates/react/types-generator.ts +76 -0
  777. package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +42 -0
  778. package/libs/instance-factories/views/templates/react/vite-config-generator.ts +38 -0
  779. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +1 -0
  780. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +1 -0
  781. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +474 -0
  782. package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +242 -0
  783. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +77 -0
  784. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +1 -0
  785. package/libs/instance-factories/views/templates/shared/adapter-types.js +47 -0
  786. package/libs/instance-factories/views/templates/shared/adapter-types.js.map +1 -0
  787. package/libs/instance-factories/views/templates/shared/adapter-types.ts +142 -0
  788. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +63 -0
  789. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +1 -0
  790. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +822 -0
  791. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +1 -0
  792. package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +908 -0
  793. package/libs/instance-factories/views/templates/shared/base-generator.d.ts +247 -0
  794. package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +1 -0
  795. package/libs/instance-factories/views/templates/shared/base-generator.js +363 -0
  796. package/libs/instance-factories/views/templates/shared/base-generator.js.map +1 -0
  797. package/libs/instance-factories/views/templates/shared/base-generator.ts +608 -0
  798. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +254 -0
  799. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +1 -0
  800. package/libs/instance-factories/views/templates/shared/component-metadata.js +602 -0
  801. package/libs/instance-factories/views/templates/shared/component-metadata.js.map +1 -0
  802. package/libs/instance-factories/views/templates/shared/component-metadata.ts +803 -0
  803. package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +250 -0
  804. package/libs/instance-factories/views/templates/shared/composite-patterns.ts +535 -0
  805. package/libs/instance-factories/views/templates/shared/index.ts +68 -0
  806. package/libs/instance-factories/views/templates/shared/pattern-validator.ts +279 -0
  807. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +149 -0
  808. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +1 -0
  809. package/libs/instance-factories/views/templates/shared/property-mapper.js +580 -0
  810. package/libs/instance-factories/views/templates/shared/property-mapper.js.map +1 -0
  811. package/libs/instance-factories/views/templates/shared/property-mapper.ts +700 -0
  812. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +143 -0
  813. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +1 -0
  814. package/libs/instance-factories/views/templates/shared/syntax-mapper.js +420 -0
  815. package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +1 -0
  816. package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +539 -0
  817. package/package.json +63 -0
@@ -0,0 +1,1036 @@
1
+ /**
2
+ * Command Generator
3
+ *
4
+ * Generates individual command files from command specifications.
5
+ * Each command registers itself on a Commander program and wires
6
+ * to its corresponding service for business logic delegation.
7
+ */
8
+
9
+ import type { TemplateContext } from '@specverse/types';
10
+
11
+ /**
12
+ * Generate a single command file.
13
+ * Called once per command in the spec.
14
+ */
15
+ export default function generateCommand(context: TemplateContext): string {
16
+ const { command } = context;
17
+
18
+ if (!command) {
19
+ throw new Error('Command is required in template context');
20
+ }
21
+
22
+ const name = command.name;
23
+ const description = command.description || '';
24
+ const args = command.arguments || {};
25
+ const flags = command.flags || {};
26
+ const exitCodes = command.exitCodes || {};
27
+ const subcommands = command.subcommands || {};
28
+ const serviceRef = command.serviceRef;
29
+
30
+ // Build positional argument string for Commander
31
+ const positionalArgs = Object.entries(args)
32
+ .filter(([_, arg]: [string, any]) => arg.positional)
33
+ .sort((a: any, b: any) => (a[1].position || 0) - (b[1].position || 0))
34
+ .map(([argName, arg]: [string, any]) => {
35
+ const required = arg.required;
36
+ return required ? `<${argName}>` : `[${argName}]`;
37
+ })
38
+ .join(' ');
39
+
40
+ const commandStr = positionalArgs ? `${name} ${positionalArgs}` : name;
41
+
42
+ // Build options
43
+ const optionDefs = Object.entries(flags).map(([flagName, flag]: [string, any]) => {
44
+ const alias = flag.alias ? `${flag.alias}, ` : '';
45
+ const flagType = flag.type?.toLowerCase();
46
+ const valuePart = flagType === 'boolean' ? '' : ` <${flagName.replace(/^--/, '')}>`;
47
+ const defaultVal = flag.default !== undefined ? `, ${JSON.stringify(flag.default)}` : '';
48
+ const desc = flag.description || `${flagName} option`;
49
+ return ` .option('${alias}${flagName}${valuePart}', '${desc}'${defaultVal})`;
50
+ });
51
+
52
+ // Build type interface for options
53
+ const optionTypes = Object.entries(flags).map(([flagName, flag]: [string, any]) => {
54
+ const tsType = mapFlagTypeToTS(flag.type);
55
+ const key = flagName.replace(/^--/, '').replace(/-([a-z])/g, (_, c: string) => c.toUpperCase());
56
+ return ` ${key}${flag.required ? '' : '?'}: ${tsType};`;
57
+ });
58
+
59
+ // Build positional arg types
60
+ const argTypes = Object.entries(args)
61
+ .filter(([_, arg]: [string, any]) => arg.positional)
62
+ .map(([argName, arg]: [string, any]) => {
63
+ const tsType = mapArgTypeToTS(arg.type);
64
+ return `${argName}: ${tsType}`;
65
+ });
66
+
67
+ // Generate action handler
68
+ const actionParams = argTypes.length > 0
69
+ ? argTypes.join(', ') + ', options: CommandOptions'
70
+ : 'options: CommandOptions';
71
+
72
+ // Generate exit code comments
73
+ const exitCodeComments = Object.entries(exitCodes).length > 0
74
+ ? Object.entries(exitCodes).map(([code, meaning]) =>
75
+ ` // ${code}: ${meaning}`
76
+ ).join('\n')
77
+ : '';
78
+
79
+ // Handle subcommands
80
+ const hasSubcommands = Object.keys(subcommands).length > 0;
81
+ const subcommandRegistrations = hasSubcommands
82
+ ? generateSubcommandRegistrations(name, subcommands)
83
+ : '';
84
+
85
+ // Service import
86
+ const serviceImport = serviceRef
87
+ ? `import { ${serviceRef} } from '../services/${serviceRef}.js';`
88
+ : '';
89
+
90
+ // Collect engine imports — deduplicate across parent and subcommand handlers
91
+ const allImportSets: string[] = [];
92
+ if (ENGINE_HANDLERS[name]?.imports) allImportSets.push(ENGINE_HANDLERS[name].imports);
93
+ if (hasSubcommands) {
94
+ for (const subName of Object.keys(subcommands)) {
95
+ const key = `${name}.${subName}`;
96
+ if (ENGINE_HANDLERS[key]?.imports) allImportSets.push(ENGINE_HANDLERS[key].imports);
97
+ }
98
+ }
99
+ const engineImports = deduplicateImports(allImportSets);
100
+
101
+ return `/**
102
+ * ${name} command
103
+ * ${description}
104
+ * Generated from SpecVerse specification
105
+ */
106
+
107
+ import { Command } from 'commander';
108
+ ${serviceImport}
109
+ ${engineImports}
110
+
111
+ interface CommandOptions {
112
+ ${optionTypes.length > 0 ? optionTypes.join('\n') : ' [key: string]: any;'}
113
+ }
114
+
115
+ ${exitCodeComments ? `/**\n * Exit codes:\n${exitCodeComments}\n */` : ''}
116
+
117
+ /**
118
+ * Register the ${name} command on the program.
119
+ */
120
+ export function register${capitalize(name)}Command(program: Command): void {
121
+ ${hasSubcommands ? generateCommandWithSubcommands(name, description, subcommands, optionDefs) : generateLeafCommand(name, description, commandStr, optionDefs, actionParams, serviceRef, exitCodes)}
122
+ }
123
+ ${subcommandRegistrations}
124
+ `;
125
+ }
126
+
127
+ /**
128
+ * Engine-wired command handlers for known SpecVerse commands.
129
+ * Each generates the action body that calls the actual engine.
130
+ * Unknown commands get a stub.
131
+ */
132
+ const ENGINE_HANDLERS: Record<string, { imports: string; handler: string }> = {
133
+ validate: {
134
+ imports: `import { readFileSync, existsSync } from 'fs';
135
+ import { EngineRegistry } from '@specverse/entities';
136
+ import type { ParserEngine } from '@specverse/types';`,
137
+ handler: `if (!existsSync(file)) {
138
+ console.error('File not found:', file);
139
+ process.exit(1);
140
+ }
141
+
142
+ // Discover and initialize parser engine
143
+ const registry = new EngineRegistry();
144
+ await registry.discover();
145
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
146
+ if (!parser) {
147
+ console.error('No parser engine found. Install @specverse/engines.');
148
+ process.exit(1);
149
+ }
150
+ await parser.initialize();
151
+
152
+ const content = readFileSync(file, 'utf8');
153
+ const result = parser.parseContent(content, file);
154
+
155
+ if (result.errors.length > 0) {
156
+ console.error('Validation failed');
157
+ result.errors.forEach((e: string) => console.error(' ', e));
158
+ if (result.warnings && result.warnings.length > 0) {
159
+ console.warn('Warnings:');
160
+ result.warnings.forEach((w: string) => console.warn(' ', w));
161
+ }
162
+ process.exit(1);
163
+ }
164
+
165
+ if (options.json) {
166
+ console.log(JSON.stringify({ valid: true, warnings: result.warnings }, null, 2));
167
+ } else {
168
+ console.log('Validation successful');
169
+ if (result.warnings && result.warnings.length > 0) {
170
+ console.warn('Warnings:');
171
+ result.warnings.forEach((w: string) => console.warn(' ', w));
172
+ }
173
+ }`
174
+ },
175
+ infer: {
176
+ imports: `import { readFileSync, writeFileSync, existsSync } from 'fs';
177
+ import { EngineRegistry } from '@specverse/entities';
178
+ import type { ParserEngine, InferenceEngine } from '@specverse/types';`,
179
+ handler: `if (!existsSync(file)) {
180
+ console.error('File not found:', file);
181
+ process.exit(1);
182
+ }
183
+
184
+ console.log('Running inference on', file, '...');
185
+
186
+ // Discover engines
187
+ const registry = new EngineRegistry();
188
+ await registry.discover();
189
+
190
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
191
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
192
+ await parser.initialize();
193
+
194
+ const inferEngine = registry.getEngineForCapability('infer') as InferenceEngine;
195
+ if (!inferEngine) { console.error('No inference engine found.'); process.exit(1); }
196
+ await inferEngine.initialize({ options: { verbose: options.verbose } });
197
+
198
+ const content = readFileSync(file, 'utf8');
199
+ const parseResult = parser.parseContent(content, file);
200
+
201
+ if (parseResult.errors.length > 0) {
202
+ console.error('Cannot infer from invalid specification:');
203
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
204
+ process.exit(1);
205
+ }
206
+
207
+ const ast = parseResult.ast!;
208
+ const inferResult = await inferEngine.infer(ast, {
209
+ generateControllers: true,
210
+ generateServices: true,
211
+ generateEvents: true,
212
+ generateViews: true,
213
+ generateDeployment: options.deployment || false,
214
+ verbose: options.verbose || false,
215
+ });
216
+
217
+ const outputFile = options.output || file.replace(/\\.specly$/, '-inferred.specly');
218
+ writeFileSync(outputFile, inferResult.yaml, 'utf8');
219
+ console.log('Inferred specification written to:', outputFile);`
220
+ },
221
+ realize: {
222
+ imports: `import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'fs';
223
+ import { resolve, join } from 'path';
224
+ import { EngineRegistry } from '@specverse/entities';
225
+ import type { ParserEngine, InferenceEngine, RealizeEngine } from '@specverse/types';`,
226
+ handler: `if (!existsSync(file)) {
227
+ console.error('File not found:', file);
228
+ process.exit(1);
229
+ }
230
+
231
+ // Discover engines
232
+ const registry = new EngineRegistry();
233
+ await registry.discover();
234
+
235
+ // Parse — let the parser engine handle its own schema
236
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
237
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
238
+ await parser.initialize();
239
+
240
+ const content = readFileSync(file, 'utf8');
241
+ const parseResult = parser.parseContent(content, file);
242
+ if (parseResult.errors.length > 0) {
243
+ console.error('Invalid spec:');
244
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
245
+ process.exit(1);
246
+ }
247
+
248
+ // Infer — let the inference engine handle its own rules
249
+ const inferEngine = registry.getEngineForCapability('infer') as InferenceEngine;
250
+ if (!inferEngine) { console.error('No inference engine found.'); process.exit(1); }
251
+ await inferEngine.initialize();
252
+ const inferResult = await inferEngine.infer(parseResult.ast!, {
253
+ generateControllers: true, generateServices: true,
254
+ generateEvents: true, generateViews: true,
255
+ });
256
+
257
+ // Load inferred YAML and flatten component data for realize
258
+ const yaml = await import('js-yaml');
259
+ const inferredYaml = yaml.load(inferResult.yaml) as any;
260
+ // Inference output: { components: { Name: { models, controllers, ... } } }
261
+ // realizeAll expects: { models: {...}, controllers: {...}, ... } (flat component data)
262
+ const componentName = Object.keys(inferredYaml?.components || {})[0];
263
+ const componentData = componentName ? inferredYaml.components[componentName] : {};
264
+
265
+ // Merge original spec's services/events/views that inference didn't generate
266
+ // (inference generates from models; explicit services in the spec are preserved here)
267
+ const origComponent = parseResult.ast!.components?.[0] || {};
268
+ for (const section of ['services', 'events', 'views']) {
269
+ const origData = (origComponent as any)[section];
270
+ if (origData && (!componentData[section] || JSON.stringify(componentData[section]) === '{}')) {
271
+ // Convert array form (from parser) to object form (for realize)
272
+ if (Array.isArray(origData)) {
273
+ componentData[section] = {};
274
+ for (const item of origData) {
275
+ componentData[section][item.name] = item;
276
+ }
277
+ } else {
278
+ componentData[section] = origData;
279
+ }
280
+ }
281
+ }
282
+
283
+ // Inject key as name into entity maps, and expand convention-format attributes
284
+ // Iterate all object-valued sections (not hardcoded — covers any entity type)
285
+ const entitySections = Object.keys(componentData).filter(k =>
286
+ componentData[k] && typeof componentData[k] === 'object' && !Array.isArray(componentData[k])
287
+ && !['version', 'description', 'name', 'componentName', 'commonDefinitions'].includes(k)
288
+ );
289
+ for (const section of entitySections) {
290
+ if (componentData[section] && typeof componentData[section] === 'object' && !Array.isArray(componentData[section])) {
291
+ for (const [key, value] of Object.entries(componentData[section])) {
292
+ if (value && typeof value === 'object') {
293
+ (value as any).name = key;
294
+ // Expand convention-format attributes: { attrName: "Type modifiers" } → [{ name, type, ... }]
295
+ if ((value as any).attributes && typeof (value as any).attributes === 'object' && !Array.isArray((value as any).attributes)) {
296
+ (value as any).attributes = Object.entries((value as any).attributes).map(([attrName, attrDef]: [string, any]) => {
297
+ if (typeof attrDef === 'string') {
298
+ const parts = attrDef.split(' ');
299
+ return { name: attrName, type: parts[0], required: parts.includes('required'), unique: parts.includes('unique'), auto: parts.find((p: string) => p.startsWith('auto='))?.split('=')[1] };
300
+ }
301
+ return { name: attrName, ...(typeof attrDef === 'object' ? attrDef : {}) };
302
+ });
303
+ }
304
+ // Expand convention-format relationships: { relName: "type Target modifiers" } → array
305
+ if ((value as any).relationships && typeof (value as any).relationships === 'object' && !Array.isArray((value as any).relationships)) {
306
+ (value as any).relationships = Object.entries((value as any).relationships).map(([relName, relDef]: [string, any]) => {
307
+ if (typeof relDef === 'object') return { name: relName, ...relDef };
308
+ if (typeof relDef === 'string') {
309
+ const parts = relDef.split(' ');
310
+ return { name: relName, type: parts[0], target: parts[1], cascade: parts.includes('cascade') };
311
+ }
312
+ return { name: relName };
313
+ });
314
+ }
315
+ }
316
+ }
317
+ }
318
+ }
319
+ const inferredSpec = { ...componentData, componentName, components: inferredYaml?.components || {} };
320
+
321
+ // Realize — let the realize engine handle its own library
322
+ const manifestPath = options.manifest || resolve(process.cwd(), 'manifests/implementation.yaml');
323
+ if (!existsSync(manifestPath)) {
324
+ console.error('Manifest not found:', manifestPath);
325
+ process.exit(1);
326
+ }
327
+
328
+ // Runtime mode (default): swap ReactApp → ReactAppRuntime in manifest
329
+ let effectiveManifestPath = manifestPath;
330
+ if (!options.static) {
331
+ const manifestContent = readFileSync(manifestPath, 'utf8');
332
+ if (/instanceFactory:\\s*["']?ReactApp["']?\\s*$/m.test(manifestContent)) {
333
+ const { tmpdir } = await import('os');
334
+ const runtimeManifest = manifestContent.replace(
335
+ /instanceFactory:\\s*["']?ReactApp["']?\\s*$/gm,
336
+ 'instanceFactory: "ReactAppRuntime"'
337
+ );
338
+ effectiveManifestPath = join(tmpdir(), 'specverse-runtime-manifest.yaml');
339
+ writeFileSync(effectiveManifestPath, runtimeManifest, 'utf8');
340
+ console.log(' Using runtime mode (slim frontend with @specverse/runtime)');
341
+ }
342
+ } else {
343
+ console.log(' Using static mode (full frontend generation)');
344
+ }
345
+
346
+ const realizeEngine = registry.getEngineForCapability('realize') as RealizeEngine;
347
+ if (!realizeEngine) { console.error('No realize engine found.'); process.exit(1); }
348
+ await realizeEngine.initialize({ manifestPath: effectiveManifestPath, workingDir: process.cwd() });
349
+
350
+ const outputDir = options.output || resolve(process.cwd(), 'generated/code');
351
+ console.log('Realizing ' + type + ' from ' + file + '...');
352
+ await (realizeEngine as any).realizeAll(inferredSpec, outputDir);
353
+
354
+ // Write dev.specly for runtime mode
355
+ if (!options.static && inferResult.devYaml) {
356
+ const frontendDir = join(outputDir, 'frontend', 'src');
357
+ mkdirSync(frontendDir, { recursive: true });
358
+ const devSpeclyPath = join(frontendDir, 'dev.specly');
359
+ writeFileSync(devSpeclyPath, inferResult.devYaml, 'utf8');
360
+ console.log(' Wrote dev.specly →', devSpeclyPath);
361
+ }`
362
+ },
363
+ init: {
364
+ imports: `import { existsSync, mkdirSync, readdirSync, statSync, readFileSync, writeFileSync, copyFileSync } from 'fs';
365
+ import { resolve, join, dirname } from 'path';
366
+ import { fileURLToPath } from 'url';`,
367
+ handler: `const __fn = fileURLToPath(import.meta.url);
368
+ const __dn = dirname(__fn);
369
+
370
+ // Resolve templates from package.json "specverse.templateDir" config
371
+ const templatesDir = await (async () => {
372
+ const { createRequire } = await import('module');
373
+ const require = createRequire(import.meta.url);
374
+
375
+ // Find our own package.json by walking up
376
+ let dir = __dn;
377
+ while (dir !== dirname(dir)) {
378
+ const pkgPath = join(dir, 'package.json');
379
+ if (existsSync(pkgPath)) {
380
+ const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));
381
+ if (pkg.specverse?.templateDir) {
382
+ const candidate = resolve(dir, pkg.specverse.templateDir);
383
+ if (existsSync(candidate)) return candidate;
384
+ }
385
+ }
386
+ dir = dirname(dir);
387
+ }
388
+
389
+ // Fallback: engine-realize assets
390
+ try {
391
+ const realizePkg = dirname(require.resolve('@specverse/engine-realize/package.json'));
392
+ const candidate = join(realizePkg, 'assets', 'templates');
393
+ if (existsSync(candidate)) return candidate;
394
+ } catch { /* not installed */ }
395
+
396
+ return null;
397
+ })();
398
+
399
+ if (!templatesDir) {
400
+ console.error('Templates not found. Set "specverse.templateDir" in package.json or install @specverse/engine-realize.');
401
+ process.exit(1);
402
+ }
403
+
404
+ if (options.list) {
405
+ const templates = readdirSync(templatesDir).filter(
406
+ d => statSync(join(templatesDir!, d)).isDirectory()
407
+ );
408
+ console.log('Available templates:');
409
+ templates.forEach(t => console.log(' ' + t));
410
+ return;
411
+ }
412
+
413
+ const projectName = name || 'my-project';
414
+ const templateName = options.template || 'default';
415
+ const templateDir = join(templatesDir, templateName);
416
+
417
+ if (!existsSync(templateDir)) {
418
+ console.error('Template not found: ' + templateName);
419
+ console.error('Available: ' + readdirSync(templatesDir).filter(
420
+ d => statSync(join(templatesDir!, d)).isDirectory()
421
+ ).join(', '));
422
+ process.exit(1);
423
+ }
424
+
425
+ const destDir = resolve(process.cwd(), projectName);
426
+ if (existsSync(destDir)) {
427
+ console.error('Directory already exists: ' + destDir);
428
+ process.exit(1);
429
+ }
430
+
431
+ // Copy template with variable substitution
432
+ const kebab = projectName.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
433
+ const component = projectName.charAt(0).toUpperCase() + projectName.slice(1);
434
+ const vars: Record<string, string> = {
435
+ '{{PROJECT_NAME}}': projectName,
436
+ '{{projectName}}': projectName,
437
+ '{{projectNameKebab}}': kebab,
438
+ '{{componentName}}': component,
439
+ '{{DB_USER}}': 'postgres',
440
+ '{{DB_PASSWORD}}': 'postgres',
441
+ };
442
+
443
+ function copyDir(src: string, dest: string) {
444
+ mkdirSync(dest, { recursive: true });
445
+ for (const item of readdirSync(src)) {
446
+ const srcPath = join(src, item);
447
+ let destName = item;
448
+ if (item === 'gitignore') destName = '.gitignore';
449
+ if (item === 'dot.env.example') destName = '.env.example';
450
+ const destPath = join(dest, destName);
451
+
452
+ if (statSync(srcPath).isDirectory()) {
453
+ copyDir(srcPath, destPath);
454
+ } else {
455
+ let content = readFileSync(srcPath, 'utf8');
456
+ for (const [key, val] of Object.entries(vars)) {
457
+ content = content.split(key).join(val);
458
+ }
459
+ writeFileSync(destPath, content);
460
+ }
461
+ }
462
+ }
463
+
464
+ copyDir(templateDir, destDir);
465
+ console.log('Project created: ' + destDir);
466
+ console.log('Template: ' + templateName);
467
+ console.log('');
468
+ console.log('Next steps:');
469
+ console.log(' cd ' + projectName);
470
+ console.log(' npm run setup # validate, generate code, install deps, setup db');
471
+ console.log(' npm run dev:backend # start backend (terminal 1)');
472
+ console.log(' npm run dev:frontend # start frontend (terminal 2)');`
473
+ },
474
+ // === gen subcommands ===
475
+ 'gen.diagrams': {
476
+ imports: `import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'fs';
477
+ import { resolve, dirname, basename, join } from 'path';
478
+ import { fileURLToPath } from 'url';
479
+ import { EngineRegistry } from '@specverse/entities';
480
+ import type { ParserEngine } from '@specverse/types';`,
481
+ handler: `const registry = new EngineRegistry();
482
+ await registry.discover();
483
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
484
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
485
+ await parser.initialize();
486
+
487
+ const content = readFileSync(file, 'utf8');
488
+ const parseResult = parser.parseContent(content, file);
489
+ if (parseResult.errors.length > 0) {
490
+ console.error('Invalid spec:');
491
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
492
+ process.exit(1);
493
+ }
494
+
495
+ const gen = registry.getEngineForCapability('generate-diagrams') as any;
496
+ if (!gen) { console.error('No generators engine found.'); process.exit(1); }
497
+ await gen.initialize();
498
+
499
+ const diagrams = await gen.generateDiagrams(parseResult.ast!, { type: options.type || 'all' });
500
+ const outputDir = options.output || basename(file, '.specly') + '-diagrams';
501
+ if (!existsSync(outputDir)) mkdirSync(outputDir, { recursive: true });
502
+ for (const [diagramType, diagramContent] of diagrams.entries()) {
503
+ writeFileSync(join(outputDir, diagramType + '.mmd'), diagramContent);
504
+ console.log(' ' + diagramType);
505
+ }
506
+ console.log('Generated ' + diagrams.size + ' diagrams in: ' + outputDir);`
507
+ },
508
+ 'gen.docs': {
509
+ imports: `import { readFileSync, writeFileSync, existsSync } from 'fs';
510
+ import { resolve, dirname, basename } from 'path';
511
+ import { fileURLToPath } from 'url';
512
+ import { EngineRegistry } from '@specverse/entities';
513
+ import type { ParserEngine } from '@specverse/types';`,
514
+ handler: `const registry = new EngineRegistry();
515
+ await registry.discover();
516
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
517
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
518
+ await parser.initialize();
519
+
520
+ const content = readFileSync(file, 'utf8');
521
+ const parseResult = parser.parseContent(content, file);
522
+ if (parseResult.errors.length > 0) {
523
+ console.error('Invalid spec:');
524
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
525
+ process.exit(1);
526
+ }
527
+
528
+ const gen = registry.getEngineForCapability('generate-docs') as any;
529
+ if (!gen) { console.error('No generators engine found.'); process.exit(1); }
530
+ await gen.initialize();
531
+
532
+ const docs = await gen.generateDocs(parseResult.ast!, { format: options.format || 'markdown' });
533
+ const ext = options.format === 'html' ? '.html' : '.md';
534
+ const outputFile = options.output || basename(file, '.specly') + '-docs' + ext;
535
+ writeFileSync(outputFile, docs);
536
+ console.log('Documentation generated: ' + outputFile);`
537
+ },
538
+ 'gen.uml': {
539
+ imports: `import { readFileSync, writeFileSync, existsSync } from 'fs';
540
+ import { resolve, dirname, basename } from 'path';
541
+ import { fileURLToPath } from 'url';
542
+ import { EngineRegistry } from '@specverse/entities';
543
+ import type { ParserEngine } from '@specverse/types';`,
544
+ handler: `const registry = new EngineRegistry();
545
+ await registry.discover();
546
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
547
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
548
+ await parser.initialize();
549
+
550
+ const content = readFileSync(file, 'utf8');
551
+ const parseResult = parser.parseContent(content, file);
552
+ if (parseResult.errors.length > 0) {
553
+ console.error('Invalid spec:');
554
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
555
+ process.exit(1);
556
+ }
557
+
558
+ const gen = registry.getEngineForCapability('generate-uml') as any;
559
+ if (!gen) { console.error('No generators engine found.'); process.exit(1); }
560
+ await gen.initialize();
561
+
562
+ const uml = await gen.generateUML(parseResult.ast!, { type: options.type || 'all' });
563
+ const outputFile = basename(file, '.specly') + '-uml.puml';
564
+ writeFileSync(outputFile, uml);
565
+ console.log('UML generated: ' + outputFile);`
566
+ },
567
+ // === dev subcommands ===
568
+ 'dev.format': {
569
+ imports: `import { readFileSync, writeFileSync, existsSync } from 'fs';
570
+ import { resolve, dirname } from 'path';
571
+ import { fileURLToPath } from 'url';
572
+ import { EngineRegistry } from '@specverse/entities';
573
+ import type { ParserEngine } from '@specverse/types';`,
574
+ handler: `const registry = new EngineRegistry();
575
+ await registry.discover();
576
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
577
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
578
+ await parser.initialize();
579
+
580
+ const content = readFileSync(file, 'utf8');
581
+ const result = parser.parseContent(content, file);
582
+ if (result.errors.length > 0) {
583
+ console.error('Cannot format invalid spec:');
584
+ result.errors.forEach((e: string) => console.error(' ', e));
585
+ process.exit(1);
586
+ }
587
+ const yaml = await import('js-yaml');
588
+ const formatted = yaml.dump(yaml.load(content), { lineWidth: 120, noRefs: true });
589
+ if (options.write) {
590
+ writeFileSync(file, formatted);
591
+ console.log('Formatted and saved: ' + file);
592
+ } else {
593
+ console.log(formatted);
594
+ }`
595
+ },
596
+ 'dev.watch': {
597
+ imports: `import { readFileSync, existsSync, watch } from 'fs';
598
+ import { resolve, dirname } from 'path';
599
+ import { fileURLToPath } from 'url';
600
+ import { EngineRegistry } from '@specverse/entities';
601
+ import type { ParserEngine } from '@specverse/types';`,
602
+ handler: `const registry = new EngineRegistry();
603
+ await registry.discover();
604
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
605
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
606
+ await parser.initialize();
607
+
608
+ console.log('Watching ' + file + ' for changes...');
609
+ const doValidate = () => {
610
+ try {
611
+ const c = readFileSync(file, 'utf8');
612
+ const r = parser.parseContent(c, file);
613
+ if (r.errors.length > 0) {
614
+ console.log('[' + new Date().toLocaleTimeString() + '] FAILED');
615
+ r.errors.forEach((e: string) => console.error(' ', e));
616
+ } else {
617
+ console.log('[' + new Date().toLocaleTimeString() + '] Valid');
618
+ }
619
+ } catch (e: any) { console.error('Watch error:', e.message); }
620
+ };
621
+ doValidate();
622
+ watch(file, doValidate);
623
+ await new Promise(() => {});`
624
+ },
625
+ 'dev.quick': {
626
+ imports: `import { readFileSync, existsSync } from 'fs';
627
+ import { resolve, dirname } from 'path';
628
+ import { fileURLToPath } from 'url';
629
+ import { EngineRegistry } from '@specverse/entities';
630
+ import type { ParserEngine } from '@specverse/types';`,
631
+ handler: `const registry = new EngineRegistry();
632
+ await registry.discover();
633
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
634
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
635
+ await parser.initialize();
636
+
637
+ const content = readFileSync(file, 'utf8');
638
+ const result = parser.parseContent(content, file);
639
+ if (result.errors.length > 0) {
640
+ console.error('Quick check: FAILED');
641
+ result.errors.forEach((e: string) => console.error(' ', e));
642
+ process.exit(1);
643
+ }
644
+ console.log('Quick check: OK');`
645
+ },
646
+ // === cache command (leaf, not subcommand) ===
647
+ cache: {
648
+ imports: `import { EngineRegistry } from '@specverse/entities';
649
+ import type { ParserEngine } from '@specverse/types';`,
650
+ handler: `const registry = new EngineRegistry();
651
+ await registry.discover();
652
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
653
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
654
+ await parser.initialize();
655
+
656
+ // Access ImportResolver cache via parser
657
+ const resolverModule = await import('@specverse/engines/parser');
658
+ const resolver = new resolverModule.ImportResolver({ basePath: process.cwd() });
659
+
660
+ const cacheDir = (resolver as any).getCacheDir ? (resolver as any).getCacheDir() : null;
661
+ if (options.stats) {
662
+ console.log('Cache directory:', cacheDir || 'default');
663
+ } else if (options.list) {
664
+ if (cacheDir) {
665
+ const fs = await import('fs');
666
+ if (fs.existsSync(cacheDir)) {
667
+ const items = fs.readdirSync(cacheDir);
668
+ if (items.length === 0) { console.log('Cache is empty'); }
669
+ else { items.forEach((item: string) => console.log(' ', item)); }
670
+ } else { console.log('Cache directory does not exist'); }
671
+ } else { console.log('No cache directory configured'); }
672
+ } else if (options.clear) {
673
+ if (resolver.clearCache) { resolver.clearCache(); }
674
+ console.log('Cache cleared');
675
+ } else {
676
+ console.log('Use --stats, --list, or --clear');
677
+ }`
678
+ },
679
+ // === ai subcommands ===
680
+ 'ai.docs': {
681
+ imports: `import { readFileSync, writeFileSync, existsSync } from 'fs';
682
+ import { resolve, dirname, basename } from 'path';
683
+ import { fileURLToPath } from 'url';
684
+ import { EngineRegistry } from '@specverse/entities';
685
+ import type { ParserEngine } from '@specverse/types';`,
686
+ handler: `const registry = new EngineRegistry();
687
+ await registry.discover();
688
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
689
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
690
+ await parser.initialize();
691
+
692
+ const content = readFileSync(file, 'utf8');
693
+ const parseResult = parser.parseContent(content, file);
694
+ if (parseResult.errors.length > 0) {
695
+ console.error('Invalid spec:');
696
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
697
+ process.exit(1);
698
+ }
699
+
700
+ const aiEngine = registry.getEngineForCapability('ai-prompts') as any;
701
+ if (!aiEngine) {
702
+ console.error('AI engine not available. Install @specverse/engines.');
703
+ process.exit(1);
704
+ }
705
+ await aiEngine.initialize({ provider: options.provider });
706
+ const prompt = await aiEngine.generatePrompt(parseResult.ast!, { type: 'docs' });
707
+ const outputFile = options.output || basename(file, '.specly') + '-ai-docs.md';
708
+ writeFileSync(outputFile, prompt);
709
+ console.log('AI documentation prompt generated: ' + outputFile);`
710
+ },
711
+ 'ai.suggest': {
712
+ imports: `import { readFileSync, existsSync } from 'fs';
713
+ import { resolve, dirname } from 'path';
714
+ import { fileURLToPath } from 'url';
715
+ import { EngineRegistry } from '@specverse/entities';
716
+ import type { ParserEngine } from '@specverse/types';`,
717
+ handler: `const registry = new EngineRegistry();
718
+ await registry.discover();
719
+ const parser = registry.getEngineForCapability('parse') as ParserEngine;
720
+ if (!parser) { console.error('No parser engine found.'); process.exit(1); }
721
+ await parser.initialize();
722
+
723
+ const content = readFileSync(file, 'utf8');
724
+ const parseResult = parser.parseContent(content, file);
725
+ if (parseResult.errors.length > 0) {
726
+ console.error('Invalid spec:');
727
+ parseResult.errors.forEach((e: string) => console.error(' ', e));
728
+ process.exit(1);
729
+ }
730
+
731
+ const aiEngine = registry.getEngineForCapability('ai-suggestions') as any;
732
+ if (!aiEngine) {
733
+ console.error('AI engine not available. Install @specverse/engines.');
734
+ process.exit(1);
735
+ }
736
+ await aiEngine.initialize();
737
+ const suggestions = await aiEngine.suggest(parseResult.ast!);
738
+ if (suggestions.length === 0) {
739
+ console.log('No suggestions — spec looks good!');
740
+ } else {
741
+ const warnings = suggestions.filter((s: any) => s.severity === 'warning');
742
+ const improvements = suggestions.filter((s: any) => s.severity === 'improvement');
743
+ const info = suggestions.filter((s: any) => s.severity === 'info');
744
+ if (warnings.length > 0) {
745
+ console.log('\\nWarnings:');
746
+ warnings.forEach((s: any) => console.log(' [' + s.target + '] ' + s.description));
747
+ }
748
+ if (improvements.length > 0) {
749
+ console.log('\\nSuggested improvements:');
750
+ improvements.forEach((s: any) => console.log(' [' + s.target + '] ' + s.description));
751
+ }
752
+ if (info.length > 0) {
753
+ console.log('\\nInfo:');
754
+ info.forEach((s: any) => console.log(' [' + s.target + '] ' + s.description));
755
+ }
756
+ console.log('\\n' + suggestions.length + ' suggestion(s): ' + warnings.length + ' warning, ' + improvements.length + ' improvement, ' + info.length + ' info');
757
+ }`
758
+ },
759
+ 'ai.template': {
760
+ imports: `import { writeFileSync } from 'fs';
761
+ import { EngineRegistry } from '@specverse/entities';`,
762
+ handler: `const registry = new EngineRegistry();
763
+ await registry.discover();
764
+ const aiEngine = registry.getEngineForCapability('ai-templates') as any;
765
+ if (!aiEngine) {
766
+ console.error('AI engine not available. Install @specverse/engines.');
767
+ process.exit(1);
768
+ }
769
+ await aiEngine.initialize();
770
+ const template = await aiEngine.template(operation, { config: options.config });
771
+ if (options.output) {
772
+ writeFileSync(options.output, template);
773
+ console.log('Template written to: ' + options.output);
774
+ } else {
775
+ console.log(template);
776
+ }`
777
+ },
778
+ // === session subcommands ===
779
+ 'session.create': {
780
+ imports: `import { EngineRegistry } from '@specverse/entities';`,
781
+ handler: `const registry = new EngineRegistry();
782
+ await registry.discover();
783
+ const aiEngine = registry.getEngineForCapability('ai-prompts') as any;
784
+ if (!aiEngine) { console.error('AI engine not available.'); process.exit(1); }
785
+ await aiEngine.initialize();
786
+
787
+ const { SessionManager } = await import('@specverse/engines/ai');
788
+ const manager = new SessionManager();
789
+ const session = await manager.create({ name: options.name, pver: options.pver });
790
+
791
+ if (options.json) {
792
+ console.log(JSON.stringify(session, null, 2));
793
+ } else {
794
+ console.log('Session created: ' + session.sessionId);
795
+ console.log('Status: ' + session.status);
796
+ if (session.name) console.log('Name: ' + session.name);
797
+ console.log('Prompt version: ' + session.pver);
798
+ }`
799
+ },
800
+ 'session.list': {
801
+ imports: ``,
802
+ handler: `const { SessionManager } = await import('@specverse/engines/ai');
803
+ const manager = new SessionManager();
804
+ const sessions = await manager.list({ all: options.all });
805
+
806
+ if (options.json) {
807
+ console.log(JSON.stringify(sessions, null, 2));
808
+ } else if (sessions.length === 0) {
809
+ console.log('No sessions found. Create one with: specverse session create');
810
+ } else {
811
+ console.log('Sessions (' + sessions.length + '):');
812
+ for (const s of sessions) {
813
+ console.log(' ' + (s.status === 'active' ? '*' : ' ') + ' ' + s.sessionId + (s.name ? ' (' + s.name + ')' : '') + ' — ' + s.status + ', ' + s.jobsProcessed + ' jobs');
814
+ }
815
+ }`
816
+ },
817
+ 'session.delete': {
818
+ imports: ``,
819
+ handler: `const { SessionManager } = await import('@specverse/engines/ai');
820
+ const manager = new SessionManager();
821
+ await manager.delete(sessionId, { force: options.force });
822
+ console.log('Session deleted: ' + sessionId);`
823
+ },
824
+ 'session.submit': {
825
+ imports: ``,
826
+ handler: `const { SessionManager } = await import('@specverse/engines/ai');
827
+ const manager = new SessionManager();
828
+ const job = await manager.submit(sessionId, requirements, {
829
+ jobId: options.jobId,
830
+ outputPath: options.output,
831
+ operation: options.operation,
832
+ });
833
+ console.log('Job submitted: ' + job.jobId);
834
+ console.log('Status: ' + job.status);
835
+ if (options.output) console.log('Output: ' + options.output);`
836
+ },
837
+ 'session.status': {
838
+ imports: ``,
839
+ handler: `const { SessionManager } = await import('@specverse/engines/ai');
840
+ const manager = new SessionManager();
841
+ const status = await manager.status(id);
842
+ if (options.json) {
843
+ console.log(JSON.stringify(status, null, 2));
844
+ } else {
845
+ console.log('ID: ' + (status.sessionId || status.jobId));
846
+ console.log('Status: ' + status.status);
847
+ if (status.created) console.log('Created: ' + new Date(status.created).toLocaleString());
848
+ if (status.jobsProcessed !== undefined) console.log('Jobs: ' + status.jobsProcessed);
849
+ }`
850
+ },
851
+ 'session.process': {
852
+ imports: ``,
853
+ handler: `const { SessionManager } = await import('@specverse/engines/ai');
854
+ const manager = new SessionManager();
855
+ console.log('Processing job: ' + jobId);
856
+ await manager.process(jobId);
857
+ console.log('Job processed successfully');`
858
+ },
859
+ };
860
+
861
+ function generateLeafCommand(
862
+ name: string,
863
+ description: string,
864
+ commandStr: string,
865
+ optionDefs: string[],
866
+ actionParams: string,
867
+ serviceRef: string | undefined,
868
+ exitCodes: Record<string, string>
869
+ ): string {
870
+ // Check for engine-wired handler
871
+ const engineHandler = ENGINE_HANDLERS[name];
872
+ const handler = engineHandler
873
+ ? engineHandler.handler
874
+ : serviceRef
875
+ ? `const service = new ${serviceRef}();
876
+ const result = await service.execute(${actionParams.includes(':') ? '{ ' + actionParams.split(',').map(p => p.trim().split(':')[0].trim()).join(', ') + ', ...options }' : 'options'});
877
+ console.log(result);`
878
+ : `console.log('Executing ${name}...');
879
+ // TODO: Wire to service`;
880
+
881
+ return `const cmd = program
882
+ .command('${commandStr}')
883
+ .description('${description}')
884
+ ${optionDefs.join('\n')}
885
+ .action(async (${actionParams}) => {
886
+ try {
887
+ ${handler}
888
+ } catch (error: any) {
889
+ console.error('Error:', error.message);
890
+ process.exit(${Object.keys(exitCodes).find(k => k !== '0') || '1'});
891
+ }
892
+ });`;
893
+ }
894
+
895
+ function generateCommandWithSubcommands(
896
+ name: string,
897
+ description: string,
898
+ subcommands: Record<string, any>,
899
+ optionDefs: string[]
900
+ ): string {
901
+ const subcmdRegistrations = Object.entries(subcommands).map(([subName, subDef]) => {
902
+ const subDesc = subDef.description || '';
903
+ const subArgs = subDef.arguments || {};
904
+ const subFlags = subDef.flags || {};
905
+
906
+ const positionalStr = Object.entries(subArgs)
907
+ .filter(([_, a]: [string, any]) => a.positional)
908
+ .map(([n, a]: [string, any]) => a.required ? `<${n}>` : `[${n}]`)
909
+ .join(' ');
910
+
911
+ const subCmdStr = positionalStr ? `${subName} ${positionalStr}` : subName;
912
+
913
+ const subOptionDefs = Object.entries(subFlags).map(([flagName, flag]: [string, any]) => {
914
+ const alias = flag.alias ? `${flag.alias}, ` : '';
915
+ const flagType = flag.type?.toLowerCase();
916
+ const valuePart = flagType === 'boolean' ? '' : ` <${flagName.replace(/^--/, '')}>`;
917
+ const defaultVal = flag.default !== undefined ? `, ${JSON.stringify(flag.default)}` : '';
918
+ return ` .option('${alias}${flagName}${valuePart}', '${flag.description || flagName}'${defaultVal})`;
919
+ });
920
+
921
+ // Look up engine handler for this subcommand
922
+ const handlerKey = `${name}.${subName}`;
923
+ const engineHandler = ENGINE_HANDLERS[handlerKey];
924
+
925
+ // Build action parameters from subcommand args
926
+ const subArgTypes = Object.entries(subArgs)
927
+ .filter(([_, a]: [string, any]) => a.positional)
928
+ .map(([n, a]: [string, any]) => `${n}: ${mapArgTypeToTS(a.type)}`);
929
+ const subActionParams = subArgTypes.length > 0
930
+ ? subArgTypes.join(', ') + ', options: any'
931
+ : 'options: any';
932
+
933
+ const handler = engineHandler
934
+ ? engineHandler.handler
935
+ : `console.log('${name} ${subName}: not yet implemented via engine');`;
936
+
937
+ return `
938
+ cmd
939
+ .command('${subCmdStr}')
940
+ .description('${subDesc}')
941
+ ${subOptionDefs.join('\n')}
942
+ .action(async (${subActionParams}) => {
943
+ try {
944
+ ${handler}
945
+ } catch (error: any) {
946
+ console.error('Error:', error.message);
947
+ process.exit(1);
948
+ }
949
+ });`;
950
+ });
951
+
952
+ return `const cmd = program
953
+ .command('${name}')
954
+ .description('${description}');
955
+ ${subcmdRegistrations.join('\n')}`;
956
+ }
957
+
958
+ function generateSubcommandRegistrations(
959
+ _parentName: string,
960
+ _subcommands: Record<string, any>
961
+ ): string {
962
+ return ''; // Subcommands are registered inline
963
+ }
964
+
965
+ function mapFlagTypeToTS(type: string): string {
966
+ if (!type) return 'string';
967
+ const lower = type.toLowerCase();
968
+ if (lower === 'boolean') return 'boolean';
969
+ if (lower === 'number' || lower === 'integer') return 'number';
970
+ return 'string';
971
+ }
972
+
973
+ function mapArgTypeToTS(type: string): string {
974
+ if (!type) return 'string';
975
+ const lower = type.toLowerCase();
976
+ if (lower === 'filepath' || lower === 'string') return 'string';
977
+ if (lower === 'number' || lower === 'integer') return 'number';
978
+ if (lower === 'boolean') return 'boolean';
979
+ return 'string';
980
+ }
981
+
982
+ function capitalize(str: string): string {
983
+ // Convert hyphenated names to PascalCase: "validate-manifest" → "ValidateManifest"
984
+ return str.split('-').map(part => part.charAt(0).toUpperCase() + part.slice(1)).join('');
985
+ }
986
+
987
+ /**
988
+ * Deduplicate import statements across multiple handler import blocks.
989
+ * Merges named imports from the same module and removes exact duplicates.
990
+ */
991
+ function deduplicateImports(importBlocks: string[]): string {
992
+ const seen = new Map<string, Set<string>>(); // module -> set of named imports
993
+ const typeImports = new Map<string, Set<string>>(); // module -> set of type imports
994
+ const rawLines = new Set<string>(); // non-mergeable lines
995
+
996
+ for (const block of importBlocks) {
997
+ for (const line of block.split('\n').map(l => l.trim()).filter(l => l)) {
998
+ // Match: import { X, Y } from 'module';
999
+ const namedMatch = line.match(/^import\s+\{\s*(.+?)\s*\}\s+from\s+'(.+?)';?$/);
1000
+ if (namedMatch) {
1001
+ const names = namedMatch[1].split(',').map(n => n.trim());
1002
+ const mod = namedMatch[2];
1003
+ if (!seen.has(mod)) seen.set(mod, new Set());
1004
+ names.forEach(n => seen.get(mod)!.add(n));
1005
+ continue;
1006
+ }
1007
+ // Match: import type { X } from 'module';
1008
+ const typeMatch = line.match(/^import\s+type\s+\{\s*(.+?)\s*\}\s+from\s+'(.+?)';?$/);
1009
+ if (typeMatch) {
1010
+ const names = typeMatch[1].split(',').map(n => n.trim());
1011
+ const mod = typeMatch[2];
1012
+ if (!typeImports.has(mod)) typeImports.set(mod, new Set());
1013
+ names.forEach(n => typeImports.get(mod)!.add(n));
1014
+ continue;
1015
+ }
1016
+ rawLines.add(line);
1017
+ }
1018
+ }
1019
+
1020
+ const result: string[] = [];
1021
+ for (const [mod, names] of seen.entries()) {
1022
+ result.push(`import { ${[...names].join(', ')} } from '${mod}';`);
1023
+ }
1024
+ for (const [mod, names] of typeImports.entries()) {
1025
+ // Remove type imports that are already in regular imports
1026
+ const regularNames = seen.get(mod) || new Set();
1027
+ const typeOnly = [...names].filter(n => !regularNames.has(n));
1028
+ if (typeOnly.length > 0) {
1029
+ result.push(`import type { ${typeOnly.join(', ')} } from '${mod}';`);
1030
+ }
1031
+ }
1032
+ for (const line of rawLines) {
1033
+ result.push(line);
1034
+ }
1035
+ return result.join('\n');
1036
+ }