agenv-cli 0.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 (162) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +110 -0
  3. package/dist/adapters/claude/index.d.ts +2 -0
  4. package/dist/adapters/claude/index.js +50 -0
  5. package/dist/adapters/claude/index.js.map +1 -0
  6. package/dist/adapters/codex/index.d.ts +2 -0
  7. package/dist/adapters/codex/index.js +31 -0
  8. package/dist/adapters/codex/index.js.map +1 -0
  9. package/dist/adapters/copilot/index.d.ts +2 -0
  10. package/dist/adapters/copilot/index.js +34 -0
  11. package/dist/adapters/copilot/index.js.map +1 -0
  12. package/dist/adapters/index.d.ts +3 -0
  13. package/dist/adapters/index.js +18 -0
  14. package/dist/adapters/index.js.map +1 -0
  15. package/dist/adapters/mcp/index.d.ts +2 -0
  16. package/dist/adapters/mcp/index.js +45 -0
  17. package/dist/adapters/mcp/index.js.map +1 -0
  18. package/dist/adapters/types.d.ts +23 -0
  19. package/dist/adapters/types.js +2 -0
  20. package/dist/adapters/types.js.map +1 -0
  21. package/dist/cli/commands/diff.d.ts +18 -0
  22. package/dist/cli/commands/diff.js +65 -0
  23. package/dist/cli/commands/diff.js.map +1 -0
  24. package/dist/cli/commands/doctor.d.ts +2 -0
  25. package/dist/cli/commands/doctor.js +26 -0
  26. package/dist/cli/commands/doctor.js.map +1 -0
  27. package/dist/cli/commands/generate.d.ts +21 -0
  28. package/dist/cli/commands/generate.js +73 -0
  29. package/dist/cli/commands/generate.js.map +1 -0
  30. package/dist/cli/commands/init.d.ts +2 -0
  31. package/dist/cli/commands/init.js +93 -0
  32. package/dist/cli/commands/init.js.map +1 -0
  33. package/dist/cli/commands/templates-list.d.ts +2 -0
  34. package/dist/cli/commands/templates-list.js +20 -0
  35. package/dist/cli/commands/templates-list.js.map +1 -0
  36. package/dist/cli/index.d.ts +3 -0
  37. package/dist/cli/index.js +30 -0
  38. package/dist/cli/index.js.map +1 -0
  39. package/dist/cli/prompts/init-flow.d.ts +5 -0
  40. package/dist/cli/prompts/init-flow.js +23 -0
  41. package/dist/cli/prompts/init-flow.js.map +1 -0
  42. package/dist/cli/prompts/sessions/auth.d.ts +5 -0
  43. package/dist/cli/prompts/sessions/auth.js +6 -0
  44. package/dist/cli/prompts/sessions/auth.js.map +1 -0
  45. package/dist/cli/prompts/sessions/data.d.ts +5 -0
  46. package/dist/cli/prompts/sessions/data.js +6 -0
  47. package/dist/cli/prompts/sessions/data.js.map +1 -0
  48. package/dist/cli/prompts/sessions/output.d.ts +5 -0
  49. package/dist/cli/prompts/sessions/output.js +6 -0
  50. package/dist/cli/prompts/sessions/output.js.map +1 -0
  51. package/dist/cli/prompts/sessions/project-type.d.ts +5 -0
  52. package/dist/cli/prompts/sessions/project-type.js +6 -0
  53. package/dist/cli/prompts/sessions/project-type.js.map +1 -0
  54. package/dist/cli/prompts/sessions/quality.d.ts +5 -0
  55. package/dist/cli/prompts/sessions/quality.js +6 -0
  56. package/dist/cli/prompts/sessions/quality.js.map +1 -0
  57. package/dist/cli/prompts/sessions/setup-depth.d.ts +5 -0
  58. package/dist/cli/prompts/sessions/setup-depth.js +6 -0
  59. package/dist/cli/prompts/sessions/setup-depth.js.map +1 -0
  60. package/dist/cli/prompts/sessions/stack.d.ts +5 -0
  61. package/dist/cli/prompts/sessions/stack.js +6 -0
  62. package/dist/cli/prompts/sessions/stack.js.map +1 -0
  63. package/dist/cli/prompts/sessions/tooling.d.ts +5 -0
  64. package/dist/cli/prompts/sessions/tooling.js +6 -0
  65. package/dist/cli/prompts/sessions/tooling.js.map +1 -0
  66. package/dist/cli/prompts/sessions/tools.d.ts +5 -0
  67. package/dist/cli/prompts/sessions/tools.js +6 -0
  68. package/dist/cli/prompts/sessions/tools.js.map +1 -0
  69. package/dist/cli/prompts/sessions/ui.d.ts +5 -0
  70. package/dist/cli/prompts/sessions/ui.js +6 -0
  71. package/dist/cli/prompts/sessions/ui.js.map +1 -0
  72. package/dist/detect/dependencies.d.ts +8 -0
  73. package/dist/detect/dependencies.js +19 -0
  74. package/dist/detect/dependencies.js.map +1 -0
  75. package/dist/detect/existing-ai-files.d.ts +1 -0
  76. package/dist/detect/existing-ai-files.js +26 -0
  77. package/dist/detect/existing-ai-files.js.map +1 -0
  78. package/dist/detect/frameworks.d.ts +2 -0
  79. package/dist/detect/frameworks.js +13 -0
  80. package/dist/detect/frameworks.js.map +1 -0
  81. package/dist/detect/package-json.d.ts +7 -0
  82. package/dist/detect/package-json.js +20 -0
  83. package/dist/detect/package-json.js.map +1 -0
  84. package/dist/detect/repo-inspector.d.ts +10 -0
  85. package/dist/detect/repo-inspector.js +35 -0
  86. package/dist/detect/repo-inspector.js.map +1 -0
  87. package/dist/doctor/checks/compatibility.d.ts +4 -0
  88. package/dist/doctor/checks/compatibility.js +16 -0
  89. package/dist/doctor/checks/compatibility.js.map +1 -0
  90. package/dist/doctor/checks/env.d.ts +3 -0
  91. package/dist/doctor/checks/env.js +14 -0
  92. package/dist/doctor/checks/env.js.map +1 -0
  93. package/dist/doctor/checks/manifest.d.ts +3 -0
  94. package/dist/doctor/checks/manifest.js +31 -0
  95. package/dist/doctor/checks/manifest.js.map +1 -0
  96. package/dist/doctor/checks/paths.d.ts +3 -0
  97. package/dist/doctor/checks/paths.js +29 -0
  98. package/dist/doctor/checks/paths.js.map +1 -0
  99. package/dist/doctor/checks/repo-match.d.ts +4 -0
  100. package/dist/doctor/checks/repo-match.js +16 -0
  101. package/dist/doctor/checks/repo-match.js.map +1 -0
  102. package/dist/doctor/checks/security.d.ts +3 -0
  103. package/dist/doctor/checks/security.js +16 -0
  104. package/dist/doctor/checks/security.js.map +1 -0
  105. package/dist/doctor/run.d.ts +7 -0
  106. package/dist/doctor/run.js +47 -0
  107. package/dist/doctor/run.js.map +1 -0
  108. package/dist/doctor/types.d.ts +12 -0
  109. package/dist/doctor/types.js +2 -0
  110. package/dist/doctor/types.js.map +1 -0
  111. package/dist/fs/backups.d.ts +1 -0
  112. package/dist/fs/backups.js +4 -0
  113. package/dist/fs/backups.js.map +1 -0
  114. package/dist/fs/diff.d.ts +8 -0
  115. package/dist/fs/diff.js +39 -0
  116. package/dist/fs/diff.js.map +1 -0
  117. package/dist/fs/headers.d.ts +6 -0
  118. package/dist/fs/headers.js +32 -0
  119. package/dist/fs/headers.js.map +1 -0
  120. package/dist/fs/write.d.ts +8 -0
  121. package/dist/fs/write.js +42 -0
  122. package/dist/fs/write.js.map +1 -0
  123. package/dist/manifest/defaults.d.ts +11 -0
  124. package/dist/manifest/defaults.js +71 -0
  125. package/dist/manifest/defaults.js.map +1 -0
  126. package/dist/manifest/load.d.ts +10 -0
  127. package/dist/manifest/load.js +34 -0
  128. package/dist/manifest/load.js.map +1 -0
  129. package/dist/manifest/normalize.d.ts +7 -0
  130. package/dist/manifest/normalize.js +40 -0
  131. package/dist/manifest/normalize.js.map +1 -0
  132. package/dist/manifest/save.d.ts +2 -0
  133. package/dist/manifest/save.js +9 -0
  134. package/dist/manifest/save.js.map +1 -0
  135. package/dist/manifest/schema.d.ts +166 -0
  136. package/dist/manifest/schema.js +96 -0
  137. package/dist/manifest/schema.js.map +1 -0
  138. package/dist/planner/build-plan.d.ts +29 -0
  139. package/dist/planner/build-plan.js +49 -0
  140. package/dist/planner/build-plan.js.map +1 -0
  141. package/dist/planner/output-map.d.ts +18 -0
  142. package/dist/planner/output-map.js +192 -0
  143. package/dist/planner/output-map.js.map +1 -0
  144. package/dist/planner/warnings.d.ts +7 -0
  145. package/dist/planner/warnings.js +26 -0
  146. package/dist/planner/warnings.js.map +1 -0
  147. package/dist/render/render-plan.d.ts +4 -0
  148. package/dist/render/render-plan.js +15 -0
  149. package/dist/render/render-plan.js.map +1 -0
  150. package/dist/render/shared.d.ts +4 -0
  151. package/dist/render/shared.js +426 -0
  152. package/dist/render/shared.js.map +1 -0
  153. package/dist/templates/registry.d.ts +10 -0
  154. package/dist/templates/registry.js +48 -0
  155. package/dist/templates/registry.js.map +1 -0
  156. package/dist/utils/format.d.ts +3 -0
  157. package/dist/utils/format.js +20 -0
  158. package/dist/utils/format.js.map +1 -0
  159. package/dist/utils/json.d.ts +3 -0
  160. package/dist/utils/json.js +12 -0
  161. package/dist/utils/json.js.map +1 -0
  162. package/package.json +53 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 syoo
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,110 @@
1
+ # agenv
2
+
3
+ `agenv` is an npm package for bootstrapping a portable, reviewable AI workspace for web development repositories.
4
+
5
+ It helps a team define one canonical AI workspace manifest and turn that into tool-specific outputs for supported coding assistants and MCP-compatible tooling.
6
+
7
+ ## What It Does
8
+
9
+ - inspects a web development repo and infers useful setup hints
10
+ - creates or loads `ai-workspace.json`
11
+ - plans generated files for supported targets
12
+ - generates shared docs and tool-specific files
13
+ - supports Codex, Copilot, Claude, and MCP in the current MVP direction
14
+ - supports both `dashboard` and `web-app` as project types
15
+
16
+ ## Current Status
17
+
18
+ This repo is no longer docs-only. It now includes:
19
+
20
+ - a buildable TypeScript package scaffold
21
+ - a CLI entrypoint and command shells
22
+ - manifest schema, defaults, normalization, load, and save
23
+ - repo inspection and stack hints
24
+ - generation planning and warnings
25
+ - a first real `generate` and `diff` path
26
+ - unit and integration tests
27
+
28
+ Still early:
29
+
30
+ - interactive `init` is still shallow
31
+ - generated file content is functional but not fully polished
32
+ - `doctor` has structure but is not feature-complete yet
33
+ - the current MVP is still most optimized for dashboard and internal-tool workflows
34
+
35
+ ## Vision
36
+
37
+ Set up a portable, reviewable AI coding environment for web development in one command.
38
+
39
+ ## Install and Use
40
+
41
+ ```bash
42
+ npx agenv-cli --help
43
+ ```
44
+
45
+ ```bash
46
+ npm install -g agenv-cli
47
+ agenv --help
48
+ ```
49
+
50
+ Examples:
51
+
52
+ ```bash
53
+ agenv init --yes
54
+ agenv generate
55
+ ```
56
+
57
+ ```bash
58
+ agenv diff
59
+ agenv templates-list
60
+ ```
61
+
62
+ ## Start Here
63
+
64
+ If you are new to the repo, read these in order:
65
+
66
+ - contributor guide: [doc/getting-started.md](/Users/syoo/Documents/code/agenv-package/doc/getting-started.md)
67
+ - product requirements: [doc/prd.md](/Users/syoo/Documents/code/agenv-package/doc/prd.md)
68
+ - technical requirements: [doc/trd.md](/Users/syoo/Documents/code/agenv-package/doc/trd.md)
69
+ - CLI contract: [doc/cli-spec.md](/Users/syoo/Documents/code/agenv-package/doc/cli-spec.md)
70
+ - manifest contract: [doc/manifest-spec.md](/Users/syoo/Documents/code/agenv-package/doc/manifest-spec.md)
71
+ - output map: [doc/output-map.md](/Users/syoo/Documents/code/agenv-package/doc/output-map.md)
72
+ - adapter contract: [doc/adapter-contract.md](/Users/syoo/Documents/code/agenv-package/doc/adapter-contract.md)
73
+ - implementation plan: [doc/implementation-plan.md](/Users/syoo/Documents/code/agenv-package/doc/implementation-plan.md)
74
+
75
+ ## Development Commands
76
+
77
+ ```bash
78
+ npm install
79
+ npm test
80
+ npm run typecheck
81
+ npm run build
82
+ node dist/cli/index.js --help
83
+ ```
84
+
85
+ ## Package Shape
86
+
87
+ ```text
88
+ src/
89
+ adapters/
90
+ cli/
91
+ detect/
92
+ doctor/
93
+ fs/
94
+ manifest/
95
+ planner/
96
+ render/
97
+ templates/
98
+ utils/
99
+ doc/
100
+ tests/
101
+ ```
102
+
103
+ ## Best Next Step
104
+
105
+ The strongest near-term path is to keep improving the first usable slice:
106
+
107
+ 1. make generated files richer and less placeholder-like
108
+ 2. deepen `init --yes` and preview behavior
109
+ 3. expand `doctor`
110
+ 4. add more integration coverage around real CLI behavior
@@ -0,0 +1,2 @@
1
+ import type { Adapter } from "../types.js";
2
+ export declare const claudeAdapter: Adapter;
@@ -0,0 +1,50 @@
1
+ import { formatJson } from "../../utils/json.js";
2
+ function supports(manifest) {
3
+ return {
4
+ supported: manifest.targets.claude,
5
+ issues: manifest.targets.claude
6
+ ? []
7
+ : [
8
+ {
9
+ severity: "warning",
10
+ code: "claude_target_disabled",
11
+ message: "Claude output is disabled in the manifest targets.",
12
+ },
13
+ ],
14
+ };
15
+ }
16
+ function plan(_manifest, generationPlan) {
17
+ return generationPlan.files.filter((file) => file.target === "claude");
18
+ }
19
+ function renderMarkdownForPath(file, manifest) {
20
+ if (file.path === ".claude/README.md") {
21
+ const projectLabel = manifest.project.type === "web-app" ? "web app" : "dashboard";
22
+ return `# Claude Workspace\n\nGenerated by agenv.\n\nThis workspace is configured for a ${manifest.project.framework} ${projectLabel} project.\n`;
23
+ }
24
+ if (file.path.includes("/skills/")) {
25
+ const skillName = file.path.split("/").pop()?.replace(".md", "") ?? "skill";
26
+ return `# ${skillName}\n\nGenerated skill scaffold for ${manifest.project.name}.\n`;
27
+ }
28
+ if (file.path.includes("/agents/")) {
29
+ const agentName = file.path.split("/").pop()?.replace(".md", "") ?? "agent";
30
+ return `# ${agentName}\n\nGenerated agent scaffold for ${manifest.project.name}.\n`;
31
+ }
32
+ return formatJson({
33
+ generatedBy: "agenv",
34
+ project: manifest.project.name,
35
+ });
36
+ }
37
+ function render(file, manifest) {
38
+ return {
39
+ path: file.path,
40
+ trustSensitive: file.trustSensitive,
41
+ content: renderMarkdownForPath(file, manifest),
42
+ };
43
+ }
44
+ export const claudeAdapter = {
45
+ id: "claude",
46
+ supports,
47
+ plan,
48
+ render,
49
+ };
50
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/adapters/claude/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGjD,SAAS,QAAQ,CAAC,QAAkB;IAClC,OAAO;QACL,SAAS,EAAE,QAAQ,CAAC,OAAO,CAAC,MAAM;QAClC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,MAAM;YAC7B,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC;gBACE;oBACE,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,wBAAwB;oBAC9B,OAAO,EAAE,oDAAoD;iBAC9D;aACF;KACN,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CAAC,SAAmB,EAAE,cAA8B;IAC/D,OAAO,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC;AACzE,CAAC;AAED,SAAS,qBAAqB,CAAC,IAAiB,EAAE,QAAkB;IAClE,IAAI,IAAI,CAAC,IAAI,KAAK,mBAAmB,EAAE,CAAC;QACtC,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;QAEnF,OAAO,mFAAmF,QAAQ,CAAC,OAAO,CAAC,SAAS,IAAI,YAAY,aAAa,CAAC;IACpJ,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QACnC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC;QAC5E,OAAO,KAAK,SAAS,oCAAoC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC;IACtF,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;QACnC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC;QAC5E,OAAO,KAAK,SAAS,oCAAoC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC;IACtF,CAAC;IAED,OAAO,UAAU,CAAC;QAChB,WAAW,EAAE,OAAO;QACpB,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI;KAC/B,CAAC,CAAC;AACL,CAAC;AAED,SAAS,MAAM,CAAC,IAAiB,EAAE,QAAkB;IACnD,OAAO;QACL,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,OAAO,EAAE,qBAAqB,CAAC,IAAI,EAAE,QAAQ,CAAC;KAC/C,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,aAAa,GAAY;IACpC,EAAE,EAAE,QAAQ;IACZ,QAAQ;IACR,IAAI;IACJ,MAAM;CACP,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { Adapter } from "../types.js";
2
+ export declare const codexAdapter: Adapter;
@@ -0,0 +1,31 @@
1
+ function supports(manifest) {
2
+ return {
3
+ supported: manifest.targets.codex,
4
+ issues: manifest.targets.codex
5
+ ? []
6
+ : [
7
+ {
8
+ severity: "warning",
9
+ code: "codex_target_disabled",
10
+ message: "Codex output is disabled in the manifest targets.",
11
+ },
12
+ ],
13
+ };
14
+ }
15
+ function plan(_manifest, generationPlan) {
16
+ return generationPlan.files.filter((file) => file.target === "codex");
17
+ }
18
+ function render(file, manifest) {
19
+ return {
20
+ path: file.path,
21
+ trustSensitive: file.trustSensitive,
22
+ content: `# AGENTS\n\nGenerated by agenv.\n\n## Project\n\n- Name: ${manifest.project.name}\n- Framework: ${manifest.project.framework}\n\n## Coding Style\n\n${manifest.instructions.codingStyle.map((rule) => `- ${rule}`).join("\n")}\n\n## Review Rules\n\n${manifest.instructions.reviewRules.map((rule) => `- ${rule}`).join("\n")}\n`,
23
+ };
24
+ }
25
+ export const codexAdapter = {
26
+ id: "codex",
27
+ supports,
28
+ plan,
29
+ render,
30
+ };
31
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/adapters/codex/index.ts"],"names":[],"mappings":"AAIA,SAAS,QAAQ,CAAC,QAAkB;IAClC,OAAO;QACL,SAAS,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK;QACjC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK;YAC5B,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC;gBACE;oBACE,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,uBAAuB;oBAC7B,OAAO,EAAE,mDAAmD;iBAC7D;aACF;KACN,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CAAC,SAAmB,EAAE,cAA8B;IAC/D,OAAO,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC;AACxE,CAAC;AAED,SAAS,MAAM,CAAC,IAAiB,EAAE,QAAkB;IACnD,OAAO;QACL,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,OAAO,EAAE,4DAA4D,QAAQ,CAAC,OAAO,CAAC,IAAI,kBAAkB,QAAQ,CAAC,OAAO,CAAC,SAAS,0BAA0B,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,0BAA0B,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI;KAC7U,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,YAAY,GAAY;IACnC,EAAE,EAAE,OAAO;IACX,QAAQ;IACR,IAAI;IACJ,MAAM;CACP,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { Adapter } from "../types.js";
2
+ export declare const copilotAdapter: Adapter;
@@ -0,0 +1,34 @@
1
+ function supports(manifest) {
2
+ return {
3
+ supported: manifest.targets.copilot,
4
+ issues: manifest.targets.copilot
5
+ ? []
6
+ : [
7
+ {
8
+ severity: "warning",
9
+ code: "copilot_target_disabled",
10
+ message: "Copilot output is disabled in the manifest targets.",
11
+ },
12
+ ],
13
+ };
14
+ }
15
+ function plan(_manifest, generationPlan) {
16
+ return generationPlan.files.filter((file) => file.target === "copilot");
17
+ }
18
+ function render(file, manifest) {
19
+ const projectLabel = manifest.project.type === "web-app" ? "web app" : "dashboard";
20
+ return {
21
+ path: file.path,
22
+ trustSensitive: file.trustSensitive,
23
+ content: `# Copilot Instructions\n\nGenerated by agenv.\n\nUse the shared ${projectLabel} conventions for ${manifest.project.name}.\n\n${manifest.instructions.codingStyle
24
+ .map((rule) => `- ${rule}`)
25
+ .join("\n")}\n`,
26
+ };
27
+ }
28
+ export const copilotAdapter = {
29
+ id: "copilot",
30
+ supports,
31
+ plan,
32
+ render,
33
+ };
34
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/adapters/copilot/index.ts"],"names":[],"mappings":"AAIA,SAAS,QAAQ,CAAC,QAAkB;IAClC,OAAO;QACL,SAAS,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO;QACnC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,OAAO;YAC9B,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC;gBACE;oBACE,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,yBAAyB;oBAC/B,OAAO,EAAE,qDAAqD;iBAC/D;aACF;KACN,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CAAC,SAAmB,EAAE,cAA8B;IAC/D,OAAO,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC;AAC1E,CAAC;AAED,SAAS,MAAM,CAAC,IAAiB,EAAE,QAAkB;IACnD,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;IAEnF,OAAO;QACL,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,OAAO,EAAE,mEAAmE,YAAY,oBAAoB,QAAQ,CAAC,OAAO,CAAC,IAAI,QAAQ,QAAQ,CAAC,YAAY,CAAC,WAAW;aACvK,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC;aAC1B,IAAI,CAAC,IAAI,CAAC,IAAI;KAClB,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAAY;IACrC,EAAE,EAAE,SAAS;IACb,QAAQ;IACR,IAAI;IACJ,MAAM;CACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Adapter, AdapterId } from "./types.js";
2
+ export declare const ADAPTERS: Adapter[];
3
+ export declare function getAdapter(adapterId: AdapterId): Adapter;
@@ -0,0 +1,18 @@
1
+ import { claudeAdapter } from "./claude/index.js";
2
+ import { codexAdapter } from "./codex/index.js";
3
+ import { copilotAdapter } from "./copilot/index.js";
4
+ import { mcpAdapter } from "./mcp/index.js";
5
+ export const ADAPTERS = [
6
+ codexAdapter,
7
+ copilotAdapter,
8
+ claudeAdapter,
9
+ mcpAdapter,
10
+ ];
11
+ export function getAdapter(adapterId) {
12
+ const adapter = ADAPTERS.find((candidate) => candidate.id === adapterId);
13
+ if (!adapter) {
14
+ throw new Error(`No adapter registered for '${adapterId}'.`);
15
+ }
16
+ return adapter;
17
+ }
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5C,MAAM,CAAC,MAAM,QAAQ,GAAc;IACjC,YAAY;IACZ,cAAc;IACd,aAAa;IACb,UAAU;CACX,CAAC;AAEF,MAAM,UAAU,UAAU,CAAC,SAAoB;IAC7C,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC;IAEzE,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,8BAA8B,SAAS,IAAI,CAAC,CAAC;IAC/D,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { Adapter } from "../types.js";
2
+ export declare const mcpAdapter: Adapter;
@@ -0,0 +1,45 @@
1
+ import { formatJson } from "../../utils/json.js";
2
+ function supports(manifest) {
3
+ return {
4
+ supported: manifest.targets.mcp,
5
+ issues: manifest.targets.mcp
6
+ ? [
7
+ {
8
+ severity: "warning",
9
+ code: "mcp_requires_review",
10
+ message: "MCP configs are trust-sensitive and should be reviewed before use.",
11
+ },
12
+ ]
13
+ : [
14
+ {
15
+ severity: "warning",
16
+ code: "mcp_target_disabled",
17
+ message: "MCP output is disabled in the manifest targets.",
18
+ },
19
+ ],
20
+ };
21
+ }
22
+ function plan(_manifest, generationPlan) {
23
+ return generationPlan.files.filter((file) => file.target === "mcp");
24
+ }
25
+ function render(file, manifest) {
26
+ return {
27
+ path: file.path,
28
+ trustSensitive: file.trustSensitive,
29
+ content: formatJson({
30
+ generatedBy: "agenv",
31
+ project: manifest.project.name,
32
+ presets: manifest.generated.mcpPresets,
33
+ env: {
34
+ EXAMPLE_API_KEY: "${EXAMPLE_API_KEY}",
35
+ },
36
+ }),
37
+ };
38
+ }
39
+ export const mcpAdapter = {
40
+ id: "mcp",
41
+ supports,
42
+ plan,
43
+ render,
44
+ };
45
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/adapters/mcp/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGjD,SAAS,QAAQ,CAAC,QAAkB;IAClC,OAAO;QACL,SAAS,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG;QAC/B,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG;YAC1B,CAAC,CAAC;gBACE;oBACE,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,qBAAqB;oBAC3B,OAAO,EAAE,oEAAoE;iBAC9E;aACF;YACH,CAAC,CAAC;gBACE;oBACE,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,qBAAqB;oBAC3B,OAAO,EAAE,iDAAiD;iBAC3D;aACF;KACN,CAAC;AACJ,CAAC;AAED,SAAS,IAAI,CAAC,SAAmB,EAAE,cAA8B;IAC/D,OAAO,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,CAAC;AACtE,CAAC;AAED,SAAS,MAAM,CAAC,IAAiB,EAAE,QAAkB;IACnD,OAAO;QACL,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,cAAc,EAAE,IAAI,CAAC,cAAc;QACnC,OAAO,EAAE,UAAU,CAAC;YAClB,WAAW,EAAE,OAAO;YACpB,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI;YAC9B,OAAO,EAAE,QAAQ,CAAC,SAAS,CAAC,UAAU;YACtC,GAAG,EAAE;gBACH,eAAe,EAAE,oBAAoB;aACtC;SACF,CAAC;KACH,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,UAAU,GAAY;IACjC,EAAE,EAAE,KAAK;IACT,QAAQ;IACR,IAAI;IACJ,MAAM;CACP,CAAC"}
@@ -0,0 +1,23 @@
1
+ import type { Manifest } from "../manifest/schema.js";
2
+ import type { GenerationPlan, PlannedFile } from "../planner/build-plan.js";
3
+ export type AdapterId = "codex" | "copilot" | "claude" | "mcp";
4
+ export type SupportIssue = {
5
+ severity: "warning" | "error";
6
+ code: string;
7
+ message: string;
8
+ };
9
+ export type SupportResult = {
10
+ supported: boolean;
11
+ issues: SupportIssue[];
12
+ };
13
+ export type RenderedFile = {
14
+ path: string;
15
+ content: string;
16
+ trustSensitive: boolean;
17
+ };
18
+ export interface Adapter {
19
+ id: AdapterId;
20
+ supports(manifest: Manifest): SupportResult;
21
+ plan(manifest: Manifest, plan: GenerationPlan): PlannedFile[];
22
+ render(file: PlannedFile, manifest: Manifest): RenderedFile;
23
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/adapters/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ import { Command } from "commander";
2
+ import { summarizeRenderedDiff } from "../../fs/diff.js";
3
+ import { buildGenerationPlan } from "../../planner/build-plan.js";
4
+ import type { AdapterTarget, OutputLayer, OutputScope } from "../../planner/output-map.js";
5
+ export type RunDiffOptions = {
6
+ cwd: string;
7
+ targets?: AdapterTarget[] | undefined;
8
+ layers?: OutputLayer[] | undefined;
9
+ scopes?: OutputScope[] | undefined;
10
+ };
11
+ export type RunDiffResult = {
12
+ command: "diff";
13
+ manifestPath: string;
14
+ plan: ReturnType<typeof buildGenerationPlan>;
15
+ summary: Awaited<ReturnType<typeof summarizeRenderedDiff>>;
16
+ };
17
+ export declare function runDiff(options: RunDiffOptions): Promise<RunDiffResult>;
18
+ export declare function registerDiffCommand(program: Command): void;
@@ -0,0 +1,65 @@
1
+ import { summarizeRenderedDiff } from "../../fs/diff.js";
2
+ import { loadManifest } from "../../manifest/load.js";
3
+ import { buildGenerationPlan } from "../../planner/build-plan.js";
4
+ import { renderPlanFiles } from "../../render/render-plan.js";
5
+ import { formatCommandOutput, formatTextBlock, parseCommaList } from "../../utils/format.js";
6
+ function parseTargets(value) {
7
+ const targets = parseCommaList(value);
8
+ return targets.length > 0 ? targets : undefined;
9
+ }
10
+ function parseLayers(value) {
11
+ const layers = parseCommaList(value);
12
+ return layers.length > 0 ? layers : undefined;
13
+ }
14
+ function parseScopes(value) {
15
+ const scopes = parseCommaList(value);
16
+ return scopes.length > 0 ? scopes : undefined;
17
+ }
18
+ function compactObject(value) {
19
+ return Object.fromEntries(Object.entries(value).filter(([, entryValue]) => entryValue !== undefined));
20
+ }
21
+ export async function runDiff(options) {
22
+ const { manifest, sharedPath } = await loadManifest(options.cwd);
23
+ const plan = buildGenerationPlan(manifest, compactObject({
24
+ targets: options.targets,
25
+ layers: options.layers,
26
+ scopes: options.scopes,
27
+ }));
28
+ const renderedFiles = renderPlanFiles(manifest, plan);
29
+ const summary = await summarizeRenderedDiff(options.cwd, renderedFiles);
30
+ return {
31
+ command: "diff",
32
+ manifestPath: sharedPath,
33
+ plan,
34
+ summary,
35
+ };
36
+ }
37
+ export function registerDiffCommand(program) {
38
+ program
39
+ .command("diff")
40
+ .description("Show what generate would plan without writing files.")
41
+ .option("--json", "emit machine-readable output")
42
+ .option("--targets <list>", "limit diff to selected targets")
43
+ .option("--layer <list>", "limit diff to selected layers")
44
+ .option("--scope <list>", "limit diff to shared or local scope")
45
+ .action(async (options) => {
46
+ const result = await runDiff({
47
+ cwd: process.cwd(),
48
+ ...compactObject({
49
+ targets: parseTargets(options.targets),
50
+ layers: parseLayers(options.layer),
51
+ scopes: parseScopes(options.scope),
52
+ }),
53
+ });
54
+ const text = formatTextBlock([
55
+ `Manifest: ${result.manifestPath}`,
56
+ `Create: ${result.summary.create.length}`,
57
+ `Update: ${result.summary.update.length}`,
58
+ `Unchanged: ${result.summary.unchanged.length}`,
59
+ `Skip: ${result.summary.skip.length}`,
60
+ `Warnings: ${result.plan.warnings.length}`,
61
+ ]);
62
+ process.stdout.write(formatCommandOutput(text, result, Boolean(options.json)));
63
+ });
64
+ }
65
+ //# sourceMappingURL=diff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff.js","sourceRoot":"","sources":["../../../src/cli/commands/diff.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from "commander";
2
+ export declare function registerDoctorCommand(program: Command): void;
@@ -0,0 +1,26 @@
1
+ import { runDoctor } from "../../doctor/run.js";
2
+ import { formatCommandOutput, formatTextBlock, parseCommaList } from "../../utils/format.js";
3
+ export function registerDoctorCommand(program) {
4
+ program
5
+ .command("doctor")
6
+ .description("Validate the current manifest and repo compatibility.")
7
+ .option("--json", "emit machine-readable output")
8
+ .option("--strict", "treat warnings as blocking")
9
+ .option("--targets <list>", "reserved for future target-specific checks")
10
+ .action(async (options) => {
11
+ const cwd = process.cwd();
12
+ const targetFilter = parseCommaList(options.targets);
13
+ const result = await runDoctor(cwd, { strict: Boolean(options.strict), targets: targetFilter });
14
+ const text = formatTextBlock([
15
+ `Status: ${result.status}`,
16
+ `Errors: ${result.errors.length}`,
17
+ `Warnings: ${result.warnings.length}`,
18
+ `Info: ${result.info.length}`,
19
+ ]);
20
+ process.stdout.write(formatCommandOutput(text, result, Boolean(options.json)));
21
+ if (result.status === "error") {
22
+ process.exitCode = 1;
23
+ }
24
+ });
25
+ }
26
+ //# sourceMappingURL=doctor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"doctor.js","sourceRoot":"","sources":["../../../src/cli/commands/doctor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAQ7F,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,uDAAuD,CAAC;SACpE,MAAM,CAAC,QAAQ,EAAE,8BAA8B,CAAC;SAChD,MAAM,CAAC,UAAU,EAAE,4BAA4B,CAAC;SAChD,MAAM,CAAC,kBAAkB,EAAE,4CAA4C,CAAC;SACxE,MAAM,CAAC,KAAK,EAAE,OAAsB,EAAE,EAAE;QACvC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,MAAM,YAAY,GAAG,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC;QAEhG,MAAM,IAAI,GAAG,eAAe,CAAC;YAC3B,WAAW,MAAM,CAAC,MAAM,EAAE;YAC1B,WAAW,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;YACjC,aAAa,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE;YACrC,SAAS,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE;SAC9B,CAAC,CAAC;QAEH,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAE/E,IAAI,MAAM,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;YAC9B,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACvB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { Command } from "commander";
2
+ import { summarizeRenderedDiff } from "../../fs/diff.js";
3
+ import { writeRenderedFiles } from "../../fs/write.js";
4
+ import { buildGenerationPlan } from "../../planner/build-plan.js";
5
+ import type { AdapterTarget, OutputLayer, OutputScope } from "../../planner/output-map.js";
6
+ export type RunGenerateOptions = {
7
+ cwd: string;
8
+ dryRun?: boolean;
9
+ targets?: AdapterTarget[] | undefined;
10
+ layers?: OutputLayer[] | undefined;
11
+ scopes?: OutputScope[] | undefined;
12
+ };
13
+ export type RunGenerateResult = {
14
+ command: "generate";
15
+ manifestPath: string;
16
+ plan: ReturnType<typeof buildGenerationPlan>;
17
+ summary: Awaited<ReturnType<typeof summarizeRenderedDiff>> | Awaited<ReturnType<typeof writeRenderedFiles>>;
18
+ dryRun: boolean;
19
+ };
20
+ export declare function runGenerate(options: RunGenerateOptions): Promise<RunGenerateResult>;
21
+ export declare function registerGenerateCommand(program: Command): void;
@@ -0,0 +1,73 @@
1
+ import { summarizeRenderedDiff } from "../../fs/diff.js";
2
+ import { writeRenderedFiles } from "../../fs/write.js";
3
+ import { loadManifest } from "../../manifest/load.js";
4
+ import { buildGenerationPlan } from "../../planner/build-plan.js";
5
+ import { renderPlanFiles } from "../../render/render-plan.js";
6
+ import { formatCommandOutput, formatTextBlock, parseCommaList } from "../../utils/format.js";
7
+ function parseTargets(value) {
8
+ const targets = parseCommaList(value);
9
+ return targets.length > 0 ? targets : undefined;
10
+ }
11
+ function parseLayers(value) {
12
+ const layers = parseCommaList(value);
13
+ return layers.length > 0 ? layers : undefined;
14
+ }
15
+ function parseScopes(value) {
16
+ const scopes = parseCommaList(value);
17
+ return scopes.length > 0 ? scopes : undefined;
18
+ }
19
+ function compactObject(value) {
20
+ return Object.fromEntries(Object.entries(value).filter(([, entryValue]) => entryValue !== undefined));
21
+ }
22
+ export async function runGenerate(options) {
23
+ const { manifest, sharedPath } = await loadManifest(options.cwd);
24
+ const plan = buildGenerationPlan(manifest, compactObject({
25
+ targets: options.targets,
26
+ layers: options.layers,
27
+ scopes: options.scopes,
28
+ }));
29
+ const renderedFiles = renderPlanFiles(manifest, plan);
30
+ const summary = options.dryRun
31
+ ? await summarizeRenderedDiff(options.cwd, renderedFiles)
32
+ : await writeRenderedFiles(options.cwd, renderedFiles);
33
+ return {
34
+ command: "generate",
35
+ manifestPath: sharedPath,
36
+ plan,
37
+ summary,
38
+ dryRun: Boolean(options.dryRun),
39
+ };
40
+ }
41
+ export function registerGenerateCommand(program) {
42
+ program
43
+ .command("generate")
44
+ .description("Load a manifest and compute the generation plan.")
45
+ .option("--dry-run", "plan without writing files")
46
+ .option("--json", "emit machine-readable output")
47
+ .option("--targets <list>", "limit generation to selected targets")
48
+ .option("--layer <list>", "limit generation to selected layers")
49
+ .option("--scope <list>", "limit generation to shared or local scope")
50
+ .action(async (options) => {
51
+ const result = await runGenerate({
52
+ cwd: process.cwd(),
53
+ dryRun: Boolean(options.dryRun),
54
+ ...compactObject({
55
+ targets: parseTargets(options.targets),
56
+ layers: parseLayers(options.layer),
57
+ scopes: parseScopes(options.scope),
58
+ }),
59
+ });
60
+ const text = formatTextBlock([
61
+ `Manifest: ${result.manifestPath}`,
62
+ `Planned files: ${result.plan.files.length}`,
63
+ `Warnings: ${result.plan.warnings.length}`,
64
+ `Created: ${"created" in result.summary ? result.summary.created.length : result.summary.create.length}`,
65
+ `Updated: ${"updated" in result.summary ? result.summary.updated.length : result.summary.update.length}`,
66
+ `Unchanged: ${result.summary.unchanged.length}`,
67
+ `Skipped: ${"skipped" in result.summary ? result.summary.skipped.length : result.summary.skip.length}`,
68
+ result.dryRun ? "Dry run only: files were not written." : "Files written successfully.",
69
+ ]);
70
+ process.stdout.write(formatCommandOutput(text, result, Boolean(options.json)));
71
+ });
72
+ }
73
+ //# sourceMappingURL=generate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../src/cli/commands/generate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Command } from "commander";
2
+ export declare function registerInitCommand(program: Command): void;