@agents-inc/cli 0.90.0 → 0.91.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 (179) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/{chunk-OWPIGGPP.js → chunk-2RXDM5HN.js} +2 -2
  3. package/dist/{chunk-JI44SVMW.js → chunk-35WALWDD.js} +2 -2
  4. package/dist/{chunk-D254XO7K.js → chunk-3O57Z6Q3.js} +2 -2
  5. package/dist/{chunk-TWOHWCKS.js → chunk-3STOCHK4.js} +2 -2
  6. package/dist/{chunk-BO4JY7BT.js → chunk-5IR4QU7G.js} +24 -19
  7. package/dist/chunk-5IR4QU7G.js.map +1 -0
  8. package/dist/chunk-7QWCPF6F.js +135 -0
  9. package/dist/chunk-7QWCPF6F.js.map +1 -0
  10. package/dist/{chunk-VJBCOPMG.js → chunk-AWB6DO24.js} +16 -9
  11. package/dist/chunk-AWB6DO24.js.map +1 -0
  12. package/dist/{chunk-SB2R5KHJ.js → chunk-BGICSUQK.js} +2 -2
  13. package/dist/{chunk-HK53FRMU.js → chunk-DVBA6PGR.js} +3 -7
  14. package/dist/{chunk-HK53FRMU.js.map → chunk-DVBA6PGR.js.map} +1 -1
  15. package/dist/{chunk-I5AZKNNL.js → chunk-FEKVKYCN.js} +2 -2
  16. package/dist/{chunk-7AUGC7PK.js → chunk-G3VPBEBC.js} +2 -2
  17. package/dist/chunk-M6J5YQ3P.js +100 -0
  18. package/dist/chunk-M6J5YQ3P.js.map +1 -0
  19. package/dist/{chunk-3T5XT2VU.js → chunk-MBEXASMU.js} +3 -3
  20. package/dist/{chunk-TEA5KBIA.js → chunk-NESVWSI7.js} +2 -2
  21. package/dist/{chunk-V36FRPAU.js → chunk-ORTNQZLF.js} +4 -2
  22. package/dist/{chunk-V36FRPAU.js.map → chunk-ORTNQZLF.js.map} +1 -1
  23. package/dist/{chunk-TP6BX5M2.js → chunk-RDQBXB3Y.js} +5 -5
  24. package/dist/{chunk-VYLF4IIK.js → chunk-TJHCK4OS.js} +2 -2
  25. package/dist/{chunk-Z5FXZFX2.js → chunk-UK572773.js} +2 -2
  26. package/dist/{chunk-4ITKYWVG.js → chunk-V75HVZTB.js} +3 -3
  27. package/dist/chunk-V75HVZTB.js.map +1 -0
  28. package/dist/commands/build/marketplace.js +58 -40
  29. package/dist/commands/build/marketplace.js.map +1 -1
  30. package/dist/commands/build/plugins.js +38 -29
  31. package/dist/commands/build/plugins.js.map +1 -1
  32. package/dist/commands/build/stack.js +35 -27
  33. package/dist/commands/build/stack.js.map +1 -1
  34. package/dist/commands/compile.js +35 -32
  35. package/dist/commands/compile.js.map +1 -1
  36. package/dist/commands/diff.js +4 -3
  37. package/dist/commands/diff.js.map +1 -1
  38. package/dist/commands/doctor.js +8 -31
  39. package/dist/commands/doctor.js.map +1 -1
  40. package/dist/commands/edit.js +52 -59
  41. package/dist/commands/edit.js.map +1 -1
  42. package/dist/commands/import/skill.js +53 -43
  43. package/dist/commands/import/skill.js.map +1 -1
  44. package/dist/commands/init.js +17 -18
  45. package/dist/commands/new/marketplace.js +90 -75
  46. package/dist/commands/new/marketplace.js.map +1 -1
  47. package/dist/commands/outdated.js +82 -91
  48. package/dist/commands/outdated.js.map +1 -1
  49. package/dist/commands/search.js +2 -2
  50. package/dist/commands/uninstall.js +33 -24
  51. package/dist/commands/uninstall.js.map +1 -1
  52. package/dist/components/skill-search/skill-search.js +2 -2
  53. package/dist/components/wizard/category-grid.js +2 -2
  54. package/dist/components/wizard/category-grid.test.js +3 -3
  55. package/dist/components/wizard/domain-selection.js +2 -2
  56. package/dist/components/wizard/{help-modal.js → info-panel.js} +6 -6
  57. package/dist/components/wizard/search-modal.js +2 -2
  58. package/dist/components/wizard/search-modal.test.js +2 -2
  59. package/dist/components/wizard/source-grid.js +3 -3
  60. package/dist/components/wizard/source-grid.test.js +4 -4
  61. package/dist/components/wizard/stack-selection.js +2 -2
  62. package/dist/components/wizard/stats-panel.js +106 -5
  63. package/dist/components/wizard/stats-panel.js.map +1 -1
  64. package/dist/components/wizard/step-agents.js +2 -2
  65. package/dist/components/wizard/step-agents.test.js +2 -2
  66. package/dist/components/wizard/step-build.js +4 -5
  67. package/dist/components/wizard/step-build.test.js +4 -5
  68. package/dist/components/wizard/step-build.test.js.map +1 -1
  69. package/dist/components/wizard/step-confirm.test.js +1 -1
  70. package/dist/components/wizard/step-refine.js +2 -2
  71. package/dist/components/wizard/step-refine.test.js +2 -2
  72. package/dist/components/wizard/step-settings.js +2 -2
  73. package/dist/components/wizard/step-settings.test.js +2 -2
  74. package/dist/components/wizard/step-sources.js +6 -6
  75. package/dist/components/wizard/step-sources.test.js +6 -6
  76. package/dist/components/wizard/step-stack.js +3 -3
  77. package/dist/components/wizard/step-stack.test.js +3 -3
  78. package/dist/components/wizard/wizard-layout.js +5 -5
  79. package/dist/components/wizard/wizard.js +16 -17
  80. package/dist/hooks/init.js +17 -18
  81. package/dist/hooks/init.js.map +1 -1
  82. package/dist/plugins/dummy-skill/.claude-plugin/.content-hash +1 -0
  83. package/dist/plugins/dummy-skill/.claude-plugin/plugin.json +13 -0
  84. package/dist/src/agents/developer/ai-developer/critical-reminders.md +31 -0
  85. package/dist/src/agents/developer/ai-developer/critical-requirements.md +17 -0
  86. package/dist/src/agents/developer/ai-developer/examples.md +137 -0
  87. package/dist/src/agents/developer/ai-developer/intro.md +23 -0
  88. package/dist/src/agents/developer/ai-developer/metadata.yaml +12 -0
  89. package/dist/src/agents/developer/ai-developer/output-format.md +228 -0
  90. package/dist/src/agents/developer/ai-developer/workflow.md +464 -0
  91. package/dist/src/agents/planning/api-pm/critical-reminders.md +32 -0
  92. package/dist/src/agents/planning/api-pm/critical-requirements.md +21 -0
  93. package/dist/src/agents/planning/api-pm/examples.md +157 -0
  94. package/dist/src/agents/planning/api-pm/intro.md +14 -0
  95. package/dist/src/agents/planning/api-pm/metadata.yaml +12 -0
  96. package/dist/src/agents/planning/api-pm/output-format.md +317 -0
  97. package/dist/src/agents/planning/api-pm/workflow.md +214 -0
  98. package/dist/src/agents/reviewer/ai-reviewer/critical-reminders.md +23 -0
  99. package/dist/src/agents/reviewer/ai-reviewer/critical-requirements.md +19 -0
  100. package/dist/src/agents/reviewer/ai-reviewer/examples.md +131 -0
  101. package/dist/src/agents/reviewer/ai-reviewer/intro.md +23 -0
  102. package/dist/src/agents/reviewer/ai-reviewer/metadata.yaml +10 -0
  103. package/dist/src/agents/reviewer/ai-reviewer/output-format.md +263 -0
  104. package/dist/src/agents/reviewer/ai-reviewer/workflow.md +177 -0
  105. package/dist/src/agents/reviewer/infra-reviewer/critical-reminders.md +21 -0
  106. package/dist/src/agents/reviewer/infra-reviewer/critical-requirements.md +19 -0
  107. package/dist/src/agents/reviewer/infra-reviewer/examples.md +123 -0
  108. package/dist/src/agents/reviewer/infra-reviewer/intro.md +25 -0
  109. package/dist/src/agents/reviewer/infra-reviewer/metadata.yaml +10 -0
  110. package/dist/src/agents/reviewer/infra-reviewer/output-format.md +240 -0
  111. package/dist/src/agents/reviewer/infra-reviewer/workflow.md +250 -0
  112. package/dist/src/agents/tester/api-tester/critical-reminders.md +23 -0
  113. package/dist/src/agents/tester/api-tester/critical-requirements.md +19 -0
  114. package/dist/src/agents/tester/api-tester/examples.md +74 -0
  115. package/dist/src/agents/tester/api-tester/intro.md +21 -0
  116. package/dist/src/agents/tester/api-tester/metadata.yaml +12 -0
  117. package/dist/src/agents/tester/api-tester/output-format.md +209 -0
  118. package/dist/src/agents/tester/api-tester/workflow.md +364 -0
  119. package/dist/stores/wizard-store.js +1 -1
  120. package/dist/stores/wizard-store.test.js +17 -17
  121. package/dist/stores/wizard-store.test.js.map +1 -1
  122. package/package.json +1 -1
  123. package/src/agents/developer/ai-developer/critical-reminders.md +31 -0
  124. package/src/agents/developer/ai-developer/critical-requirements.md +17 -0
  125. package/src/agents/developer/ai-developer/examples.md +137 -0
  126. package/src/agents/developer/ai-developer/intro.md +23 -0
  127. package/src/agents/developer/ai-developer/metadata.yaml +12 -0
  128. package/src/agents/developer/ai-developer/output-format.md +228 -0
  129. package/src/agents/developer/ai-developer/workflow.md +464 -0
  130. package/src/agents/planning/api-pm/critical-reminders.md +32 -0
  131. package/src/agents/planning/api-pm/critical-requirements.md +21 -0
  132. package/src/agents/planning/api-pm/examples.md +157 -0
  133. package/src/agents/planning/api-pm/intro.md +14 -0
  134. package/src/agents/planning/api-pm/metadata.yaml +12 -0
  135. package/src/agents/planning/api-pm/output-format.md +317 -0
  136. package/src/agents/planning/api-pm/workflow.md +214 -0
  137. package/src/agents/reviewer/ai-reviewer/critical-reminders.md +23 -0
  138. package/src/agents/reviewer/ai-reviewer/critical-requirements.md +19 -0
  139. package/src/agents/reviewer/ai-reviewer/examples.md +131 -0
  140. package/src/agents/reviewer/ai-reviewer/intro.md +23 -0
  141. package/src/agents/reviewer/ai-reviewer/metadata.yaml +10 -0
  142. package/src/agents/reviewer/ai-reviewer/output-format.md +263 -0
  143. package/src/agents/reviewer/ai-reviewer/workflow.md +177 -0
  144. package/src/agents/reviewer/infra-reviewer/critical-reminders.md +21 -0
  145. package/src/agents/reviewer/infra-reviewer/critical-requirements.md +19 -0
  146. package/src/agents/reviewer/infra-reviewer/examples.md +123 -0
  147. package/src/agents/reviewer/infra-reviewer/intro.md +25 -0
  148. package/src/agents/reviewer/infra-reviewer/metadata.yaml +10 -0
  149. package/src/agents/reviewer/infra-reviewer/output-format.md +240 -0
  150. package/src/agents/reviewer/infra-reviewer/workflow.md +250 -0
  151. package/src/agents/tester/api-tester/critical-reminders.md +23 -0
  152. package/src/agents/tester/api-tester/critical-requirements.md +19 -0
  153. package/src/agents/tester/api-tester/examples.md +74 -0
  154. package/src/agents/tester/api-tester/intro.md +21 -0
  155. package/src/agents/tester/api-tester/metadata.yaml +12 -0
  156. package/src/agents/tester/api-tester/output-format.md +209 -0
  157. package/src/agents/tester/api-tester/workflow.md +364 -0
  158. package/dist/chunk-4ITKYWVG.js.map +0 -1
  159. package/dist/chunk-BO4JY7BT.js.map +0 -1
  160. package/dist/chunk-FGVCQBXH.js +0 -143
  161. package/dist/chunk-FGVCQBXH.js.map +0 -1
  162. package/dist/chunk-FQTYF3OU.js +0 -114
  163. package/dist/chunk-FQTYF3OU.js.map +0 -1
  164. package/dist/chunk-O423DMUE.js +0 -111
  165. package/dist/chunk-O423DMUE.js.map +0 -1
  166. package/dist/chunk-VJBCOPMG.js.map +0 -1
  167. /package/dist/{chunk-OWPIGGPP.js.map → chunk-2RXDM5HN.js.map} +0 -0
  168. /package/dist/{chunk-JI44SVMW.js.map → chunk-35WALWDD.js.map} +0 -0
  169. /package/dist/{chunk-D254XO7K.js.map → chunk-3O57Z6Q3.js.map} +0 -0
  170. /package/dist/{chunk-TWOHWCKS.js.map → chunk-3STOCHK4.js.map} +0 -0
  171. /package/dist/{chunk-SB2R5KHJ.js.map → chunk-BGICSUQK.js.map} +0 -0
  172. /package/dist/{chunk-I5AZKNNL.js.map → chunk-FEKVKYCN.js.map} +0 -0
  173. /package/dist/{chunk-7AUGC7PK.js.map → chunk-G3VPBEBC.js.map} +0 -0
  174. /package/dist/{chunk-3T5XT2VU.js.map → chunk-MBEXASMU.js.map} +0 -0
  175. /package/dist/{chunk-TEA5KBIA.js.map → chunk-NESVWSI7.js.map} +0 -0
  176. /package/dist/{chunk-TP6BX5M2.js.map → chunk-RDQBXB3Y.js.map} +0 -0
  177. /package/dist/{chunk-VYLF4IIK.js.map → chunk-TJHCK4OS.js.map} +0 -0
  178. /package/dist/{chunk-Z5FXZFX2.js.map → chunk-UK572773.js.map} +0 -0
  179. /package/dist/components/wizard/{help-modal.js.map → info-panel.js.map} +0 -0
@@ -71,37 +71,11 @@ var BuildPlugins = class _BuildPlugins extends BaseCommand {
71
71
  const projectRoot = process.cwd();
72
72
  const skillsDir = path.resolve(projectRoot, flags["skills-dir"]);
73
73
  const outputDir = path.resolve(projectRoot, flags["output-dir"]);
74
- this.log("");
75
- this.log("Compiling skill plugins");
76
- this.log(` Skills directory: ${skillsDir}`);
77
- this.log(` Output directory: ${outputDir}`);
78
- this.log("");
74
+ this.printHeader(skillsDir, outputDir);
79
75
  try {
80
- if (flags.skill) {
81
- const skillPath = path.resolve(skillsDir, flags.skill);
82
- this.log(`Compiling skill at ${skillPath}...`);
83
- const result = await compileSkillPlugin({
84
- skillPath,
85
- outputDir
86
- });
87
- this.log(`Compiled ${result.skillName}`);
88
- this.log(` Plugin path: ${result.pluginPath}`);
89
- } else {
90
- this.log("Finding and compiling all skills...");
91
- const results = await compileAllSkillPlugins(skillsDir, outputDir);
92
- this.log(`Compiled ${results.length} skill plugins`);
93
- printCompilationSummary(results);
94
- }
76
+ await this.compileSkills(flags.skill, skillsDir, outputDir);
95
77
  if (flags["agents-dir"]) {
96
- const agentsDir = path.resolve(projectRoot, flags["agents-dir"]);
97
- this.log("");
98
- this.log("Compiling agent plugins");
99
- this.log(` Agents directory: ${agentsDir}`);
100
- this.log("");
101
- this.log("Finding and compiling all agents...");
102
- const agentResults = await compileAllAgentPlugins(agentsDir, outputDir);
103
- this.log(`Compiled ${agentResults.length} agent plugins`);
104
- printAgentCompilationSummary(agentResults);
78
+ await this.compileAgents(projectRoot, flags["agents-dir"], outputDir);
105
79
  }
106
80
  this.log("");
107
81
  this.logSuccess("Plugin compilation complete!");
@@ -110,6 +84,41 @@ var BuildPlugins = class _BuildPlugins extends BaseCommand {
110
84
  this.handleError(error);
111
85
  }
112
86
  }
87
+ printHeader(skillsDir, outputDir) {
88
+ this.log("");
89
+ this.log("Compiling skill plugins");
90
+ this.log(` Skills directory: ${skillsDir}`);
91
+ this.log(` Output directory: ${outputDir}`);
92
+ this.log("");
93
+ }
94
+ async compileSkills(skillFlag, skillsDir, outputDir) {
95
+ if (skillFlag) {
96
+ const skillPath = path.resolve(skillsDir, skillFlag);
97
+ this.log(`Compiling skill at ${skillPath}...`);
98
+ const result = await compileSkillPlugin({
99
+ skillPath,
100
+ outputDir
101
+ });
102
+ this.log(`Compiled ${result.skillName}`);
103
+ this.log(` Plugin path: ${result.pluginPath}`);
104
+ } else {
105
+ this.log("Finding and compiling all skills...");
106
+ const results = await compileAllSkillPlugins(skillsDir, outputDir);
107
+ this.log(`Compiled ${results.length} skill plugins`);
108
+ printCompilationSummary(results);
109
+ }
110
+ }
111
+ async compileAgents(projectRoot, agentsDir, outputDir) {
112
+ const resolvedAgentsDir = path.resolve(projectRoot, agentsDir);
113
+ this.log("");
114
+ this.log("Compiling agent plugins");
115
+ this.log(` Agents directory: ${resolvedAgentsDir}`);
116
+ this.log("");
117
+ this.log("Finding and compiling all agents...");
118
+ const agentResults = await compileAllAgentPlugins(resolvedAgentsDir, outputDir);
119
+ this.log(`Compiled ${agentResults.length} agent plugins`);
120
+ printAgentCompilationSummary(agentResults);
121
+ }
113
122
  };
114
123
  export {
115
124
  BuildPlugins as default
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/cli/commands/build/plugins.ts"],"sourcesContent":["import { Flags } from \"@oclif/core\";\nimport path from \"path\";\n\nimport { BaseCommand } from \"../../base-command\";\nimport { setVerbose } from \"../../utils/logger\";\nimport { DIRS } from \"../../consts\";\nimport {\n compileAllSkillPlugins,\n compileSkillPlugin,\n printCompilationSummary,\n} from \"../../lib/skills\";\nimport { compileAllAgentPlugins, printAgentCompilationSummary } from \"../../lib/agents\";\n\nconst DEFAULT_OUTPUT_DIR = \"dist/plugins\";\n\nexport default class BuildPlugins extends BaseCommand {\n static summary = \"Build skills and agents into standalone plugins\";\n\n static description =\n \"Build skills and agents into standalone plugins. By default, compiles all skills. Use --skill to compile a specific skill only. Use --agents-dir to also compile agents.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --skill cli-commander\",\n \"<%= config.bin %> <%= command.id %> --skills-dir ./src/skills --output-dir ./plugins\",\n \"<%= config.bin %> <%= command.id %> --agents-dir ./agents\",\n \"<%= config.bin %> <%= command.id %> --verbose\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n \"skills-dir\": Flags.string({\n char: \"s\",\n description: \"Skills source directory\",\n default: DIRS.skills,\n }),\n \"agents-dir\": Flags.string({\n char: \"a\",\n description: \"Agents source directory (builds one plugin per agent)\",\n }),\n \"output-dir\": Flags.string({\n char: \"o\",\n description: \"Output directory\",\n default: DEFAULT_OUTPUT_DIR,\n }),\n skill: Flags.string({\n description: \"Compile only a specific skill (path to skill directory)\",\n }),\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(BuildPlugins);\n\n setVerbose(flags.verbose);\n\n const projectRoot = process.cwd();\n const skillsDir = path.resolve(projectRoot, flags[\"skills-dir\"]);\n const outputDir = path.resolve(projectRoot, flags[\"output-dir\"]);\n\n this.log(\"\");\n this.log(\"Compiling skill plugins\");\n this.log(` Skills directory: ${skillsDir}`);\n this.log(` Output directory: ${outputDir}`);\n this.log(\"\");\n\n try {\n if (flags.skill) {\n const skillPath = path.resolve(skillsDir, flags.skill);\n this.log(`Compiling skill at ${skillPath}...`);\n\n const result = await compileSkillPlugin({\n skillPath,\n outputDir,\n });\n\n this.log(`Compiled ${result.skillName}`);\n this.log(` Plugin path: ${result.pluginPath}`);\n } else {\n this.log(\"Finding and compiling all skills...\");\n\n const results = await compileAllSkillPlugins(skillsDir, outputDir);\n\n this.log(`Compiled ${results.length} skill plugins`);\n printCompilationSummary(results);\n }\n\n if (flags[\"agents-dir\"]) {\n const agentsDir = path.resolve(projectRoot, flags[\"agents-dir\"]);\n\n this.log(\"\");\n this.log(\"Compiling agent plugins\");\n this.log(` Agents directory: ${agentsDir}`);\n this.log(\"\");\n\n this.log(\"Finding and compiling all agents...\");\n\n const agentResults = await compileAllAgentPlugins(agentsDir, outputDir);\n\n this.log(`Compiled ${agentResults.length} agent plugins`);\n printAgentCompilationSummary(agentResults);\n }\n\n this.log(\"\");\n this.logSuccess(\"Plugin compilation complete!\");\n } catch (error) {\n this.log(\"Compilation failed\");\n this.handleError(error);\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA,SAAS,aAAa;AACtB,OAAO,UAAU;AAYjB,IAAM,qBAAqB;AAE3B,IAAqB,eAArB,MAAqB,sBAAqB,YAAY;AAAA,EACpD,OAAO,UAAU;AAAA,EAEjB,OAAO,cACL;AAAA,EAEF,OAAO,WAAW;AAAA,IAChB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA,EAEA,OAAO,QAAQ;AAAA,IACb,GAAG,YAAY;AAAA,IACf,cAAc,MAAM,OAAO;AAAA,MACzB,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS,KAAK;AAAA,IAChB,CAAC;AAAA,IACD,cAAc,MAAM,OAAO;AAAA,MACzB,MAAM;AAAA,MACN,aAAa;AAAA,IACf,CAAC;AAAA,IACD,cAAc,MAAM,OAAO;AAAA,MACzB,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,IACX,CAAC;AAAA,IACD,OAAO,MAAM,OAAO;AAAA,MAClB,aAAa;AAAA,IACf,CAAC;AAAA,IACD,SAAS,MAAM,QAAQ;AAAA,MACrB,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,IACX,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,MAAqB;AACzB,UAAM,EAAE,MAAM,IAAI,MAAM,KAAK,MAAM,aAAY;AAE/C,eAAW,MAAM,OAAO;AAExB,UAAM,cAAc,QAAQ,IAAI;AAChC,UAAM,YAAY,KAAK,QAAQ,aAAa,MAAM,YAAY,CAAC;AAC/D,UAAM,YAAY,KAAK,QAAQ,aAAa,MAAM,YAAY,CAAC;AAE/D,SAAK,IAAI,EAAE;AACX,SAAK,IAAI,yBAAyB;AAClC,SAAK,IAAI,uBAAuB,SAAS,EAAE;AAC3C,SAAK,IAAI,uBAAuB,SAAS,EAAE;AAC3C,SAAK,IAAI,EAAE;AAEX,QAAI;AACF,UAAI,MAAM,OAAO;AACf,cAAM,YAAY,KAAK,QAAQ,WAAW,MAAM,KAAK;AACrD,aAAK,IAAI,sBAAsB,SAAS,KAAK;AAE7C,cAAM,SAAS,MAAM,mBAAmB;AAAA,UACtC;AAAA,UACA;AAAA,QACF,CAAC;AAED,aAAK,IAAI,YAAY,OAAO,SAAS,EAAE;AACvC,aAAK,IAAI,kBAAkB,OAAO,UAAU,EAAE;AAAA,MAChD,OAAO;AACL,aAAK,IAAI,qCAAqC;AAE9C,cAAM,UAAU,MAAM,uBAAuB,WAAW,SAAS;AAEjE,aAAK,IAAI,YAAY,QAAQ,MAAM,gBAAgB;AACnD,gCAAwB,OAAO;AAAA,MACjC;AAEA,UAAI,MAAM,YAAY,GAAG;AACvB,cAAM,YAAY,KAAK,QAAQ,aAAa,MAAM,YAAY,CAAC;AAE/D,aAAK,IAAI,EAAE;AACX,aAAK,IAAI,yBAAyB;AAClC,aAAK,IAAI,uBAAuB,SAAS,EAAE;AAC3C,aAAK,IAAI,EAAE;AAEX,aAAK,IAAI,qCAAqC;AAE9C,cAAM,eAAe,MAAM,uBAAuB,WAAW,SAAS;AAEtE,aAAK,IAAI,YAAY,aAAa,MAAM,gBAAgB;AACxD,qCAA6B,YAAY;AAAA,MAC3C;AAEA,WAAK,IAAI,EAAE;AACX,WAAK,WAAW,8BAA8B;AAAA,IAChD,SAAS,OAAO;AACd,WAAK,IAAI,oBAAoB;AAC7B,WAAK,YAAY,KAAK;AAAA,IACxB;AAAA,EACF;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../src/cli/commands/build/plugins.ts"],"sourcesContent":["import { Flags } from \"@oclif/core\";\nimport path from \"path\";\n\nimport { BaseCommand } from \"../../base-command\";\nimport { setVerbose } from \"../../utils/logger\";\nimport { DIRS } from \"../../consts\";\nimport {\n compileAllSkillPlugins,\n compileSkillPlugin,\n printCompilationSummary,\n} from \"../../lib/skills\";\nimport { compileAllAgentPlugins, printAgentCompilationSummary } from \"../../lib/agents\";\n\nconst DEFAULT_OUTPUT_DIR = \"dist/plugins\";\n\nexport default class BuildPlugins extends BaseCommand {\n static summary = \"Build skills and agents into standalone plugins\";\n\n static description =\n \"Build skills and agents into standalone plugins. By default, compiles all skills. Use --skill to compile a specific skill only. Use --agents-dir to also compile agents.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --skill cli-commander\",\n \"<%= config.bin %> <%= command.id %> --skills-dir ./src/skills --output-dir ./plugins\",\n \"<%= config.bin %> <%= command.id %> --agents-dir ./agents\",\n \"<%= config.bin %> <%= command.id %> --verbose\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n \"skills-dir\": Flags.string({\n char: \"s\",\n description: \"Skills source directory\",\n default: DIRS.skills,\n }),\n \"agents-dir\": Flags.string({\n char: \"a\",\n description: \"Agents source directory (builds one plugin per agent)\",\n }),\n \"output-dir\": Flags.string({\n char: \"o\",\n description: \"Output directory\",\n default: DEFAULT_OUTPUT_DIR,\n }),\n skill: Flags.string({\n description: \"Compile only a specific skill (path to skill directory)\",\n }),\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(BuildPlugins);\n setVerbose(flags.verbose);\n\n const projectRoot = process.cwd();\n const skillsDir = path.resolve(projectRoot, flags[\"skills-dir\"]);\n const outputDir = path.resolve(projectRoot, flags[\"output-dir\"]);\n\n this.printHeader(skillsDir, outputDir);\n\n try {\n await this.compileSkills(flags.skill, skillsDir, outputDir);\n\n if (flags[\"agents-dir\"]) {\n await this.compileAgents(projectRoot, flags[\"agents-dir\"], outputDir);\n }\n\n this.log(\"\");\n this.logSuccess(\"Plugin compilation complete!\");\n } catch (error) {\n this.log(\"Compilation failed\");\n this.handleError(error);\n }\n }\n\n private printHeader(skillsDir: string, outputDir: string): void {\n this.log(\"\");\n this.log(\"Compiling skill plugins\");\n this.log(` Skills directory: ${skillsDir}`);\n this.log(` Output directory: ${outputDir}`);\n this.log(\"\");\n }\n\n private async compileSkills(\n skillFlag: string | undefined,\n skillsDir: string,\n outputDir: string,\n ): Promise<void> {\n if (skillFlag) {\n const skillPath = path.resolve(skillsDir, skillFlag);\n this.log(`Compiling skill at ${skillPath}...`);\n\n const result = await compileSkillPlugin({\n skillPath,\n outputDir,\n });\n\n this.log(`Compiled ${result.skillName}`);\n this.log(` Plugin path: ${result.pluginPath}`);\n } else {\n this.log(\"Finding and compiling all skills...\");\n\n const results = await compileAllSkillPlugins(skillsDir, outputDir);\n\n this.log(`Compiled ${results.length} skill plugins`);\n printCompilationSummary(results);\n }\n }\n\n private async compileAgents(\n projectRoot: string,\n agentsDir: string,\n outputDir: string,\n ): Promise<void> {\n const resolvedAgentsDir = path.resolve(projectRoot, agentsDir);\n\n this.log(\"\");\n this.log(\"Compiling agent plugins\");\n this.log(` Agents directory: ${resolvedAgentsDir}`);\n this.log(\"\");\n\n this.log(\"Finding and compiling all agents...\");\n\n const agentResults = await compileAllAgentPlugins(resolvedAgentsDir, outputDir);\n\n this.log(`Compiled ${agentResults.length} agent plugins`);\n printAgentCompilationSummary(agentResults);\n }\n}\n"],"mappings":"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","names":[]}
@@ -88,51 +88,59 @@ var BuildStack = class _BuildStack extends BaseCommand {
88
88
  setVerbose(flags.verbose);
89
89
  const projectRoot = process.cwd();
90
90
  const outputDir = path.resolve(projectRoot, flags["output-dir"]);
91
- let stackId = flags.stack;
92
- if (!stackId) {
93
- const stacks = await loadStacks(projectRoot);
94
- const availableStacks = stacks.map((s) => s.id).sort();
95
- if (availableStacks.length === 0) {
96
- this.error(`No stacks found in ${STACKS_FILE_PATH}`, {
97
- exit: EXIT_CODES.ERROR
98
- });
99
- }
100
- stackId = await new Promise((resolve, reject) => {
101
- const { waitUntilExit } = render(
102
- /* @__PURE__ */ jsx(
103
- StackSelector,
104
- {
105
- availableStacks,
106
- onSelect: (selected) => {
107
- resolve(selected);
108
- }
109
- }
110
- )
111
- );
112
- waitUntilExit().catch(reject);
113
- }).catch(() => {
114
- this.log("Cancelled");
115
- this.exit(EXIT_CODES.CANCELLED);
91
+ const stackId = flags.stack ?? await this.selectStackInteractively(projectRoot);
92
+ this.printCompileHeader(stackId, outputDir);
93
+ const agentSourcePath = await this.loadAgentPartials(flags);
94
+ await this.compileStack(stackId, outputDir, projectRoot, agentSourcePath);
95
+ }
96
+ async selectStackInteractively(projectRoot) {
97
+ const stacks = await loadStacks(projectRoot);
98
+ const availableStacks = stacks.map((s) => s.id).sort();
99
+ if (availableStacks.length === 0) {
100
+ this.error(`No stacks found in ${STACKS_FILE_PATH}`, {
101
+ exit: EXIT_CODES.ERROR
116
102
  });
117
103
  }
104
+ return new Promise((resolve, reject) => {
105
+ const { waitUntilExit } = render(
106
+ /* @__PURE__ */ jsx(
107
+ StackSelector,
108
+ {
109
+ availableStacks,
110
+ onSelect: (selected) => {
111
+ resolve(selected);
112
+ }
113
+ }
114
+ )
115
+ );
116
+ waitUntilExit().catch(reject);
117
+ }).catch(() => {
118
+ this.log("Cancelled");
119
+ this.exit(EXIT_CODES.CANCELLED);
120
+ });
121
+ }
122
+ printCompileHeader(stackId, outputDir) {
118
123
  this.log("");
119
124
  this.log(`Compiling stack plugin: ${stackId}`);
120
125
  this.log(` Output directory: ${outputDir}`);
121
126
  this.log("");
122
- let agentSourcePath;
127
+ }
128
+ async loadAgentPartials(flags) {
123
129
  try {
124
130
  this.log(flags["agent-source"] ? "Fetching agent partials..." : "Loading agent partials...");
125
131
  const agentDefs = await getAgentDefinitions(flags["agent-source"], {
126
132
  forceRefresh: flags.refresh
127
133
  });
128
- agentSourcePath = agentDefs.sourcePath;
129
134
  this.log(
130
135
  flags["agent-source"] ? `Agent partials fetched from: ${flags["agent-source"]}` : `Agent partials loaded from: ${PROJECT_ROOT}`
131
136
  );
137
+ return agentDefs.sourcePath;
132
138
  } catch (error) {
133
139
  this.log("Failed to load agent partials");
134
140
  this.handleError(error);
135
141
  }
142
+ }
143
+ async compileStack(stackId, outputDir, projectRoot, agentSourcePath) {
136
144
  try {
137
145
  this.log(`Compiling stack "${stackId}"...`);
138
146
  const result = await compileStackPlugin({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/cli/commands/build/stack.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Flags } from \"@oclif/core\";\nimport { Select } from \"@inkjs/ui\";\nimport { render, Box, Text } from \"ink\";\nimport path from \"path\";\n\nimport { BaseCommand } from \"../../base-command\";\nimport { setVerbose } from \"../../utils/logger\";\nimport { PROJECT_ROOT, STACKS_FILE_PATH } from \"../../consts\";\nimport { compileStackPlugin, printStackCompilationSummary, loadStacks } from \"../../lib/stacks\";\nimport { getAgentDefinitions } from \"../../lib/agents\";\nimport { EXIT_CODES } from \"../../lib/exit-codes\";\n\nconst DEFAULT_OUTPUT_DIR = \"dist/stacks\";\n\ntype StackSelectorProps = {\n availableStacks: string[];\n onSelect: (stackId: string) => void;\n};\n\nconst StackSelector: React.FC<StackSelectorProps> = ({ availableStacks, onSelect }) => {\n return (\n <Box flexDirection=\"column\">\n <Text>Select a stack to compile:</Text>\n <Select\n options={availableStacks.map((name) => ({\n value: name,\n label: name,\n }))}\n onChange={(value) => {\n onSelect(value);\n }}\n />\n </Box>\n );\n};\n\nexport default class BuildStack extends BaseCommand {\n static summary = \"Build a stack into a standalone plugin\";\n\n static description =\n \"Build a stack into a standalone plugin (requires skills repo). If no stack is specified, you will be prompted to select one.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --stack frontend-stack\",\n \"<%= config.bin %> <%= command.id %> --stack frontend-stack --output-dir ./plugins\",\n \"<%= config.bin %> <%= command.id %> --agent-source /path/to/agents --refresh\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n stack: Flags.string({\n description: \"Stack ID to compile (directory name in src/stacks/)\",\n }),\n \"output-dir\": Flags.string({\n char: \"o\",\n description: \"Output directory\",\n default: DEFAULT_OUTPUT_DIR,\n }),\n \"agent-source\": Flags.string({\n description: \"Agent partials source (default: local CLI)\",\n }),\n refresh: Flags.boolean({\n description: \"Force refresh remote agent source\",\n default: false,\n }),\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(BuildStack);\n\n setVerbose(flags.verbose);\n\n const projectRoot = process.cwd();\n const outputDir = path.resolve(projectRoot, flags[\"output-dir\"]);\n\n let stackId = flags.stack;\n\n if (!stackId) {\n const stacks = await loadStacks(projectRoot);\n const availableStacks = stacks.map((s) => s.id).sort();\n\n if (availableStacks.length === 0) {\n this.error(`No stacks found in ${STACKS_FILE_PATH}`, {\n exit: EXIT_CODES.ERROR,\n });\n }\n\n stackId = await new Promise<string>((resolve, reject) => {\n const { waitUntilExit } = render(\n <StackSelector\n availableStacks={availableStacks}\n onSelect={(selected) => {\n resolve(selected);\n }}\n />,\n );\n\n waitUntilExit().catch(reject);\n }).catch(() => {\n this.log(\"Cancelled\");\n this.exit(EXIT_CODES.CANCELLED);\n });\n }\n\n this.log(\"\");\n this.log(`Compiling stack plugin: ${stackId}`);\n this.log(` Output directory: ${outputDir}`);\n this.log(\"\");\n\n let agentSourcePath: string;\n try {\n this.log(flags[\"agent-source\"] ? \"Fetching agent partials...\" : \"Loading agent partials...\");\n const agentDefs = await getAgentDefinitions(flags[\"agent-source\"], {\n forceRefresh: flags.refresh,\n });\n agentSourcePath = agentDefs.sourcePath;\n this.log(\n flags[\"agent-source\"]\n ? `Agent partials fetched from: ${flags[\"agent-source\"]}`\n : `Agent partials loaded from: ${PROJECT_ROOT}`,\n );\n } catch (error) {\n this.log(\"Failed to load agent partials\");\n this.handleError(error);\n }\n\n try {\n this.log(`Compiling stack \"${stackId}\"...`);\n\n const result = await compileStackPlugin({\n stackId,\n outputDir,\n projectRoot,\n agentSourcePath,\n });\n\n this.log(`Compiled stack plugin: ${result.stackName}`);\n\n printStackCompilationSummary(result);\n\n this.log(\"\");\n this.logSuccess(\"Stack plugin compilation complete!\");\n } catch (error) {\n this.log(\"Compilation failed\");\n this.handleError(error);\n }\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../../src/cli/commands/build/stack.tsx"],"sourcesContent":["import React from \"react\";\n\nimport { Flags } from \"@oclif/core\";\nimport { Select } from \"@inkjs/ui\";\nimport { render, Box, Text } from \"ink\";\nimport path from \"path\";\n\nimport { BaseCommand } from \"../../base-command\";\nimport { setVerbose } from \"../../utils/logger\";\nimport { PROJECT_ROOT, STACKS_FILE_PATH } from \"../../consts\";\nimport { compileStackPlugin, printStackCompilationSummary, loadStacks } from \"../../lib/stacks\";\nimport { getAgentDefinitions } from \"../../lib/agents\";\nimport { EXIT_CODES } from \"../../lib/exit-codes\";\n\nconst DEFAULT_OUTPUT_DIR = \"dist/stacks\";\n\ntype StackSelectorProps = {\n availableStacks: string[];\n onSelect: (stackId: string) => void;\n};\n\nconst StackSelector: React.FC<StackSelectorProps> = ({ availableStacks, onSelect }) => {\n return (\n <Box flexDirection=\"column\">\n <Text>Select a stack to compile:</Text>\n <Select\n options={availableStacks.map((name) => ({\n value: name,\n label: name,\n }))}\n onChange={(value) => {\n onSelect(value);\n }}\n />\n </Box>\n );\n};\n\nexport default class BuildStack extends BaseCommand {\n static summary = \"Build a stack into a standalone plugin\";\n\n static description =\n \"Build a stack into a standalone plugin (requires skills repo). If no stack is specified, you will be prompted to select one.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --stack frontend-stack\",\n \"<%= config.bin %> <%= command.id %> --stack frontend-stack --output-dir ./plugins\",\n \"<%= config.bin %> <%= command.id %> --agent-source /path/to/agents --refresh\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n stack: Flags.string({\n description: \"Stack ID to compile (directory name in src/stacks/)\",\n }),\n \"output-dir\": Flags.string({\n char: \"o\",\n description: \"Output directory\",\n default: DEFAULT_OUTPUT_DIR,\n }),\n \"agent-source\": Flags.string({\n description: \"Agent partials source (default: local CLI)\",\n }),\n refresh: Flags.boolean({\n description: \"Force refresh remote agent source\",\n default: false,\n }),\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(BuildStack);\n setVerbose(flags.verbose);\n\n const projectRoot = process.cwd();\n const outputDir = path.resolve(projectRoot, flags[\"output-dir\"]);\n\n const stackId = flags.stack ?? (await this.selectStackInteractively(projectRoot));\n\n this.printCompileHeader(stackId, outputDir);\n const agentSourcePath = await this.loadAgentPartials(flags);\n await this.compileStack(stackId, outputDir, projectRoot, agentSourcePath);\n }\n\n private async selectStackInteractively(projectRoot: string): Promise<string> {\n const stacks = await loadStacks(projectRoot);\n const availableStacks = stacks.map((s) => s.id).sort();\n\n if (availableStacks.length === 0) {\n this.error(`No stacks found in ${STACKS_FILE_PATH}`, {\n exit: EXIT_CODES.ERROR,\n });\n }\n\n return new Promise<string>((resolve, reject) => {\n const { waitUntilExit } = render(\n <StackSelector\n availableStacks={availableStacks}\n onSelect={(selected) => {\n resolve(selected);\n }}\n />,\n );\n\n waitUntilExit().catch(reject);\n }).catch(() => {\n this.log(\"Cancelled\");\n this.exit(EXIT_CODES.CANCELLED);\n });\n }\n\n private printCompileHeader(stackId: string, outputDir: string): void {\n this.log(\"\");\n this.log(`Compiling stack plugin: ${stackId}`);\n this.log(` Output directory: ${outputDir}`);\n this.log(\"\");\n }\n\n private async loadAgentPartials(flags: {\n \"agent-source\"?: string;\n refresh: boolean;\n }): Promise<string> {\n try {\n this.log(flags[\"agent-source\"] ? \"Fetching agent partials...\" : \"Loading agent partials...\");\n const agentDefs = await getAgentDefinitions(flags[\"agent-source\"], {\n forceRefresh: flags.refresh,\n });\n this.log(\n flags[\"agent-source\"]\n ? `Agent partials fetched from: ${flags[\"agent-source\"]}`\n : `Agent partials loaded from: ${PROJECT_ROOT}`,\n );\n return agentDefs.sourcePath;\n } catch (error) {\n this.log(\"Failed to load agent partials\");\n this.handleError(error);\n }\n }\n\n private async compileStack(\n stackId: string,\n outputDir: string,\n projectRoot: string,\n agentSourcePath: string,\n ): Promise<void> {\n try {\n this.log(`Compiling stack \"${stackId}\"...`);\n\n const result = await compileStackPlugin({\n stackId,\n outputDir,\n projectRoot,\n agentSourcePath,\n });\n\n this.log(`Compiled stack plugin: ${result.stackName}`);\n printStackCompilationSummary(result);\n\n this.log(\"\");\n this.logSuccess(\"Stack plugin compilation complete!\");\n } catch (error) {\n this.log(\"Compilation failed\");\n this.handleError(error);\n }\n }\n}\n"],"mappings":"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","names":[]}
@@ -100,26 +100,10 @@ var Compile = class _Compile extends BaseCommand {
100
100
  }
101
101
  }
102
102
  async compileAllScopes(installations, agentDefs, cwd) {
103
- const homeDir = os.homedir();
103
+ const passes = buildCompilePasses(installations, cwd, agentDefs.sourcePath);
104
104
  let totalPassesWithSkills = 0;
105
- if (installations.global) {
106
- const hadSkills = await this.runCompilePass({
107
- label: "Global",
108
- projectDir: homeDir,
109
- installation: installations.global,
110
- sourcePath: agentDefs.sourcePath,
111
- scopeFilter: installations.hasBoth ? "global" : void 0
112
- });
113
- if (hadSkills) totalPassesWithSkills++;
114
- }
115
- if (installations.project) {
116
- const hadSkills = await this.runCompilePass({
117
- label: "Project",
118
- projectDir: cwd,
119
- installation: installations.project,
120
- sourcePath: agentDefs.sourcePath,
121
- scopeFilter: installations.hasBoth ? "project" : void 0
122
- });
105
+ for (const pass of passes) {
106
+ const hadSkills = await this.runCompilePass(pass);
123
107
  if (hadSkills) totalPassesWithSkills++;
124
108
  }
125
109
  if (totalPassesWithSkills === 0) {
@@ -132,19 +116,8 @@ var Compile = class _Compile extends BaseCommand {
132
116
  async discoverAllSkills(projectDir) {
133
117
  this.log(STATUS_MESSAGES.DISCOVERING_SKILLS);
134
118
  const result = await discoverInstalledSkills(projectDir);
135
- if (result.totalSkillCount === 0) {
136
- return result;
137
- }
138
- if (result.pluginSkillCount > 0 && result.totalSkillCount > result.pluginSkillCount) {
139
- const localCount = result.totalSkillCount - result.pluginSkillCount;
140
- this.log(
141
- `Discovered ${result.totalSkillCount} skills (${result.pluginSkillCount} from plugins, ${localCount} local)`
142
- );
143
- } else if (result.pluginSkillCount > 0) {
144
- this.log(`Discovered ${result.pluginSkillCount} skills from plugins`);
145
- } else {
146
- this.log(`Discovered ${result.totalSkillCount} local skills`);
147
- }
119
+ if (result.totalSkillCount === 0) return result;
120
+ this.log(formatDiscoveryMessage(result));
148
121
  return result;
149
122
  }
150
123
  async runCompilePass(params) {
@@ -194,6 +167,36 @@ var Compile = class _Compile extends BaseCommand {
194
167
  return true;
195
168
  }
196
169
  };
170
+ function buildCompilePasses(installations, cwd, sourcePath) {
171
+ const passes = [];
172
+ if (installations.global) {
173
+ passes.push({
174
+ label: "Global",
175
+ projectDir: os.homedir(),
176
+ installation: installations.global,
177
+ sourcePath,
178
+ scopeFilter: installations.hasBoth ? "global" : void 0
179
+ });
180
+ }
181
+ if (installations.project) {
182
+ passes.push({
183
+ label: "Project",
184
+ projectDir: cwd,
185
+ installation: installations.project,
186
+ sourcePath,
187
+ scopeFilter: installations.hasBoth ? "project" : void 0
188
+ });
189
+ }
190
+ return passes;
191
+ }
192
+ function formatDiscoveryMessage(result) {
193
+ const { totalSkillCount, pluginSkillCount } = result;
194
+ const localCount = totalSkillCount - pluginSkillCount;
195
+ if (pluginSkillCount > 0 && localCount > 0) {
196
+ return `Discovered ${totalSkillCount} skills (${pluginSkillCount} from plugins, ${localCount} local)`;
197
+ }
198
+ return pluginSkillCount > 0 ? `Discovered ${pluginSkillCount} skills from plugins` : `Discovered ${totalSkillCount} local skills`;
199
+ }
197
200
  export {
198
201
  Compile as default
199
202
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/cli/commands/compile.ts"],"sourcesContent":["import { Flags } from \"@oclif/core\";\nimport os from \"os\";\nimport { BaseCommand } from \"../base-command\";\nimport { setVerbose, verbose } from \"../utils/logger\";\nimport {\n detectBothInstallations,\n type BothInstallations,\n loadAgentDefs,\n type AgentDefs,\n compileAgents,\n discoverInstalledSkills,\n type DiscoveredSkills,\n} from \"../lib/operations\";\nimport { resolveSource } from \"../lib/configuration\";\nimport { CLI_BIN_NAME } from \"../consts\";\nimport { EXIT_CODES } from \"../lib/exit-codes\";\nimport { ERROR_MESSAGES, STATUS_MESSAGES, INFO_MESSAGES } from \"../utils/messages\";\nimport { type Installation } from \"../lib/installation\";\n\nexport default class Compile extends BaseCommand {\n static summary = \"Compile agents using local skills and agent definitions\";\n\n static description =\n \"Compile agents with resolved skill references. Compiles to the Claude plugin directory.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --verbose\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n \"agent-source\": Flags.string({\n description: \"Remote agent partials source (default: local CLI)\",\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(Compile);\n setVerbose(flags.verbose);\n const cwd = process.cwd();\n\n const installations = await this.detectInstallations(cwd);\n await this.resolveAndLogSource(flags.source);\n const agentDefs = await this.loadAgentDefsOrFail(flags, cwd);\n await this.compileAllScopes(installations, agentDefs, cwd);\n }\n\n private async detectInstallations(cwd: string): Promise<BothInstallations> {\n const installations = await detectBothInstallations(cwd);\n\n if (!installations.global && !installations.project) {\n this.error(ERROR_MESSAGES.NO_INSTALLATION, {\n exit: EXIT_CODES.ERROR,\n });\n }\n\n return installations;\n }\n\n private async resolveAndLogSource(sourceFlag?: string): Promise<void> {\n this.log(STATUS_MESSAGES.RESOLVING_SOURCE);\n try {\n const sourceConfig = await resolveSource(sourceFlag);\n this.log(`Source: ${sourceConfig.sourceOrigin}`);\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_RESOLVE_SOURCE);\n this.handleError(error);\n }\n }\n\n private async loadAgentDefsOrFail(\n flags: { \"agent-source\"?: string },\n cwd: string,\n ): Promise<AgentDefs> {\n this.log(\n flags[\"agent-source\"]\n ? STATUS_MESSAGES.FETCHING_AGENT_PARTIALS\n : STATUS_MESSAGES.LOADING_AGENT_PARTIALS,\n );\n try {\n const defs = await loadAgentDefs(flags[\"agent-source\"], { projectDir: cwd });\n this.log(flags[\"agent-source\"] ? \"Agent partials fetched\" : \"Agent partials loaded\");\n verbose(` Agents: ${defs.agentSourcePaths.agentsDir}`);\n verbose(` Templates: ${defs.agentSourcePaths.templatesDir}`);\n return defs;\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_LOAD_AGENT_PARTIALS);\n this.handleError(error);\n }\n }\n\n private async compileAllScopes(\n installations: BothInstallations,\n agentDefs: AgentDefs,\n cwd: string,\n ): Promise<void> {\n const homeDir = os.homedir();\n let totalPassesWithSkills = 0;\n\n // When both installations exist, filter each pass to its own scope to prevent\n // the project pass from overwriting global agents with zero-skill versions\n // (the project config's stack only has project agent entries).\n if (installations.global) {\n const hadSkills = await this.runCompilePass({\n label: \"Global\",\n projectDir: homeDir,\n installation: installations.global,\n sourcePath: agentDefs.sourcePath,\n scopeFilter: installations.hasBoth ? \"global\" : undefined,\n });\n if (hadSkills) totalPassesWithSkills++;\n }\n\n if (installations.project) {\n const hadSkills = await this.runCompilePass({\n label: \"Project\",\n projectDir: cwd,\n installation: installations.project,\n sourcePath: agentDefs.sourcePath,\n scopeFilter: installations.hasBoth ? \"project\" : undefined,\n });\n if (hadSkills) totalPassesWithSkills++;\n }\n\n if (totalPassesWithSkills === 0) {\n this.error(\n `No skills found. Add skills with '${CLI_BIN_NAME} add <skill>' or create in .claude/skills/.`,\n { exit: EXIT_CODES.ERROR },\n );\n }\n }\n\n private async discoverAllSkills(projectDir: string): Promise<DiscoveredSkills> {\n this.log(STATUS_MESSAGES.DISCOVERING_SKILLS);\n const result = await discoverInstalledSkills(projectDir);\n\n if (result.totalSkillCount === 0) {\n return result;\n }\n\n if (result.pluginSkillCount > 0 && result.totalSkillCount > result.pluginSkillCount) {\n const localCount = result.totalSkillCount - result.pluginSkillCount;\n this.log(\n `Discovered ${result.totalSkillCount} skills (${result.pluginSkillCount} from plugins, ${localCount} local)`,\n );\n } else if (result.pluginSkillCount > 0) {\n this.log(`Discovered ${result.pluginSkillCount} skills from plugins`);\n } else {\n this.log(`Discovered ${result.totalSkillCount} local skills`);\n }\n\n return result;\n }\n\n private async runCompilePass(params: {\n label: string;\n projectDir: string;\n installation: Installation;\n sourcePath: string;\n scopeFilter?: \"project\" | \"global\";\n }): Promise<boolean> {\n const { label, projectDir, installation, sourcePath, scopeFilter } = params;\n\n this.log(\"\");\n this.log(`Compiling ${label.toLowerCase()} agents...`);\n this.log(\"\");\n\n verbose(` Project: ${projectDir}`);\n verbose(` Agents: ${installation.agentsDir}`);\n\n const { allSkills, totalSkillCount } = await this.discoverAllSkills(projectDir);\n\n if (totalSkillCount === 0) {\n this.log(`No skills found for ${label.toLowerCase()} pass, skipping`);\n return false;\n }\n\n this.log(STATUS_MESSAGES.RECOMPILING_AGENTS);\n try {\n const recompileResult = await compileAgents({\n projectDir,\n sourcePath,\n skills: allSkills,\n pluginDir: projectDir,\n outputDir: installation.agentsDir,\n scopeFilter,\n });\n\n if (recompileResult.failed.length > 0) {\n this.log(\n `Recompiled ${recompileResult.compiled.length} ${label.toLowerCase()} agents (${recompileResult.failed.length} failed)`,\n );\n for (const warning of recompileResult.warnings) {\n this.warn(warning);\n }\n } else if (recompileResult.compiled.length > 0) {\n this.log(`Recompiled ${recompileResult.compiled.length} ${label.toLowerCase()} agents`);\n } else {\n this.log(INFO_MESSAGES.NO_AGENTS_TO_RECOMPILE);\n }\n\n if (recompileResult.compiled.length > 0) {\n verbose(` Compiled: ${recompileResult.compiled.join(\", \")}`);\n }\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_COMPILE_AGENTS);\n this.handleError(error);\n }\n\n this.log(\"\");\n this.logSuccess(`${label} compile complete!`);\n this.log(\"\");\n\n return true;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA,SAAS,aAAa;AACtB,OAAO,QAAQ;AAkBf,IAAqB,UAArB,MAAqB,iBAAgB,YAAY;AAAA,EAC/C,OAAO,UAAU;AAAA,EAEjB,OAAO,cACL;AAAA,EAEF,OAAO,WAAW;AAAA,IAChB;AAAA,IACA;AAAA,EACF;AAAA,EAEA,OAAO,QAAQ;AAAA,IACb,GAAG,YAAY;AAAA,IACf,SAAS,MAAM,QAAQ;AAAA,MACrB,MAAM;AAAA,MACN,aAAa;AAAA,MACb,SAAS;AAAA,IACX,CAAC;AAAA,IACD,gBAAgB,MAAM,OAAO;AAAA,MAC3B,aAAa;AAAA,IACf,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,MAAqB;AACzB,UAAM,EAAE,MAAM,IAAI,MAAM,KAAK,MAAM,QAAO;AAC1C,eAAW,MAAM,OAAO;AACxB,UAAM,MAAM,QAAQ,IAAI;AAExB,UAAM,gBAAgB,MAAM,KAAK,oBAAoB,GAAG;AACxD,UAAM,KAAK,oBAAoB,MAAM,MAAM;AAC3C,UAAM,YAAY,MAAM,KAAK,oBAAoB,OAAO,GAAG;AAC3D,UAAM,KAAK,iBAAiB,eAAe,WAAW,GAAG;AAAA,EAC3D;AAAA,EAEA,MAAc,oBAAoB,KAAyC;AACzE,UAAM,gBAAgB,MAAM,wBAAwB,GAAG;AAEvD,QAAI,CAAC,cAAc,UAAU,CAAC,cAAc,SAAS;AACnD,WAAK,MAAM,eAAe,iBAAiB;AAAA,QACzC,MAAM,WAAW;AAAA,MACnB,CAAC;AAAA,IACH;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,oBAAoB,YAAoC;AACpE,SAAK,IAAI,gBAAgB,gBAAgB;AACzC,QAAI;AACF,YAAM,eAAe,MAAM,cAAc,UAAU;AACnD,WAAK,IAAI,WAAW,aAAa,YAAY,EAAE;AAAA,IACjD,SAAS,OAAO;AACd,WAAK,IAAI,eAAe,qBAAqB;AAC7C,WAAK,YAAY,KAAK;AAAA,IACxB;AAAA,EACF;AAAA,EAEA,MAAc,oBACZ,OACA,KACoB;AACpB,SAAK;AAAA,MACH,MAAM,cAAc,IAChB,gBAAgB,0BAChB,gBAAgB;AAAA,IACtB;AACA,QAAI;AACF,YAAM,OAAO,MAAM,cAAc,MAAM,cAAc,GAAG,EAAE,YAAY,IAAI,CAAC;AAC3E,WAAK,IAAI,MAAM,cAAc,IAAI,2BAA2B,uBAAuB;AACnF,cAAQ,aAAa,KAAK,iBAAiB,SAAS,EAAE;AACtD,cAAQ,gBAAgB,KAAK,iBAAiB,YAAY,EAAE;AAC5D,aAAO;AAAA,IACT,SAAS,OAAO;AACd,WAAK,IAAI,eAAe,0BAA0B;AAClD,WAAK,YAAY,KAAK;AAAA,IACxB;AAAA,EACF;AAAA,EAEA,MAAc,iBACZ,eACA,WACA,KACe;AACf,UAAM,UAAU,GAAG,QAAQ;AAC3B,QAAI,wBAAwB;AAK5B,QAAI,cAAc,QAAQ;AACxB,YAAM,YAAY,MAAM,KAAK,eAAe;AAAA,QAC1C,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,cAAc,cAAc;AAAA,QAC5B,YAAY,UAAU;AAAA,QACtB,aAAa,cAAc,UAAU,WAAW;AAAA,MAClD,CAAC;AACD,UAAI,UAAW;AAAA,IACjB;AAEA,QAAI,cAAc,SAAS;AACzB,YAAM,YAAY,MAAM,KAAK,eAAe;AAAA,QAC1C,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,cAAc,cAAc;AAAA,QAC5B,YAAY,UAAU;AAAA,QACtB,aAAa,cAAc,UAAU,YAAY;AAAA,MACnD,CAAC;AACD,UAAI,UAAW;AAAA,IACjB;AAEA,QAAI,0BAA0B,GAAG;AAC/B,WAAK;AAAA,QACH,qCAAqC,YAAY;AAAA,QACjD,EAAE,MAAM,WAAW,MAAM;AAAA,MAC3B;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAc,kBAAkB,YAA+C;AAC7E,SAAK,IAAI,gBAAgB,kBAAkB;AAC3C,UAAM,SAAS,MAAM,wBAAwB,UAAU;AAEvD,QAAI,OAAO,oBAAoB,GAAG;AAChC,aAAO;AAAA,IACT;AAEA,QAAI,OAAO,mBAAmB,KAAK,OAAO,kBAAkB,OAAO,kBAAkB;AACnF,YAAM,aAAa,OAAO,kBAAkB,OAAO;AACnD,WAAK;AAAA,QACH,cAAc,OAAO,eAAe,YAAY,OAAO,gBAAgB,kBAAkB,UAAU;AAAA,MACrG;AAAA,IACF,WAAW,OAAO,mBAAmB,GAAG;AACtC,WAAK,IAAI,cAAc,OAAO,gBAAgB,sBAAsB;AAAA,IACtE,OAAO;AACL,WAAK,IAAI,cAAc,OAAO,eAAe,eAAe;AAAA,IAC9D;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,eAAe,QAMR;AACnB,UAAM,EAAE,OAAO,YAAY,cAAc,YAAY,YAAY,IAAI;AAErE,SAAK,IAAI,EAAE;AACX,SAAK,IAAI,aAAa,MAAM,YAAY,CAAC,YAAY;AACrD,SAAK,IAAI,EAAE;AAEX,YAAQ,cAAc,UAAU,EAAE;AAClC,YAAQ,aAAa,aAAa,SAAS,EAAE;AAE7C,UAAM,EAAE,WAAW,gBAAgB,IAAI,MAAM,KAAK,kBAAkB,UAAU;AAE9E,QAAI,oBAAoB,GAAG;AACzB,WAAK,IAAI,uBAAuB,MAAM,YAAY,CAAC,iBAAiB;AACpE,aAAO;AAAA,IACT;AAEA,SAAK,IAAI,gBAAgB,kBAAkB;AAC3C,QAAI;AACF,YAAM,kBAAkB,MAAM,cAAc;AAAA,QAC1C;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,QACR,WAAW;AAAA,QACX,WAAW,aAAa;AAAA,QACxB;AAAA,MACF,CAAC;AAED,UAAI,gBAAgB,OAAO,SAAS,GAAG;AACrC,aAAK;AAAA,UACH,cAAc,gBAAgB,SAAS,MAAM,IAAI,MAAM,YAAY,CAAC,YAAY,gBAAgB,OAAO,MAAM;AAAA,QAC/G;AACA,mBAAW,WAAW,gBAAgB,UAAU;AAC9C,eAAK,KAAK,OAAO;AAAA,QACnB;AAAA,MACF,WAAW,gBAAgB,SAAS,SAAS,GAAG;AAC9C,aAAK,IAAI,cAAc,gBAAgB,SAAS,MAAM,IAAI,MAAM,YAAY,CAAC,SAAS;AAAA,MACxF,OAAO;AACL,aAAK,IAAI,cAAc,sBAAsB;AAAA,MAC/C;AAEA,UAAI,gBAAgB,SAAS,SAAS,GAAG;AACvC,gBAAQ,eAAe,gBAAgB,SAAS,KAAK,IAAI,CAAC,EAAE;AAAA,MAC9D;AAAA,IACF,SAAS,OAAO;AACd,WAAK,IAAI,eAAe,qBAAqB;AAC7C,WAAK,YAAY,KAAK;AAAA,IACxB;AAEA,SAAK,IAAI,EAAE;AACX,SAAK,WAAW,GAAG,KAAK,oBAAoB;AAC5C,SAAK,IAAI,EAAE;AAEX,WAAO;AAAA,EACT;AACF;","names":[]}
1
+ {"version":3,"sources":["../../src/cli/commands/compile.ts"],"sourcesContent":["import { Flags } from \"@oclif/core\";\nimport os from \"os\";\nimport { BaseCommand } from \"../base-command\";\nimport { setVerbose, verbose } from \"../utils/logger\";\nimport {\n detectBothInstallations,\n type BothInstallations,\n loadAgentDefs,\n type AgentDefs,\n compileAgents,\n discoverInstalledSkills,\n type DiscoveredSkills,\n} from \"../lib/operations\";\nimport { resolveSource } from \"../lib/configuration\";\nimport { CLI_BIN_NAME } from \"../consts\";\nimport { EXIT_CODES } from \"../lib/exit-codes\";\nimport { ERROR_MESSAGES, STATUS_MESSAGES, INFO_MESSAGES } from \"../utils/messages\";\nimport { type Installation } from \"../lib/installation\";\n\nexport default class Compile extends BaseCommand {\n static summary = \"Compile agents using local skills and agent definitions\";\n\n static description =\n \"Compile agents with resolved skill references. Compiles to the Claude plugin directory.\";\n\n static examples = [\n \"<%= config.bin %> <%= command.id %>\",\n \"<%= config.bin %> <%= command.id %> --verbose\",\n ];\n\n static flags = {\n ...BaseCommand.baseFlags,\n verbose: Flags.boolean({\n char: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n }),\n \"agent-source\": Flags.string({\n description: \"Remote agent partials source (default: local CLI)\",\n }),\n };\n\n async run(): Promise<void> {\n const { flags } = await this.parse(Compile);\n setVerbose(flags.verbose);\n const cwd = process.cwd();\n\n const installations = await this.detectInstallations(cwd);\n await this.resolveAndLogSource(flags.source);\n const agentDefs = await this.loadAgentDefsOrFail(flags, cwd);\n await this.compileAllScopes(installations, agentDefs, cwd);\n }\n\n private async detectInstallations(cwd: string): Promise<BothInstallations> {\n const installations = await detectBothInstallations(cwd);\n\n if (!installations.global && !installations.project) {\n this.error(ERROR_MESSAGES.NO_INSTALLATION, {\n exit: EXIT_CODES.ERROR,\n });\n }\n\n return installations;\n }\n\n private async resolveAndLogSource(sourceFlag?: string): Promise<void> {\n this.log(STATUS_MESSAGES.RESOLVING_SOURCE);\n try {\n const sourceConfig = await resolveSource(sourceFlag);\n this.log(`Source: ${sourceConfig.sourceOrigin}`);\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_RESOLVE_SOURCE);\n this.handleError(error);\n }\n }\n\n private async loadAgentDefsOrFail(\n flags: { \"agent-source\"?: string },\n cwd: string,\n ): Promise<AgentDefs> {\n this.log(\n flags[\"agent-source\"]\n ? STATUS_MESSAGES.FETCHING_AGENT_PARTIALS\n : STATUS_MESSAGES.LOADING_AGENT_PARTIALS,\n );\n try {\n const defs = await loadAgentDefs(flags[\"agent-source\"], { projectDir: cwd });\n this.log(flags[\"agent-source\"] ? \"Agent partials fetched\" : \"Agent partials loaded\");\n verbose(` Agents: ${defs.agentSourcePaths.agentsDir}`);\n verbose(` Templates: ${defs.agentSourcePaths.templatesDir}`);\n return defs;\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_LOAD_AGENT_PARTIALS);\n this.handleError(error);\n }\n }\n\n private async compileAllScopes(\n installations: BothInstallations,\n agentDefs: AgentDefs,\n cwd: string,\n ): Promise<void> {\n // When both installations exist, filter each pass to its own scope to prevent\n // the project pass from overwriting global agents with zero-skill versions\n // (the project config's stack only has project agent entries).\n const passes = buildCompilePasses(installations, cwd, agentDefs.sourcePath);\n\n let totalPassesWithSkills = 0;\n for (const pass of passes) {\n const hadSkills = await this.runCompilePass(pass);\n if (hadSkills) totalPassesWithSkills++;\n }\n\n if (totalPassesWithSkills === 0) {\n this.error(\n `No skills found. Add skills with '${CLI_BIN_NAME} add <skill>' or create in .claude/skills/.`,\n { exit: EXIT_CODES.ERROR },\n );\n }\n }\n\n private async discoverAllSkills(projectDir: string): Promise<DiscoveredSkills> {\n this.log(STATUS_MESSAGES.DISCOVERING_SKILLS);\n const result = await discoverInstalledSkills(projectDir);\n if (result.totalSkillCount === 0) return result;\n this.log(formatDiscoveryMessage(result));\n return result;\n }\n\n private async runCompilePass(params: CompilePass): Promise<boolean> {\n const { label, projectDir, installation, sourcePath, scopeFilter } = params;\n\n this.log(\"\");\n this.log(`Compiling ${label.toLowerCase()} agents...`);\n this.log(\"\");\n\n verbose(` Project: ${projectDir}`);\n verbose(` Agents: ${installation.agentsDir}`);\n\n const { allSkills, totalSkillCount } = await this.discoverAllSkills(projectDir);\n\n if (totalSkillCount === 0) {\n this.log(`No skills found for ${label.toLowerCase()} pass, skipping`);\n return false;\n }\n\n this.log(STATUS_MESSAGES.RECOMPILING_AGENTS);\n try {\n const recompileResult = await compileAgents({\n projectDir,\n sourcePath,\n skills: allSkills,\n pluginDir: projectDir,\n outputDir: installation.agentsDir,\n scopeFilter,\n });\n\n if (recompileResult.failed.length > 0) {\n this.log(\n `Recompiled ${recompileResult.compiled.length} ${label.toLowerCase()} agents (${recompileResult.failed.length} failed)`,\n );\n for (const warning of recompileResult.warnings) {\n this.warn(warning);\n }\n } else if (recompileResult.compiled.length > 0) {\n this.log(`Recompiled ${recompileResult.compiled.length} ${label.toLowerCase()} agents`);\n } else {\n this.log(INFO_MESSAGES.NO_AGENTS_TO_RECOMPILE);\n }\n\n if (recompileResult.compiled.length > 0) {\n verbose(` Compiled: ${recompileResult.compiled.join(\", \")}`);\n }\n } catch (error) {\n this.log(ERROR_MESSAGES.FAILED_COMPILE_AGENTS);\n this.handleError(error);\n }\n\n this.log(\"\");\n this.logSuccess(`${label} compile complete!`);\n this.log(\"\");\n\n return true;\n }\n}\n\ntype CompilePass = {\n label: string;\n projectDir: string;\n installation: Installation;\n sourcePath: string;\n scopeFilter?: \"project\" | \"global\";\n};\n\nfunction buildCompilePasses(\n installations: BothInstallations,\n cwd: string,\n sourcePath: string,\n): CompilePass[] {\n const passes: CompilePass[] = [];\n\n if (installations.global) {\n passes.push({\n label: \"Global\",\n projectDir: os.homedir(),\n installation: installations.global,\n sourcePath,\n scopeFilter: installations.hasBoth ? \"global\" : undefined,\n });\n }\n\n if (installations.project) {\n passes.push({\n label: \"Project\",\n projectDir: cwd,\n installation: installations.project,\n sourcePath,\n scopeFilter: installations.hasBoth ? \"project\" : undefined,\n });\n }\n\n return passes;\n}\n\nfunction formatDiscoveryMessage(result: DiscoveredSkills): string {\n const { totalSkillCount, pluginSkillCount } = result;\n const localCount = totalSkillCount - pluginSkillCount;\n\n if (pluginSkillCount > 0 && localCount > 0) {\n return `Discovered ${totalSkillCount} skills (${pluginSkillCount} from plugins, ${localCount} local)`;\n }\n\n return pluginSkillCount > 0\n ? `Discovered ${pluginSkillCount} skills from plugins`\n : `Discovered ${totalSkillCount} local skills`;\n}\n"],"mappings":"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","names":[]}
@@ -729,9 +729,7 @@ async function generateSkillDiff(localSkillsPath, skillDirName, sourcePath, sour
729
729
  ""
730
730
  // No local header
731
731
  );
732
- const hasDiff = diff.split("\n").some((line) => {
733
- return (line.startsWith("+") || line.startsWith("-")) && !line.startsWith("+++") && !line.startsWith("---");
734
- });
732
+ const hasDiff = diff.split("\n").some(isContentChangeLine);
735
733
  return {
736
734
  skillDirName,
737
735
  forkedFrom,
@@ -756,6 +754,9 @@ function formatColoredDiff(diffText) {
756
754
  return line;
757
755
  }).join("\n");
758
756
  }
757
+ function isContentChangeLine(line) {
758
+ return (line.startsWith("+") || line.startsWith("-")) && !line.startsWith("+++") && !line.startsWith("---");
759
+ }
759
760
  export {
760
761
  Diff as default
761
762
  };