sudocode 1.1.17 → 1.1.18-dev.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 (738) hide show
  1. package/node_modules/@sudocode-ai/cli/README.md +330 -0
  2. package/node_modules/@sudocode-ai/cli/dist/cli/feedback-commands.d.ts +53 -0
  3. package/node_modules/@sudocode-ai/cli/dist/cli/feedback-commands.d.ts.map +1 -0
  4. package/node_modules/@sudocode-ai/cli/dist/cli/feedback-commands.js +339 -0
  5. package/node_modules/@sudocode-ai/cli/dist/cli/feedback-commands.js.map +1 -0
  6. package/node_modules/@sudocode-ai/cli/dist/cli/init-commands.d.ts +20 -0
  7. package/node_modules/@sudocode-ai/cli/dist/cli/init-commands.d.ts.map +1 -0
  8. package/node_modules/@sudocode-ai/cli/dist/cli/init-commands.js +145 -0
  9. package/node_modules/@sudocode-ai/cli/dist/cli/init-commands.js.map +1 -0
  10. package/node_modules/@sudocode-ai/cli/dist/cli/issue-commands.d.ts +46 -0
  11. package/node_modules/@sudocode-ai/cli/dist/cli/issue-commands.d.ts.map +1 -0
  12. package/node_modules/@sudocode-ai/cli/dist/cli/issue-commands.js +353 -0
  13. package/node_modules/@sudocode-ai/cli/dist/cli/issue-commands.js.map +1 -0
  14. package/node_modules/@sudocode-ai/cli/dist/cli/merge-commands.d.ts +42 -0
  15. package/node_modules/@sudocode-ai/cli/dist/cli/merge-commands.d.ts.map +1 -0
  16. package/node_modules/@sudocode-ai/cli/dist/cli/merge-commands.js +405 -0
  17. package/node_modules/@sudocode-ai/cli/dist/cli/merge-commands.js.map +1 -0
  18. package/node_modules/@sudocode-ai/cli/dist/cli/plugin-commands.d.ts +62 -0
  19. package/node_modules/@sudocode-ai/cli/dist/cli/plugin-commands.d.ts.map +1 -0
  20. package/node_modules/@sudocode-ai/cli/dist/cli/plugin-commands.js +595 -0
  21. package/node_modules/@sudocode-ai/cli/dist/cli/plugin-commands.js.map +1 -0
  22. package/node_modules/@sudocode-ai/cli/dist/cli/query-commands.d.ts +18 -0
  23. package/node_modules/@sudocode-ai/cli/dist/cli/query-commands.d.ts.map +1 -0
  24. package/node_modules/@sudocode-ai/cli/dist/cli/query-commands.js +61 -0
  25. package/node_modules/@sudocode-ai/cli/dist/cli/query-commands.js.map +1 -0
  26. package/node_modules/@sudocode-ai/cli/dist/cli/reference-commands.d.ts +22 -0
  27. package/node_modules/@sudocode-ai/cli/dist/cli/reference-commands.d.ts.map +1 -0
  28. package/node_modules/@sudocode-ai/cli/dist/cli/reference-commands.js +136 -0
  29. package/node_modules/@sudocode-ai/cli/dist/cli/reference-commands.js.map +1 -0
  30. package/node_modules/@sudocode-ai/cli/dist/cli/relationship-commands.d.ts +14 -0
  31. package/node_modules/@sudocode-ai/cli/dist/cli/relationship-commands.d.ts.map +1 -0
  32. package/node_modules/@sudocode-ai/cli/dist/cli/relationship-commands.js +83 -0
  33. package/node_modules/@sudocode-ai/cli/dist/cli/relationship-commands.js.map +1 -0
  34. package/node_modules/@sudocode-ai/cli/dist/cli/server-commands.d.ts +17 -0
  35. package/node_modules/@sudocode-ai/cli/dist/cli/server-commands.d.ts.map +1 -0
  36. package/node_modules/@sudocode-ai/cli/dist/cli/server-commands.js +123 -0
  37. package/node_modules/@sudocode-ai/cli/dist/cli/server-commands.js.map +1 -0
  38. package/node_modules/@sudocode-ai/cli/dist/cli/spec-commands.d.ts +38 -0
  39. package/node_modules/@sudocode-ai/cli/dist/cli/spec-commands.d.ts.map +1 -0
  40. package/node_modules/@sudocode-ai/cli/dist/cli/spec-commands.js +326 -0
  41. package/node_modules/@sudocode-ai/cli/dist/cli/spec-commands.js.map +1 -0
  42. package/node_modules/@sudocode-ai/cli/dist/cli/status-commands.d.ts +17 -0
  43. package/node_modules/@sudocode-ai/cli/dist/cli/status-commands.d.ts.map +1 -0
  44. package/node_modules/@sudocode-ai/cli/dist/cli/status-commands.js +131 -0
  45. package/node_modules/@sudocode-ai/cli/dist/cli/status-commands.js.map +1 -0
  46. package/node_modules/@sudocode-ai/cli/dist/cli/sync-commands.d.ts +24 -0
  47. package/node_modules/@sudocode-ai/cli/dist/cli/sync-commands.d.ts.map +1 -0
  48. package/node_modules/@sudocode-ai/cli/dist/cli/sync-commands.js +429 -0
  49. package/node_modules/@sudocode-ai/cli/dist/cli/sync-commands.js.map +1 -0
  50. package/node_modules/@sudocode-ai/cli/dist/cli/update-commands.d.ts +16 -0
  51. package/node_modules/@sudocode-ai/cli/dist/cli/update-commands.d.ts.map +1 -0
  52. package/node_modules/@sudocode-ai/cli/dist/cli/update-commands.js +160 -0
  53. package/node_modules/@sudocode-ai/cli/dist/cli/update-commands.js.map +1 -0
  54. package/node_modules/@sudocode-ai/cli/dist/cli.d.ts +6 -0
  55. package/node_modules/@sudocode-ai/cli/dist/cli.d.ts.map +1 -0
  56. package/node_modules/@sudocode-ai/cli/dist/cli.js +543 -0
  57. package/node_modules/@sudocode-ai/cli/dist/cli.js.map +1 -0
  58. package/node_modules/@sudocode-ai/cli/dist/config.d.ts +50 -0
  59. package/node_modules/@sudocode-ai/cli/dist/config.d.ts.map +1 -0
  60. package/node_modules/@sudocode-ai/cli/dist/config.js +76 -0
  61. package/node_modules/@sudocode-ai/cli/dist/config.js.map +1 -0
  62. package/node_modules/@sudocode-ai/cli/dist/db.d.ts +21 -0
  63. package/node_modules/@sudocode-ai/cli/dist/db.d.ts.map +1 -0
  64. package/node_modules/@sudocode-ai/cli/dist/db.js +55 -0
  65. package/node_modules/@sudocode-ai/cli/dist/db.js.map +1 -0
  66. package/node_modules/@sudocode-ai/cli/dist/export.d.ts +84 -0
  67. package/node_modules/@sudocode-ai/cli/dist/export.d.ts.map +1 -0
  68. package/node_modules/@sudocode-ai/cli/dist/export.js +265 -0
  69. package/node_modules/@sudocode-ai/cli/dist/export.js.map +1 -0
  70. package/node_modules/@sudocode-ai/cli/dist/filename-generator.d.ts +31 -0
  71. package/node_modules/@sudocode-ai/cli/dist/filename-generator.d.ts.map +1 -0
  72. package/node_modules/@sudocode-ai/cli/dist/filename-generator.js +103 -0
  73. package/node_modules/@sudocode-ai/cli/dist/filename-generator.js.map +1 -0
  74. package/node_modules/@sudocode-ai/cli/dist/id-generator.d.ts +63 -0
  75. package/node_modules/@sudocode-ai/cli/dist/id-generator.d.ts.map +1 -0
  76. package/node_modules/@sudocode-ai/cli/dist/id-generator.js +196 -0
  77. package/node_modules/@sudocode-ai/cli/dist/id-generator.js.map +1 -0
  78. package/node_modules/@sudocode-ai/cli/dist/import.d.ts +134 -0
  79. package/node_modules/@sudocode-ai/cli/dist/import.d.ts.map +1 -0
  80. package/node_modules/@sudocode-ai/cli/dist/import.js +751 -0
  81. package/node_modules/@sudocode-ai/cli/dist/import.js.map +1 -0
  82. package/node_modules/@sudocode-ai/cli/dist/index.d.ts +15 -0
  83. package/node_modules/@sudocode-ai/cli/dist/index.d.ts.map +1 -0
  84. package/node_modules/@sudocode-ai/cli/dist/index.js +15 -0
  85. package/node_modules/@sudocode-ai/cli/dist/index.js.map +1 -0
  86. package/node_modules/@sudocode-ai/cli/dist/integrations/base-provider.d.ts +108 -0
  87. package/node_modules/@sudocode-ai/cli/dist/integrations/base-provider.d.ts.map +1 -0
  88. package/node_modules/@sudocode-ai/cli/dist/integrations/base-provider.js +80 -0
  89. package/node_modules/@sudocode-ai/cli/dist/integrations/base-provider.js.map +1 -0
  90. package/node_modules/@sudocode-ai/cli/dist/integrations/config-resolver.d.ts +62 -0
  91. package/node_modules/@sudocode-ai/cli/dist/integrations/config-resolver.d.ts.map +1 -0
  92. package/node_modules/@sudocode-ai/cli/dist/integrations/config-resolver.js +69 -0
  93. package/node_modules/@sudocode-ai/cli/dist/integrations/config-resolver.js.map +1 -0
  94. package/node_modules/@sudocode-ai/cli/dist/integrations/config-validator.d.ts +75 -0
  95. package/node_modules/@sudocode-ai/cli/dist/integrations/config-validator.d.ts.map +1 -0
  96. package/node_modules/@sudocode-ai/cli/dist/integrations/config-validator.js +129 -0
  97. package/node_modules/@sudocode-ai/cli/dist/integrations/config-validator.js.map +1 -0
  98. package/node_modules/@sudocode-ai/cli/dist/integrations/index.d.ts +14 -0
  99. package/node_modules/@sudocode-ai/cli/dist/integrations/index.d.ts.map +1 -0
  100. package/node_modules/@sudocode-ai/cli/dist/integrations/index.js +20 -0
  101. package/node_modules/@sudocode-ai/cli/dist/integrations/index.js.map +1 -0
  102. package/node_modules/@sudocode-ai/cli/dist/integrations/plugin-loader.d.ts +77 -0
  103. package/node_modules/@sudocode-ai/cli/dist/integrations/plugin-loader.d.ts.map +1 -0
  104. package/node_modules/@sudocode-ai/cli/dist/integrations/plugin-loader.js +265 -0
  105. package/node_modules/@sudocode-ai/cli/dist/integrations/plugin-loader.js.map +1 -0
  106. package/node_modules/@sudocode-ai/cli/dist/integrations/registry.d.ts +67 -0
  107. package/node_modules/@sudocode-ai/cli/dist/integrations/registry.d.ts.map +1 -0
  108. package/node_modules/@sudocode-ai/cli/dist/integrations/registry.js +77 -0
  109. package/node_modules/@sudocode-ai/cli/dist/integrations/registry.js.map +1 -0
  110. package/node_modules/@sudocode-ai/cli/dist/integrations/sync-coordinator.d.ts +191 -0
  111. package/node_modules/@sudocode-ai/cli/dist/integrations/sync-coordinator.d.ts.map +1 -0
  112. package/node_modules/@sudocode-ai/cli/dist/integrations/sync-coordinator.js +798 -0
  113. package/node_modules/@sudocode-ai/cli/dist/integrations/sync-coordinator.js.map +1 -0
  114. package/node_modules/@sudocode-ai/cli/dist/integrations/types.d.ts +142 -0
  115. package/node_modules/@sudocode-ai/cli/dist/integrations/types.d.ts.map +1 -0
  116. package/node_modules/@sudocode-ai/cli/dist/integrations/types.js +6 -0
  117. package/node_modules/@sudocode-ai/cli/dist/integrations/types.js.map +1 -0
  118. package/node_modules/@sudocode-ai/cli/dist/integrations/utils/conflict-resolver.d.ts +79 -0
  119. package/node_modules/@sudocode-ai/cli/dist/integrations/utils/conflict-resolver.d.ts.map +1 -0
  120. package/node_modules/@sudocode-ai/cli/dist/integrations/utils/conflict-resolver.js +106 -0
  121. package/node_modules/@sudocode-ai/cli/dist/integrations/utils/conflict-resolver.js.map +1 -0
  122. package/node_modules/@sudocode-ai/cli/dist/jsonl.d.ts +69 -0
  123. package/node_modules/@sudocode-ai/cli/dist/jsonl.d.ts.map +1 -0
  124. package/node_modules/@sudocode-ai/cli/dist/jsonl.js +333 -0
  125. package/node_modules/@sudocode-ai/cli/dist/jsonl.js.map +1 -0
  126. package/node_modules/@sudocode-ai/cli/dist/markdown.d.ts +146 -0
  127. package/node_modules/@sudocode-ai/cli/dist/markdown.d.ts.map +1 -0
  128. package/node_modules/@sudocode-ai/cli/dist/markdown.js +329 -0
  129. package/node_modules/@sudocode-ai/cli/dist/markdown.js.map +1 -0
  130. package/node_modules/@sudocode-ai/cli/dist/merge-resolver.d.ts +85 -0
  131. package/node_modules/@sudocode-ai/cli/dist/merge-resolver.d.ts.map +1 -0
  132. package/node_modules/@sudocode-ai/cli/dist/merge-resolver.js +301 -0
  133. package/node_modules/@sudocode-ai/cli/dist/merge-resolver.js.map +1 -0
  134. package/node_modules/@sudocode-ai/cli/dist/operations/events.d.ts +53 -0
  135. package/node_modules/@sudocode-ai/cli/dist/operations/events.d.ts.map +1 -0
  136. package/node_modules/@sudocode-ai/cli/dist/operations/events.js +108 -0
  137. package/node_modules/@sudocode-ai/cli/dist/operations/events.js.map +1 -0
  138. package/node_modules/@sudocode-ai/cli/dist/operations/external-links.d.ts +147 -0
  139. package/node_modules/@sudocode-ai/cli/dist/operations/external-links.d.ts.map +1 -0
  140. package/node_modules/@sudocode-ai/cli/dist/operations/external-links.js +411 -0
  141. package/node_modules/@sudocode-ai/cli/dist/operations/external-links.js.map +1 -0
  142. package/node_modules/@sudocode-ai/cli/dist/operations/feedback-anchors.d.ts +92 -0
  143. package/node_modules/@sudocode-ai/cli/dist/operations/feedback-anchors.d.ts.map +1 -0
  144. package/node_modules/@sudocode-ai/cli/dist/operations/feedback-anchors.js +444 -0
  145. package/node_modules/@sudocode-ai/cli/dist/operations/feedback-anchors.js.map +1 -0
  146. package/node_modules/@sudocode-ai/cli/dist/operations/feedback.d.ts +94 -0
  147. package/node_modules/@sudocode-ai/cli/dist/operations/feedback.d.ts.map +1 -0
  148. package/node_modules/@sudocode-ai/cli/dist/operations/feedback.js +278 -0
  149. package/node_modules/@sudocode-ai/cli/dist/operations/feedback.js.map +1 -0
  150. package/node_modules/@sudocode-ai/cli/dist/operations/index.d.ts +11 -0
  151. package/node_modules/@sudocode-ai/cli/dist/operations/index.d.ts.map +1 -0
  152. package/node_modules/@sudocode-ai/cli/dist/operations/index.js +11 -0
  153. package/node_modules/@sudocode-ai/cli/dist/operations/index.js.map +1 -0
  154. package/node_modules/@sudocode-ai/cli/dist/operations/issues.d.ts +88 -0
  155. package/node_modules/@sudocode-ai/cli/dist/operations/issues.d.ts.map +1 -0
  156. package/node_modules/@sudocode-ai/cli/dist/operations/issues.js +474 -0
  157. package/node_modules/@sudocode-ai/cli/dist/operations/issues.js.map +1 -0
  158. package/node_modules/@sudocode-ai/cli/dist/operations/references.d.ts +34 -0
  159. package/node_modules/@sudocode-ai/cli/dist/operations/references.d.ts.map +1 -0
  160. package/node_modules/@sudocode-ai/cli/dist/operations/references.js +117 -0
  161. package/node_modules/@sudocode-ai/cli/dist/operations/references.js.map +1 -0
  162. package/node_modules/@sudocode-ai/cli/dist/operations/relationships.d.ts +64 -0
  163. package/node_modules/@sudocode-ai/cli/dist/operations/relationships.d.ts.map +1 -0
  164. package/node_modules/@sudocode-ai/cli/dist/operations/relationships.js +281 -0
  165. package/node_modules/@sudocode-ai/cli/dist/operations/relationships.js.map +1 -0
  166. package/node_modules/@sudocode-ai/cli/dist/operations/specs.d.ts +69 -0
  167. package/node_modules/@sudocode-ai/cli/dist/operations/specs.d.ts.map +1 -0
  168. package/node_modules/@sudocode-ai/cli/dist/operations/specs.js +330 -0
  169. package/node_modules/@sudocode-ai/cli/dist/operations/specs.js.map +1 -0
  170. package/node_modules/@sudocode-ai/cli/dist/operations/tags.d.ts +42 -0
  171. package/node_modules/@sudocode-ai/cli/dist/operations/tags.d.ts.map +1 -0
  172. package/node_modules/@sudocode-ai/cli/dist/operations/tags.js +127 -0
  173. package/node_modules/@sudocode-ai/cli/dist/operations/tags.js.map +1 -0
  174. package/node_modules/@sudocode-ai/cli/dist/operations/transactions.d.ts +41 -0
  175. package/node_modules/@sudocode-ai/cli/dist/operations/transactions.d.ts.map +1 -0
  176. package/node_modules/@sudocode-ai/cli/dist/operations/transactions.js +111 -0
  177. package/node_modules/@sudocode-ai/cli/dist/operations/transactions.js.map +1 -0
  178. package/node_modules/@sudocode-ai/cli/dist/sync.d.ts +47 -0
  179. package/node_modules/@sudocode-ai/cli/dist/sync.d.ts.map +1 -0
  180. package/node_modules/@sudocode-ai/cli/dist/sync.js +464 -0
  181. package/node_modules/@sudocode-ai/cli/dist/sync.js.map +1 -0
  182. package/node_modules/@sudocode-ai/cli/dist/test-schema.d.ts +5 -0
  183. package/node_modules/@sudocode-ai/cli/dist/test-schema.d.ts.map +1 -0
  184. package/node_modules/@sudocode-ai/cli/dist/test-schema.js +46 -0
  185. package/node_modules/@sudocode-ai/cli/dist/test-schema.js.map +1 -0
  186. package/node_modules/@sudocode-ai/cli/dist/types.d.ts +7 -0
  187. package/node_modules/@sudocode-ai/cli/dist/types.d.ts.map +1 -0
  188. package/node_modules/@sudocode-ai/cli/dist/types.js +7 -0
  189. package/node_modules/@sudocode-ai/cli/dist/types.js.map +1 -0
  190. package/node_modules/@sudocode-ai/cli/dist/update-checker.d.ts +33 -0
  191. package/node_modules/@sudocode-ai/cli/dist/update-checker.d.ts.map +1 -0
  192. package/node_modules/@sudocode-ai/cli/dist/update-checker.js +193 -0
  193. package/node_modules/@sudocode-ai/cli/dist/update-checker.js.map +1 -0
  194. package/node_modules/@sudocode-ai/cli/dist/validation.d.ts +11 -0
  195. package/node_modules/@sudocode-ai/cli/dist/validation.d.ts.map +1 -0
  196. package/node_modules/@sudocode-ai/cli/dist/validation.js +58 -0
  197. package/node_modules/@sudocode-ai/cli/dist/validation.js.map +1 -0
  198. package/node_modules/@sudocode-ai/cli/dist/version.d.ts +12 -0
  199. package/node_modules/@sudocode-ai/cli/dist/version.d.ts.map +1 -0
  200. package/node_modules/@sudocode-ai/cli/dist/version.js +23 -0
  201. package/node_modules/@sudocode-ai/cli/dist/version.js.map +1 -0
  202. package/node_modules/@sudocode-ai/cli/dist/watcher.d.ts +69 -0
  203. package/node_modules/@sudocode-ai/cli/dist/watcher.d.ts.map +1 -0
  204. package/node_modules/@sudocode-ai/cli/dist/watcher.js +783 -0
  205. package/node_modules/@sudocode-ai/cli/dist/watcher.js.map +1 -0
  206. package/node_modules/@sudocode-ai/cli/package.json +73 -0
  207. package/node_modules/@sudocode-ai/integration-beads/package.json +44 -0
  208. package/node_modules/@sudocode-ai/integration-github/package.json +41 -0
  209. package/node_modules/@sudocode-ai/integration-openspec/package.json +43 -0
  210. package/node_modules/@sudocode-ai/integration-speckit/package.json +42 -0
  211. package/node_modules/@sudocode-ai/local-server/README.md +25 -0
  212. package/node_modules/@sudocode-ai/local-server/dist/cli.d.ts +7 -0
  213. package/node_modules/@sudocode-ai/local-server/dist/cli.d.ts.map +1 -0
  214. package/node_modules/@sudocode-ai/local-server/dist/cli.js +7 -0
  215. package/node_modules/@sudocode-ai/local-server/dist/cli.js.map +1 -0
  216. package/node_modules/@sudocode-ai/local-server/dist/errors/agent-errors.d.ts +43 -0
  217. package/node_modules/@sudocode-ai/local-server/dist/errors/agent-errors.d.ts.map +1 -0
  218. package/node_modules/@sudocode-ai/local-server/dist/errors/agent-errors.js +69 -0
  219. package/node_modules/@sudocode-ai/local-server/dist/errors/agent-errors.js.map +1 -0
  220. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/claude-adapter.d.ts +63 -0
  221. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/claude-adapter.d.ts.map +1 -0
  222. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/claude-adapter.js +83 -0
  223. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/claude-adapter.js.map +1 -0
  224. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-adapter.d.ts +67 -0
  225. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-adapter.d.ts.map +1 -0
  226. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-adapter.js +183 -0
  227. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-adapter.js.map +1 -0
  228. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-config-builder.d.ts +30 -0
  229. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-config-builder.d.ts.map +1 -0
  230. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-config-builder.js +110 -0
  231. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/codex-config-builder.js.map +1 -0
  232. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-adapter.d.ts +94 -0
  233. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-adapter.d.ts.map +1 -0
  234. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-adapter.js +163 -0
  235. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-adapter.js.map +1 -0
  236. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-config-builder.d.ts +48 -0
  237. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-config-builder.d.ts.map +1 -0
  238. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-config-builder.js +125 -0
  239. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/copilot-config-builder.js.map +1 -0
  240. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-adapter.d.ts +66 -0
  241. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-adapter.d.ts.map +1 -0
  242. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-adapter.js +121 -0
  243. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-adapter.js.map +1 -0
  244. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-config-builder.d.ts +29 -0
  245. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-config-builder.d.ts.map +1 -0
  246. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-config-builder.js +49 -0
  247. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/cursor-config-builder.js.map +1 -0
  248. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-presets.d.ts +102 -0
  249. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-presets.d.ts.map +1 -0
  250. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-presets.js +205 -0
  251. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-presets.js.map +1 -0
  252. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-utils.d.ts +95 -0
  253. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-utils.d.ts.map +1 -0
  254. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-utils.js +163 -0
  255. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/config-utils.js.map +1 -0
  256. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/index.d.ts +8 -0
  257. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/index.d.ts.map +1 -0
  258. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/index.js +8 -0
  259. package/node_modules/@sudocode-ai/local-server/dist/execution/adapters/shared/index.js.map +1 -0
  260. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/agent-executor-wrapper.d.ts +154 -0
  261. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/agent-executor-wrapper.d.ts.map +1 -0
  262. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/agent-executor-wrapper.js +725 -0
  263. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/agent-executor-wrapper.js.map +1 -0
  264. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/executor-factory.d.ts +95 -0
  265. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/executor-factory.d.ts.map +1 -0
  266. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/executor-factory.js +128 -0
  267. package/node_modules/@sudocode-ai/local-server/dist/execution/executors/executor-factory.js.map +1 -0
  268. package/node_modules/@sudocode-ai/local-server/dist/execution/output/ag-ui-adapter.d.ts +174 -0
  269. package/node_modules/@sudocode-ai/local-server/dist/execution/output/ag-ui-adapter.d.ts.map +1 -0
  270. package/node_modules/@sudocode-ai/local-server/dist/execution/output/ag-ui-adapter.js +436 -0
  271. package/node_modules/@sudocode-ai/local-server/dist/execution/output/ag-ui-adapter.js.map +1 -0
  272. package/node_modules/@sudocode-ai/local-server/dist/execution/output/claude-to-ag-ui.d.ts +90 -0
  273. package/node_modules/@sudocode-ai/local-server/dist/execution/output/claude-to-ag-ui.d.ts.map +1 -0
  274. package/node_modules/@sudocode-ai/local-server/dist/execution/output/claude-to-ag-ui.js +153 -0
  275. package/node_modules/@sudocode-ai/local-server/dist/execution/output/claude-to-ag-ui.js.map +1 -0
  276. package/node_modules/@sudocode-ai/local-server/dist/execution/output/index.d.ts +15 -0
  277. package/node_modules/@sudocode-ai/local-server/dist/execution/output/index.d.ts.map +1 -0
  278. package/node_modules/@sudocode-ai/local-server/dist/execution/output/index.js +13 -0
  279. package/node_modules/@sudocode-ai/local-server/dist/execution/output/index.js.map +1 -0
  280. package/node_modules/@sudocode-ai/local-server/dist/execution/output/normalized-to-ag-ui-adapter.d.ts +108 -0
  281. package/node_modules/@sudocode-ai/local-server/dist/execution/output/normalized-to-ag-ui-adapter.d.ts.map +1 -0
  282. package/node_modules/@sudocode-ai/local-server/dist/execution/output/normalized-to-ag-ui-adapter.js +321 -0
  283. package/node_modules/@sudocode-ai/local-server/dist/execution/output/normalized-to-ag-ui-adapter.js.map +1 -0
  284. package/node_modules/@sudocode-ai/local-server/dist/execution/output/types.d.ts +421 -0
  285. package/node_modules/@sudocode-ai/local-server/dist/execution/output/types.d.ts.map +1 -0
  286. package/node_modules/@sudocode-ai/local-server/dist/execution/output/types.js +22 -0
  287. package/node_modules/@sudocode-ai/local-server/dist/execution/output/types.js.map +1 -0
  288. package/node_modules/@sudocode-ai/local-server/dist/execution/process/builders/claude.d.ts +53 -0
  289. package/node_modules/@sudocode-ai/local-server/dist/execution/process/builders/claude.d.ts.map +1 -0
  290. package/node_modules/@sudocode-ai/local-server/dist/execution/process/builders/claude.js +225 -0
  291. package/node_modules/@sudocode-ai/local-server/dist/execution/process/builders/claude.js.map +1 -0
  292. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/event-buffer.d.ts +119 -0
  293. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/event-buffer.d.ts.map +1 -0
  294. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/event-buffer.js +208 -0
  295. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/event-buffer.js.map +1 -0
  296. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/index.d.ts +10 -0
  297. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/index.d.ts.map +1 -0
  298. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/index.js +10 -0
  299. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/index.js.map +1 -0
  300. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/ipc-transport-manager.d.ts +74 -0
  301. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/ipc-transport-manager.d.ts.map +1 -0
  302. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/ipc-transport-manager.js +104 -0
  303. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/ipc-transport-manager.js.map +1 -0
  304. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/sse-transport.d.ts +146 -0
  305. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/sse-transport.d.ts.map +1 -0
  306. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/sse-transport.js +282 -0
  307. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/sse-transport.js.map +1 -0
  308. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/transport-manager.d.ts +176 -0
  309. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/transport-manager.d.ts.map +1 -0
  310. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/transport-manager.js +234 -0
  311. package/node_modules/@sudocode-ai/local-server/dist/execution/transport/transport-manager.js.map +1 -0
  312. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/config.d.ts +74 -0
  313. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/config.d.ts.map +1 -0
  314. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/config.js +280 -0
  315. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/config.js.map +1 -0
  316. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/conflict-detector.d.ts +85 -0
  317. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/conflict-detector.d.ts.map +1 -0
  318. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/conflict-detector.js +129 -0
  319. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/conflict-detector.js.map +1 -0
  320. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-cli.d.ts +208 -0
  321. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-cli.d.ts.map +1 -0
  322. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-cli.js +280 -0
  323. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-cli.js.map +1 -0
  324. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-sync-cli.d.ts +225 -0
  325. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-sync-cli.d.ts.map +1 -0
  326. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-sync-cli.js +464 -0
  327. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/git-sync-cli.js.map +1 -0
  328. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/index.d.ts +16 -0
  329. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/index.d.ts.map +1 -0
  330. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/index.js +15 -0
  331. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/index.js.map +1 -0
  332. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/manager.d.ts +221 -0
  333. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/manager.d.ts.map +1 -0
  334. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/manager.js +508 -0
  335. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/manager.js.map +1 -0
  336. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/types.d.ts +90 -0
  337. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/types.d.ts.map +1 -0
  338. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/types.js +42 -0
  339. package/node_modules/@sudocode-ai/local-server/dist/execution/worktree/types.js.map +1 -0
  340. package/node_modules/@sudocode-ai/local-server/dist/index.d.ts +6 -0
  341. package/node_modules/@sudocode-ai/local-server/dist/index.d.ts.map +1 -0
  342. package/node_modules/@sudocode-ai/local-server/dist/index.js +371 -0
  343. package/node_modules/@sudocode-ai/local-server/dist/index.js.map +1 -0
  344. package/node_modules/@sudocode-ai/local-server/dist/middleware/project-context.d.ts +37 -0
  345. package/node_modules/@sudocode-ai/local-server/dist/middleware/project-context.d.ts.map +1 -0
  346. package/node_modules/@sudocode-ai/local-server/dist/middleware/project-context.js +91 -0
  347. package/node_modules/@sudocode-ai/local-server/dist/middleware/project-context.js.map +1 -0
  348. package/node_modules/@sudocode-ai/local-server/dist/public/assets/index-D4AKx6EO.css +1 -0
  349. package/node_modules/@sudocode-ai/local-server/dist/public/assets/index-DorQqwGV.js +927 -0
  350. package/node_modules/@sudocode-ai/local-server/dist/public/assets/index-DorQqwGV.js.map +1 -0
  351. package/node_modules/@sudocode-ai/local-server/dist/public/assets/react-vendor-DoNwlLhy.js +60 -0
  352. package/node_modules/@sudocode-ai/local-server/dist/public/assets/react-vendor-DoNwlLhy.js.map +1 -0
  353. package/node_modules/@sudocode-ai/local-server/dist/public/assets/ui-vendor-DlxvBun1.js +54 -0
  354. package/node_modules/@sudocode-ai/local-server/dist/public/assets/ui-vendor-DlxvBun1.js.map +1 -0
  355. package/node_modules/@sudocode-ai/local-server/dist/public/favicon.ico +0 -0
  356. package/node_modules/@sudocode-ai/local-server/dist/public/index.html +16 -0
  357. package/node_modules/@sudocode-ai/local-server/dist/public/logo.png +0 -0
  358. package/node_modules/@sudocode-ai/local-server/dist/routes/agents.d.ts +3 -0
  359. package/node_modules/@sudocode-ai/local-server/dist/routes/agents.d.ts.map +1 -0
  360. package/node_modules/@sudocode-ai/local-server/dist/routes/agents.js +62 -0
  361. package/node_modules/@sudocode-ai/local-server/dist/routes/agents.js.map +1 -0
  362. package/node_modules/@sudocode-ai/local-server/dist/routes/config.d.ts +3 -0
  363. package/node_modules/@sudocode-ai/local-server/dist/routes/config.d.ts.map +1 -0
  364. package/node_modules/@sudocode-ai/local-server/dist/routes/config.js +116 -0
  365. package/node_modules/@sudocode-ai/local-server/dist/routes/config.js.map +1 -0
  366. package/node_modules/@sudocode-ai/local-server/dist/routes/editors.d.ts +15 -0
  367. package/node_modules/@sudocode-ai/local-server/dist/routes/editors.d.ts.map +1 -0
  368. package/node_modules/@sudocode-ai/local-server/dist/routes/editors.js +98 -0
  369. package/node_modules/@sudocode-ai/local-server/dist/routes/editors.js.map +1 -0
  370. package/node_modules/@sudocode-ai/local-server/dist/routes/executions-stream.d.ts +27 -0
  371. package/node_modules/@sudocode-ai/local-server/dist/routes/executions-stream.d.ts.map +1 -0
  372. package/node_modules/@sudocode-ai/local-server/dist/routes/executions-stream.js +59 -0
  373. package/node_modules/@sudocode-ai/local-server/dist/routes/executions-stream.js.map +1 -0
  374. package/node_modules/@sudocode-ai/local-server/dist/routes/executions.d.ts +18 -0
  375. package/node_modules/@sudocode-ai/local-server/dist/routes/executions.d.ts.map +1 -0
  376. package/node_modules/@sudocode-ai/local-server/dist/routes/executions.js +1169 -0
  377. package/node_modules/@sudocode-ai/local-server/dist/routes/executions.js.map +1 -0
  378. package/node_modules/@sudocode-ai/local-server/dist/routes/feedback.d.ts +8 -0
  379. package/node_modules/@sudocode-ai/local-server/dist/routes/feedback.d.ts.map +1 -0
  380. package/node_modules/@sudocode-ai/local-server/dist/routes/feedback.js +340 -0
  381. package/node_modules/@sudocode-ai/local-server/dist/routes/feedback.js.map +1 -0
  382. package/node_modules/@sudocode-ai/local-server/dist/routes/files.d.ts +18 -0
  383. package/node_modules/@sudocode-ai/local-server/dist/routes/files.d.ts.map +1 -0
  384. package/node_modules/@sudocode-ai/local-server/dist/routes/files.js +89 -0
  385. package/node_modules/@sudocode-ai/local-server/dist/routes/files.js.map +1 -0
  386. package/node_modules/@sudocode-ai/local-server/dist/routes/import.d.ts +142 -0
  387. package/node_modules/@sudocode-ai/local-server/dist/routes/import.d.ts.map +1 -0
  388. package/node_modules/@sudocode-ai/local-server/dist/routes/import.js +896 -0
  389. package/node_modules/@sudocode-ai/local-server/dist/routes/import.js.map +1 -0
  390. package/node_modules/@sudocode-ai/local-server/dist/routes/issues.d.ts +8 -0
  391. package/node_modules/@sudocode-ai/local-server/dist/routes/issues.d.ts.map +1 -0
  392. package/node_modules/@sudocode-ai/local-server/dist/routes/issues.js +419 -0
  393. package/node_modules/@sudocode-ai/local-server/dist/routes/issues.js.map +1 -0
  394. package/node_modules/@sudocode-ai/local-server/dist/routes/plugins.d.ts +34 -0
  395. package/node_modules/@sudocode-ai/local-server/dist/routes/plugins.d.ts.map +1 -0
  396. package/node_modules/@sudocode-ai/local-server/dist/routes/plugins.js +602 -0
  397. package/node_modules/@sudocode-ai/local-server/dist/routes/plugins.js.map +1 -0
  398. package/node_modules/@sudocode-ai/local-server/dist/routes/projects.d.ts +11 -0
  399. package/node_modules/@sudocode-ai/local-server/dist/routes/projects.d.ts.map +1 -0
  400. package/node_modules/@sudocode-ai/local-server/dist/routes/projects.js +536 -0
  401. package/node_modules/@sudocode-ai/local-server/dist/routes/projects.js.map +1 -0
  402. package/node_modules/@sudocode-ai/local-server/dist/routes/relationships.d.ts +8 -0
  403. package/node_modules/@sudocode-ai/local-server/dist/routes/relationships.d.ts.map +1 -0
  404. package/node_modules/@sudocode-ai/local-server/dist/routes/relationships.js +310 -0
  405. package/node_modules/@sudocode-ai/local-server/dist/routes/relationships.js.map +1 -0
  406. package/node_modules/@sudocode-ai/local-server/dist/routes/repo-info.d.ts +3 -0
  407. package/node_modules/@sudocode-ai/local-server/dist/routes/repo-info.d.ts.map +1 -0
  408. package/node_modules/@sudocode-ai/local-server/dist/routes/repo-info.js +203 -0
  409. package/node_modules/@sudocode-ai/local-server/dist/routes/repo-info.js.map +1 -0
  410. package/node_modules/@sudocode-ai/local-server/dist/routes/specs.d.ts +8 -0
  411. package/node_modules/@sudocode-ai/local-server/dist/routes/specs.d.ts.map +1 -0
  412. package/node_modules/@sudocode-ai/local-server/dist/routes/specs.js +414 -0
  413. package/node_modules/@sudocode-ai/local-server/dist/routes/specs.js.map +1 -0
  414. package/node_modules/@sudocode-ai/local-server/dist/routes/update.d.ts +7 -0
  415. package/node_modules/@sudocode-ai/local-server/dist/routes/update.d.ts.map +1 -0
  416. package/node_modules/@sudocode-ai/local-server/dist/routes/update.js +194 -0
  417. package/node_modules/@sudocode-ai/local-server/dist/routes/update.js.map +1 -0
  418. package/node_modules/@sudocode-ai/local-server/dist/routes/version.d.ts +3 -0
  419. package/node_modules/@sudocode-ai/local-server/dist/routes/version.d.ts.map +1 -0
  420. package/node_modules/@sudocode-ai/local-server/dist/routes/version.js +25 -0
  421. package/node_modules/@sudocode-ai/local-server/dist/routes/version.js.map +1 -0
  422. package/node_modules/@sudocode-ai/local-server/dist/routes/workflows.d.ts +8 -0
  423. package/node_modules/@sudocode-ai/local-server/dist/routes/workflows.d.ts.map +1 -0
  424. package/node_modules/@sudocode-ai/local-server/dist/routes/workflows.js +1729 -0
  425. package/node_modules/@sudocode-ai/local-server/dist/routes/workflows.js.map +1 -0
  426. package/node_modules/@sudocode-ai/local-server/dist/services/agent-registry.d.ts +140 -0
  427. package/node_modules/@sudocode-ai/local-server/dist/services/agent-registry.d.ts.map +1 -0
  428. package/node_modules/@sudocode-ai/local-server/dist/services/agent-registry.js +272 -0
  429. package/node_modules/@sudocode-ai/local-server/dist/services/agent-registry.js.map +1 -0
  430. package/node_modules/@sudocode-ai/local-server/dist/services/db.d.ts +33 -0
  431. package/node_modules/@sudocode-ai/local-server/dist/services/db.d.ts.map +1 -0
  432. package/node_modules/@sudocode-ai/local-server/dist/services/db.js +90 -0
  433. package/node_modules/@sudocode-ai/local-server/dist/services/db.js.map +1 -0
  434. package/node_modules/@sudocode-ai/local-server/dist/services/editor-service.d.ts +57 -0
  435. package/node_modules/@sudocode-ai/local-server/dist/services/editor-service.d.ts.map +1 -0
  436. package/node_modules/@sudocode-ai/local-server/dist/services/editor-service.js +204 -0
  437. package/node_modules/@sudocode-ai/local-server/dist/services/editor-service.js.map +1 -0
  438. package/node_modules/@sudocode-ai/local-server/dist/services/execution-changes-service.d.ts +110 -0
  439. package/node_modules/@sudocode-ai/local-server/dist/services/execution-changes-service.d.ts.map +1 -0
  440. package/node_modules/@sudocode-ai/local-server/dist/services/execution-changes-service.js +710 -0
  441. package/node_modules/@sudocode-ai/local-server/dist/services/execution-changes-service.js.map +1 -0
  442. package/node_modules/@sudocode-ai/local-server/dist/services/execution-event-callbacks.d.ts +73 -0
  443. package/node_modules/@sudocode-ai/local-server/dist/services/execution-event-callbacks.d.ts.map +1 -0
  444. package/node_modules/@sudocode-ai/local-server/dist/services/execution-event-callbacks.js +82 -0
  445. package/node_modules/@sudocode-ai/local-server/dist/services/execution-event-callbacks.js.map +1 -0
  446. package/node_modules/@sudocode-ai/local-server/dist/services/execution-lifecycle.d.ts +145 -0
  447. package/node_modules/@sudocode-ai/local-server/dist/services/execution-lifecycle.d.ts.map +1 -0
  448. package/node_modules/@sudocode-ai/local-server/dist/services/execution-lifecycle.js +392 -0
  449. package/node_modules/@sudocode-ai/local-server/dist/services/execution-lifecycle.js.map +1 -0
  450. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-cleanup.d.ts +88 -0
  451. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-cleanup.d.ts.map +1 -0
  452. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-cleanup.js +137 -0
  453. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-cleanup.js.map +1 -0
  454. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-store.d.ts +252 -0
  455. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-store.d.ts.map +1 -0
  456. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-store.js +379 -0
  457. package/node_modules/@sudocode-ai/local-server/dist/services/execution-logs-store.js.map +1 -0
  458. package/node_modules/@sudocode-ai/local-server/dist/services/execution-service.d.ts +280 -0
  459. package/node_modules/@sudocode-ai/local-server/dist/services/execution-service.d.ts.map +1 -0
  460. package/node_modules/@sudocode-ai/local-server/dist/services/execution-service.js +1240 -0
  461. package/node_modules/@sudocode-ai/local-server/dist/services/execution-service.js.map +1 -0
  462. package/node_modules/@sudocode-ai/local-server/dist/services/execution-worker-pool.d.ts +116 -0
  463. package/node_modules/@sudocode-ai/local-server/dist/services/execution-worker-pool.d.ts.map +1 -0
  464. package/node_modules/@sudocode-ai/local-server/dist/services/execution-worker-pool.js +326 -0
  465. package/node_modules/@sudocode-ai/local-server/dist/services/execution-worker-pool.js.map +1 -0
  466. package/node_modules/@sudocode-ai/local-server/dist/services/executions.d.ts +63 -0
  467. package/node_modules/@sudocode-ai/local-server/dist/services/executions.d.ts.map +1 -0
  468. package/node_modules/@sudocode-ai/local-server/dist/services/executions.js +177 -0
  469. package/node_modules/@sudocode-ai/local-server/dist/services/executions.js.map +1 -0
  470. package/node_modules/@sudocode-ai/local-server/dist/services/export.d.ts +32 -0
  471. package/node_modules/@sudocode-ai/local-server/dist/services/export.d.ts.map +1 -0
  472. package/node_modules/@sudocode-ai/local-server/dist/services/export.js +114 -0
  473. package/node_modules/@sudocode-ai/local-server/dist/services/export.js.map +1 -0
  474. package/node_modules/@sudocode-ai/local-server/dist/services/external-refresh-service.d.ts +104 -0
  475. package/node_modules/@sudocode-ai/local-server/dist/services/external-refresh-service.d.ts.map +1 -0
  476. package/node_modules/@sudocode-ai/local-server/dist/services/external-refresh-service.js +520 -0
  477. package/node_modules/@sudocode-ai/local-server/dist/services/external-refresh-service.js.map +1 -0
  478. package/node_modules/@sudocode-ai/local-server/dist/services/feedback.d.ts +56 -0
  479. package/node_modules/@sudocode-ai/local-server/dist/services/feedback.d.ts.map +1 -0
  480. package/node_modules/@sudocode-ai/local-server/dist/services/feedback.js +78 -0
  481. package/node_modules/@sudocode-ai/local-server/dist/services/feedback.js.map +1 -0
  482. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/git-ls-files-strategy.d.ts +72 -0
  483. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/git-ls-files-strategy.d.ts.map +1 -0
  484. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/git-ls-files-strategy.js +176 -0
  485. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/git-ls-files-strategy.js.map +1 -0
  486. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/index.d.ts +9 -0
  487. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/index.d.ts.map +1 -0
  488. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/index.js +10 -0
  489. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/index.js.map +1 -0
  490. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/registry.d.ts +97 -0
  491. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/registry.d.ts.map +1 -0
  492. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/registry.js +140 -0
  493. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/registry.js.map +1 -0
  494. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/strategy.d.ts +58 -0
  495. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/strategy.d.ts.map +1 -0
  496. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/strategy.js +8 -0
  497. package/node_modules/@sudocode-ai/local-server/dist/services/file-search/strategy.js.map +1 -0
  498. package/node_modules/@sudocode-ai/local-server/dist/services/integration-sync-service.d.ts +185 -0
  499. package/node_modules/@sudocode-ai/local-server/dist/services/integration-sync-service.d.ts.map +1 -0
  500. package/node_modules/@sudocode-ai/local-server/dist/services/integration-sync-service.js +428 -0
  501. package/node_modules/@sudocode-ai/local-server/dist/services/integration-sync-service.js.map +1 -0
  502. package/node_modules/@sudocode-ai/local-server/dist/services/issues.d.ts +27 -0
  503. package/node_modules/@sudocode-ai/local-server/dist/services/issues.d.ts.map +1 -0
  504. package/node_modules/@sudocode-ai/local-server/dist/services/issues.js +35 -0
  505. package/node_modules/@sudocode-ai/local-server/dist/services/issues.js.map +1 -0
  506. package/node_modules/@sudocode-ai/local-server/dist/services/project-context.d.ts +97 -0
  507. package/node_modules/@sudocode-ai/local-server/dist/services/project-context.d.ts.map +1 -0
  508. package/node_modules/@sudocode-ai/local-server/dist/services/project-context.js +170 -0
  509. package/node_modules/@sudocode-ai/local-server/dist/services/project-context.js.map +1 -0
  510. package/node_modules/@sudocode-ai/local-server/dist/services/project-manager.d.ts +102 -0
  511. package/node_modules/@sudocode-ai/local-server/dist/services/project-manager.d.ts.map +1 -0
  512. package/node_modules/@sudocode-ai/local-server/dist/services/project-manager.js +502 -0
  513. package/node_modules/@sudocode-ai/local-server/dist/services/project-manager.js.map +1 -0
  514. package/node_modules/@sudocode-ai/local-server/dist/services/project-registry.d.ts +98 -0
  515. package/node_modules/@sudocode-ai/local-server/dist/services/project-registry.d.ts.map +1 -0
  516. package/node_modules/@sudocode-ai/local-server/dist/services/project-registry.js +289 -0
  517. package/node_modules/@sudocode-ai/local-server/dist/services/project-registry.js.map +1 -0
  518. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-resolver.d.ts +97 -0
  519. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-resolver.d.ts.map +1 -0
  520. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-resolver.js +377 -0
  521. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-resolver.js.map +1 -0
  522. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-template-engine.d.ts +108 -0
  523. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-template-engine.d.ts.map +1 -0
  524. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-template-engine.js +212 -0
  525. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-template-engine.js.map +1 -0
  526. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-templates.d.ts +97 -0
  527. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-templates.d.ts.map +1 -0
  528. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-templates.js +236 -0
  529. package/node_modules/@sudocode-ai/local-server/dist/services/prompt-templates.js.map +1 -0
  530. package/node_modules/@sudocode-ai/local-server/dist/services/relationships.d.ts +35 -0
  531. package/node_modules/@sudocode-ai/local-server/dist/services/relationships.d.ts.map +1 -0
  532. package/node_modules/@sudocode-ai/local-server/dist/services/relationships.js +42 -0
  533. package/node_modules/@sudocode-ai/local-server/dist/services/relationships.js.map +1 -0
  534. package/node_modules/@sudocode-ai/local-server/dist/services/repo-info.d.ts +33 -0
  535. package/node_modules/@sudocode-ai/local-server/dist/services/repo-info.d.ts.map +1 -0
  536. package/node_modules/@sudocode-ai/local-server/dist/services/repo-info.js +136 -0
  537. package/node_modules/@sudocode-ai/local-server/dist/services/repo-info.js.map +1 -0
  538. package/node_modules/@sudocode-ai/local-server/dist/services/specs.d.ts +27 -0
  539. package/node_modules/@sudocode-ai/local-server/dist/services/specs.d.ts.map +1 -0
  540. package/node_modules/@sudocode-ai/local-server/dist/services/specs.js +35 -0
  541. package/node_modules/@sudocode-ai/local-server/dist/services/specs.js.map +1 -0
  542. package/node_modules/@sudocode-ai/local-server/dist/services/version-service.d.ts +14 -0
  543. package/node_modules/@sudocode-ai/local-server/dist/services/version-service.d.ts.map +1 -0
  544. package/node_modules/@sudocode-ai/local-server/dist/services/version-service.js +57 -0
  545. package/node_modules/@sudocode-ai/local-server/dist/services/version-service.js.map +1 -0
  546. package/node_modules/@sudocode-ai/local-server/dist/services/watcher.d.ts +49 -0
  547. package/node_modules/@sudocode-ai/local-server/dist/services/watcher.d.ts.map +1 -0
  548. package/node_modules/@sudocode-ai/local-server/dist/services/watcher.js +52 -0
  549. package/node_modules/@sudocode-ai/local-server/dist/services/watcher.js.map +1 -0
  550. package/node_modules/@sudocode-ai/local-server/dist/services/websocket.d.ts +179 -0
  551. package/node_modules/@sudocode-ai/local-server/dist/services/websocket.d.ts.map +1 -0
  552. package/node_modules/@sudocode-ai/local-server/dist/services/websocket.js +543 -0
  553. package/node_modules/@sudocode-ai/local-server/dist/services/websocket.js.map +1 -0
  554. package/node_modules/@sudocode-ai/local-server/dist/services/workflow-broadcast-service.d.ts +43 -0
  555. package/node_modules/@sudocode-ai/local-server/dist/services/workflow-broadcast-service.d.ts.map +1 -0
  556. package/node_modules/@sudocode-ai/local-server/dist/services/workflow-broadcast-service.js +155 -0
  557. package/node_modules/@sudocode-ai/local-server/dist/services/workflow-broadcast-service.js.map +1 -0
  558. package/node_modules/@sudocode-ai/local-server/dist/services/worktree-sync-service.d.ts +437 -0
  559. package/node_modules/@sudocode-ai/local-server/dist/services/worktree-sync-service.d.ts.map +1 -0
  560. package/node_modules/@sudocode-ai/local-server/dist/services/worktree-sync-service.js +1505 -0
  561. package/node_modules/@sudocode-ai/local-server/dist/services/worktree-sync-service.js.map +1 -0
  562. package/node_modules/@sudocode-ai/local-server/dist/types/editor.d.ts +49 -0
  563. package/node_modules/@sudocode-ai/local-server/dist/types/editor.d.ts.map +1 -0
  564. package/node_modules/@sudocode-ai/local-server/dist/types/editor.js +50 -0
  565. package/node_modules/@sudocode-ai/local-server/dist/types/editor.js.map +1 -0
  566. package/node_modules/@sudocode-ai/local-server/dist/types/project.d.ts +58 -0
  567. package/node_modules/@sudocode-ai/local-server/dist/types/project.d.ts.map +1 -0
  568. package/node_modules/@sudocode-ai/local-server/dist/types/project.js +10 -0
  569. package/node_modules/@sudocode-ai/local-server/dist/types/project.js.map +1 -0
  570. package/node_modules/@sudocode-ai/local-server/dist/utils/execFileNoThrow.d.ts +43 -0
  571. package/node_modules/@sudocode-ai/local-server/dist/utils/execFileNoThrow.d.ts.map +1 -0
  572. package/node_modules/@sudocode-ai/local-server/dist/utils/execFileNoThrow.js +53 -0
  573. package/node_modules/@sudocode-ai/local-server/dist/utils/execFileNoThrow.js.map +1 -0
  574. package/node_modules/@sudocode-ai/local-server/dist/utils/executable-check.d.ts +36 -0
  575. package/node_modules/@sudocode-ai/local-server/dist/utils/executable-check.d.ts.map +1 -0
  576. package/node_modules/@sudocode-ai/local-server/dist/utils/executable-check.js +79 -0
  577. package/node_modules/@sudocode-ai/local-server/dist/utils/executable-check.js.map +1 -0
  578. package/node_modules/@sudocode-ai/local-server/dist/utils/sudocode-dir.d.ts +6 -0
  579. package/node_modules/@sudocode-ai/local-server/dist/utils/sudocode-dir.d.ts.map +1 -0
  580. package/node_modules/@sudocode-ai/local-server/dist/utils/sudocode-dir.js +9 -0
  581. package/node_modules/@sudocode-ai/local-server/dist/utils/sudocode-dir.js.map +1 -0
  582. package/node_modules/@sudocode-ai/local-server/dist/workers/execution-worker.d.ts +18 -0
  583. package/node_modules/@sudocode-ai/local-server/dist/workers/execution-worker.d.ts.map +1 -0
  584. package/node_modules/@sudocode-ai/local-server/dist/workers/execution-worker.js +340 -0
  585. package/node_modules/@sudocode-ai/local-server/dist/workers/execution-worker.js.map +1 -0
  586. package/node_modules/@sudocode-ai/local-server/dist/workers/worker-ipc.d.ts +84 -0
  587. package/node_modules/@sudocode-ai/local-server/dist/workers/worker-ipc.d.ts.map +1 -0
  588. package/node_modules/@sudocode-ai/local-server/dist/workers/worker-ipc.js +29 -0
  589. package/node_modules/@sudocode-ai/local-server/dist/workers/worker-ipc.js.map +1 -0
  590. package/node_modules/@sudocode-ai/local-server/dist/workflow/base-workflow-engine.d.ts +186 -0
  591. package/node_modules/@sudocode-ai/local-server/dist/workflow/base-workflow-engine.d.ts.map +1 -0
  592. package/node_modules/@sudocode-ai/local-server/dist/workflow/base-workflow-engine.js +557 -0
  593. package/node_modules/@sudocode-ai/local-server/dist/workflow/base-workflow-engine.js.map +1 -0
  594. package/node_modules/@sudocode-ai/local-server/dist/workflow/dependency-analyzer.d.ts +78 -0
  595. package/node_modules/@sudocode-ai/local-server/dist/workflow/dependency-analyzer.d.ts.map +1 -0
  596. package/node_modules/@sudocode-ai/local-server/dist/workflow/dependency-analyzer.js +264 -0
  597. package/node_modules/@sudocode-ai/local-server/dist/workflow/dependency-analyzer.js.map +1 -0
  598. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/orchestrator-engine.d.ts +237 -0
  599. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/orchestrator-engine.d.ts.map +1 -0
  600. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/orchestrator-engine.js +749 -0
  601. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/orchestrator-engine.js.map +1 -0
  602. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/sequential-engine.d.ts +276 -0
  603. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/sequential-engine.d.ts.map +1 -0
  604. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/sequential-engine.js +1110 -0
  605. package/node_modules/@sudocode-ai/local-server/dist/workflow/engines/sequential-engine.js.map +1 -0
  606. package/node_modules/@sudocode-ai/local-server/dist/workflow/index.d.ts +15 -0
  607. package/node_modules/@sudocode-ai/local-server/dist/workflow/index.d.ts.map +1 -0
  608. package/node_modules/@sudocode-ai/local-server/dist/workflow/index.js +22 -0
  609. package/node_modules/@sudocode-ai/local-server/dist/workflow/index.js.map +1 -0
  610. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/api-client.d.ts +103 -0
  611. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/api-client.d.ts.map +1 -0
  612. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/api-client.js +193 -0
  613. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/api-client.js.map +1 -0
  614. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/index.d.ts +16 -0
  615. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/index.d.ts.map +1 -0
  616. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/index.js +114 -0
  617. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/index.js.map +1 -0
  618. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/server.d.ts +85 -0
  619. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/server.d.ts.map +1 -0
  620. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/server.js +520 -0
  621. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/server.js.map +1 -0
  622. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/escalation.d.ts +36 -0
  623. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/escalation.d.ts.map +1 -0
  624. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/escalation.js +47 -0
  625. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/escalation.js.map +1 -0
  626. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/execution.d.ts +59 -0
  627. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/execution.d.ts.map +1 -0
  628. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/execution.js +67 -0
  629. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/execution.js.map +1 -0
  630. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/inspection.d.ts +82 -0
  631. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/inspection.d.ts.map +1 -0
  632. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/inspection.js +57 -0
  633. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/inspection.js.map +1 -0
  634. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/workflow.d.ts +59 -0
  635. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/workflow.d.ts.map +1 -0
  636. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/workflow.js +40 -0
  637. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/tools/workflow.js.map +1 -0
  638. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/types.d.ts +345 -0
  639. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/types.d.ts.map +1 -0
  640. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/types.js +7 -0
  641. package/node_modules/@sudocode-ai/local-server/dist/workflow/mcp/types.js.map +1 -0
  642. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/prompt-builder.d.ts +36 -0
  643. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/prompt-builder.d.ts.map +1 -0
  644. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/prompt-builder.js +329 -0
  645. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/prompt-builder.js.map +1 -0
  646. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/wakeup-service.d.ts +262 -0
  647. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/wakeup-service.d.ts.map +1 -0
  648. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/wakeup-service.js +809 -0
  649. package/node_modules/@sudocode-ai/local-server/dist/workflow/services/wakeup-service.js.map +1 -0
  650. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-engine.d.ts +221 -0
  651. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-engine.d.ts.map +1 -0
  652. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-engine.js +94 -0
  653. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-engine.js.map +1 -0
  654. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-event-emitter.d.ts +278 -0
  655. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-event-emitter.d.ts.map +1 -0
  656. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-event-emitter.js +259 -0
  657. package/node_modules/@sudocode-ai/local-server/dist/workflow/workflow-event-emitter.js.map +1 -0
  658. package/node_modules/@sudocode-ai/local-server/package.json +78 -0
  659. package/node_modules/@sudocode-ai/mcp/README.md +226 -0
  660. package/node_modules/@sudocode-ai/mcp/dist/client.d.ts +33 -0
  661. package/node_modules/@sudocode-ai/mcp/dist/client.d.ts.map +1 -0
  662. package/node_modules/@sudocode-ai/mcp/dist/client.js +166 -0
  663. package/node_modules/@sudocode-ai/mcp/dist/client.js.map +1 -0
  664. package/node_modules/@sudocode-ai/mcp/dist/index.d.ts +6 -0
  665. package/node_modules/@sudocode-ai/mcp/dist/index.d.ts.map +1 -0
  666. package/node_modules/@sudocode-ai/mcp/dist/index.js +64 -0
  667. package/node_modules/@sudocode-ai/mcp/dist/index.js.map +1 -0
  668. package/node_modules/@sudocode-ai/mcp/dist/server.d.ts +26 -0
  669. package/node_modules/@sudocode-ai/mcp/dist/server.d.ts.map +1 -0
  670. package/node_modules/@sudocode-ai/mcp/dist/server.js +577 -0
  671. package/node_modules/@sudocode-ai/mcp/dist/server.js.map +1 -0
  672. package/node_modules/@sudocode-ai/mcp/dist/tools/analytics.d.ts +41 -0
  673. package/node_modules/@sudocode-ai/mcp/dist/tools/analytics.d.ts.map +1 -0
  674. package/node_modules/@sudocode-ai/mcp/dist/tools/analytics.js +21 -0
  675. package/node_modules/@sudocode-ai/mcp/dist/tools/analytics.js.map +1 -0
  676. package/node_modules/@sudocode-ai/mcp/dist/tools/feedback.d.ts +21 -0
  677. package/node_modules/@sudocode-ai/mcp/dist/tools/feedback.d.ts.map +1 -0
  678. package/node_modules/@sudocode-ai/mcp/dist/tools/feedback.js +30 -0
  679. package/node_modules/@sudocode-ai/mcp/dist/tools/feedback.js.map +1 -0
  680. package/node_modules/@sudocode-ai/mcp/dist/tools/init.d.ts +17 -0
  681. package/node_modules/@sudocode-ai/mcp/dist/tools/init.d.ts.map +1 -0
  682. package/node_modules/@sudocode-ai/mcp/dist/tools/init.js +15 -0
  683. package/node_modules/@sudocode-ai/mcp/dist/tools/init.js.map +1 -0
  684. package/node_modules/@sudocode-ai/mcp/dist/tools/issues.d.ts +44 -0
  685. package/node_modules/@sudocode-ai/mcp/dist/tools/issues.d.ts.map +1 -0
  686. package/node_modules/@sudocode-ai/mcp/dist/tools/issues.js +109 -0
  687. package/node_modules/@sudocode-ai/mcp/dist/tools/issues.js.map +1 -0
  688. package/node_modules/@sudocode-ai/mcp/dist/tools/references.d.ts +21 -0
  689. package/node_modules/@sudocode-ai/mcp/dist/tools/references.d.ts.map +1 -0
  690. package/node_modules/@sudocode-ai/mcp/dist/tools/references.js +49 -0
  691. package/node_modules/@sudocode-ai/mcp/dist/tools/references.js.map +1 -0
  692. package/node_modules/@sudocode-ai/mcp/dist/tools/relationships.d.ts +15 -0
  693. package/node_modules/@sudocode-ai/mcp/dist/tools/relationships.d.ts.map +1 -0
  694. package/node_modules/@sudocode-ai/mcp/dist/tools/relationships.js +18 -0
  695. package/node_modules/@sudocode-ai/mcp/dist/tools/relationships.js.map +1 -0
  696. package/node_modules/@sudocode-ai/mcp/dist/tools/specs.d.ts +35 -0
  697. package/node_modules/@sudocode-ai/mcp/dist/tools/specs.d.ts.map +1 -0
  698. package/node_modules/@sudocode-ai/mcp/dist/tools/specs.js +85 -0
  699. package/node_modules/@sudocode-ai/mcp/dist/tools/specs.js.map +1 -0
  700. package/node_modules/@sudocode-ai/mcp/dist/types.d.ts +35 -0
  701. package/node_modules/@sudocode-ai/mcp/dist/types.d.ts.map +1 -0
  702. package/node_modules/@sudocode-ai/mcp/dist/types.js +21 -0
  703. package/node_modules/@sudocode-ai/mcp/dist/types.js.map +1 -0
  704. package/node_modules/@sudocode-ai/mcp/package.json +67 -0
  705. package/node_modules/@sudocode-ai/types/README.md +7 -0
  706. package/node_modules/@sudocode-ai/types/package.json +76 -0
  707. package/node_modules/@sudocode-ai/types/src/agents.d.ts +278 -0
  708. package/node_modules/@sudocode-ai/types/src/artifacts.d.ts +66 -0
  709. package/node_modules/@sudocode-ai/types/src/events.d.ts +70 -0
  710. package/node_modules/@sudocode-ai/types/src/index.d.ts +452 -0
  711. package/node_modules/@sudocode-ai/types/src/integrations.d.ts +454 -0
  712. package/node_modules/@sudocode-ai/types/src/workflows.d.ts +501 -0
  713. package/node_modules/commander/LICENSE +22 -0
  714. package/node_modules/commander/Readme.md +1149 -0
  715. package/node_modules/commander/esm.mjs +16 -0
  716. package/node_modules/commander/index.js +24 -0
  717. package/node_modules/commander/lib/argument.js +149 -0
  718. package/node_modules/commander/lib/command.js +2662 -0
  719. package/node_modules/commander/lib/error.js +39 -0
  720. package/node_modules/commander/lib/help.js +709 -0
  721. package/node_modules/commander/lib/option.js +367 -0
  722. package/node_modules/commander/lib/suggestSimilar.js +101 -0
  723. package/node_modules/commander/package-support.json +16 -0
  724. package/node_modules/commander/package.json +82 -0
  725. package/node_modules/commander/typings/esm.d.mts +3 -0
  726. package/node_modules/commander/typings/index.d.ts +1045 -0
  727. package/node_modules/glob/LICENSE +15 -0
  728. package/node_modules/glob/README.md +1265 -0
  729. package/node_modules/glob/package.json +99 -0
  730. package/node_modules/isexe/LICENSE +15 -0
  731. package/node_modules/isexe/README.md +74 -0
  732. package/node_modules/isexe/package.json +96 -0
  733. package/node_modules/which/LICENSE +15 -0
  734. package/node_modules/which/README.md +51 -0
  735. package/node_modules/which/bin/which.js +52 -0
  736. package/node_modules/which/lib/index.js +111 -0
  737. package/node_modules/which/package.json +52 -0
  738. package/package.json +9 -9
@@ -0,0 +1,2662 @@
1
+ const EventEmitter = require('node:events').EventEmitter;
2
+ const childProcess = require('node:child_process');
3
+ const path = require('node:path');
4
+ const fs = require('node:fs');
5
+ const process = require('node:process');
6
+
7
+ const { Argument, humanReadableArgName } = require('./argument.js');
8
+ const { CommanderError } = require('./error.js');
9
+ const { Help, stripColor } = require('./help.js');
10
+ const { Option, DualOptions } = require('./option.js');
11
+ const { suggestSimilar } = require('./suggestSimilar');
12
+
13
+ class Command extends EventEmitter {
14
+ /**
15
+ * Initialize a new `Command`.
16
+ *
17
+ * @param {string} [name]
18
+ */
19
+
20
+ constructor(name) {
21
+ super();
22
+ /** @type {Command[]} */
23
+ this.commands = [];
24
+ /** @type {Option[]} */
25
+ this.options = [];
26
+ this.parent = null;
27
+ this._allowUnknownOption = false;
28
+ this._allowExcessArguments = false;
29
+ /** @type {Argument[]} */
30
+ this.registeredArguments = [];
31
+ this._args = this.registeredArguments; // deprecated old name
32
+ /** @type {string[]} */
33
+ this.args = []; // cli args with options removed
34
+ this.rawArgs = [];
35
+ this.processedArgs = []; // like .args but after custom processing and collecting variadic
36
+ this._scriptPath = null;
37
+ this._name = name || '';
38
+ this._optionValues = {};
39
+ this._optionValueSources = {}; // default, env, cli etc
40
+ this._storeOptionsAsProperties = false;
41
+ this._actionHandler = null;
42
+ this._executableHandler = false;
43
+ this._executableFile = null; // custom name for executable
44
+ this._executableDir = null; // custom search directory for subcommands
45
+ this._defaultCommandName = null;
46
+ this._exitCallback = null;
47
+ this._aliases = [];
48
+ this._combineFlagAndOptionalValue = true;
49
+ this._description = '';
50
+ this._summary = '';
51
+ this._argsDescription = undefined; // legacy
52
+ this._enablePositionalOptions = false;
53
+ this._passThroughOptions = false;
54
+ this._lifeCycleHooks = {}; // a hash of arrays
55
+ /** @type {(boolean | string)} */
56
+ this._showHelpAfterError = false;
57
+ this._showSuggestionAfterError = true;
58
+ this._savedState = null; // used in save/restoreStateBeforeParse
59
+
60
+ // see configureOutput() for docs
61
+ this._outputConfiguration = {
62
+ writeOut: (str) => process.stdout.write(str),
63
+ writeErr: (str) => process.stderr.write(str),
64
+ outputError: (str, write) => write(str),
65
+ getOutHelpWidth: () =>
66
+ process.stdout.isTTY ? process.stdout.columns : undefined,
67
+ getErrHelpWidth: () =>
68
+ process.stderr.isTTY ? process.stderr.columns : undefined,
69
+ getOutHasColors: () =>
70
+ useColor() ?? (process.stdout.isTTY && process.stdout.hasColors?.()),
71
+ getErrHasColors: () =>
72
+ useColor() ?? (process.stderr.isTTY && process.stderr.hasColors?.()),
73
+ stripColor: (str) => stripColor(str),
74
+ };
75
+
76
+ this._hidden = false;
77
+ /** @type {(Option | null | undefined)} */
78
+ this._helpOption = undefined; // Lazy created on demand. May be null if help option is disabled.
79
+ this._addImplicitHelpCommand = undefined; // undecided whether true or false yet, not inherited
80
+ /** @type {Command} */
81
+ this._helpCommand = undefined; // lazy initialised, inherited
82
+ this._helpConfiguration = {};
83
+ }
84
+
85
+ /**
86
+ * Copy settings that are useful to have in common across root command and subcommands.
87
+ *
88
+ * (Used internally when adding a command using `.command()` so subcommands inherit parent settings.)
89
+ *
90
+ * @param {Command} sourceCommand
91
+ * @return {Command} `this` command for chaining
92
+ */
93
+ copyInheritedSettings(sourceCommand) {
94
+ this._outputConfiguration = sourceCommand._outputConfiguration;
95
+ this._helpOption = sourceCommand._helpOption;
96
+ this._helpCommand = sourceCommand._helpCommand;
97
+ this._helpConfiguration = sourceCommand._helpConfiguration;
98
+ this._exitCallback = sourceCommand._exitCallback;
99
+ this._storeOptionsAsProperties = sourceCommand._storeOptionsAsProperties;
100
+ this._combineFlagAndOptionalValue =
101
+ sourceCommand._combineFlagAndOptionalValue;
102
+ this._allowExcessArguments = sourceCommand._allowExcessArguments;
103
+ this._enablePositionalOptions = sourceCommand._enablePositionalOptions;
104
+ this._showHelpAfterError = sourceCommand._showHelpAfterError;
105
+ this._showSuggestionAfterError = sourceCommand._showSuggestionAfterError;
106
+
107
+ return this;
108
+ }
109
+
110
+ /**
111
+ * @returns {Command[]}
112
+ * @private
113
+ */
114
+
115
+ _getCommandAndAncestors() {
116
+ const result = [];
117
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
118
+ for (let command = this; command; command = command.parent) {
119
+ result.push(command);
120
+ }
121
+ return result;
122
+ }
123
+
124
+ /**
125
+ * Define a command.
126
+ *
127
+ * There are two styles of command: pay attention to where to put the description.
128
+ *
129
+ * @example
130
+ * // Command implemented using action handler (description is supplied separately to `.command`)
131
+ * program
132
+ * .command('clone <source> [destination]')
133
+ * .description('clone a repository into a newly created directory')
134
+ * .action((source, destination) => {
135
+ * console.log('clone command called');
136
+ * });
137
+ *
138
+ * // Command implemented using separate executable file (description is second parameter to `.command`)
139
+ * program
140
+ * .command('start <service>', 'start named service')
141
+ * .command('stop [service]', 'stop named service, or all if no name supplied');
142
+ *
143
+ * @param {string} nameAndArgs - command name and arguments, args are `<required>` or `[optional]` and last may also be `variadic...`
144
+ * @param {(object | string)} [actionOptsOrExecDesc] - configuration options (for action), or description (for executable)
145
+ * @param {object} [execOpts] - configuration options (for executable)
146
+ * @return {Command} returns new command for action handler, or `this` for executable command
147
+ */
148
+
149
+ command(nameAndArgs, actionOptsOrExecDesc, execOpts) {
150
+ let desc = actionOptsOrExecDesc;
151
+ let opts = execOpts;
152
+ if (typeof desc === 'object' && desc !== null) {
153
+ opts = desc;
154
+ desc = null;
155
+ }
156
+ opts = opts || {};
157
+ const [, name, args] = nameAndArgs.match(/([^ ]+) *(.*)/);
158
+
159
+ const cmd = this.createCommand(name);
160
+ if (desc) {
161
+ cmd.description(desc);
162
+ cmd._executableHandler = true;
163
+ }
164
+ if (opts.isDefault) this._defaultCommandName = cmd._name;
165
+ cmd._hidden = !!(opts.noHelp || opts.hidden); // noHelp is deprecated old name for hidden
166
+ cmd._executableFile = opts.executableFile || null; // Custom name for executable file, set missing to null to match constructor
167
+ if (args) cmd.arguments(args);
168
+ this._registerCommand(cmd);
169
+ cmd.parent = this;
170
+ cmd.copyInheritedSettings(this);
171
+
172
+ if (desc) return this;
173
+ return cmd;
174
+ }
175
+
176
+ /**
177
+ * Factory routine to create a new unattached command.
178
+ *
179
+ * See .command() for creating an attached subcommand, which uses this routine to
180
+ * create the command. You can override createCommand to customise subcommands.
181
+ *
182
+ * @param {string} [name]
183
+ * @return {Command} new command
184
+ */
185
+
186
+ createCommand(name) {
187
+ return new Command(name);
188
+ }
189
+
190
+ /**
191
+ * You can customise the help with a subclass of Help by overriding createHelp,
192
+ * or by overriding Help properties using configureHelp().
193
+ *
194
+ * @return {Help}
195
+ */
196
+
197
+ createHelp() {
198
+ return Object.assign(new Help(), this.configureHelp());
199
+ }
200
+
201
+ /**
202
+ * You can customise the help by overriding Help properties using configureHelp(),
203
+ * or with a subclass of Help by overriding createHelp().
204
+ *
205
+ * @param {object} [configuration] - configuration options
206
+ * @return {(Command | object)} `this` command for chaining, or stored configuration
207
+ */
208
+
209
+ configureHelp(configuration) {
210
+ if (configuration === undefined) return this._helpConfiguration;
211
+
212
+ this._helpConfiguration = configuration;
213
+ return this;
214
+ }
215
+
216
+ /**
217
+ * The default output goes to stdout and stderr. You can customise this for special
218
+ * applications. You can also customise the display of errors by overriding outputError.
219
+ *
220
+ * The configuration properties are all functions:
221
+ *
222
+ * // change how output being written, defaults to stdout and stderr
223
+ * writeOut(str)
224
+ * writeErr(str)
225
+ * // change how output being written for errors, defaults to writeErr
226
+ * outputError(str, write) // used for displaying errors and not used for displaying help
227
+ * // specify width for wrapping help
228
+ * getOutHelpWidth()
229
+ * getErrHelpWidth()
230
+ * // color support, currently only used with Help
231
+ * getOutHasColors()
232
+ * getErrHasColors()
233
+ * stripColor() // used to remove ANSI escape codes if output does not have colors
234
+ *
235
+ * @param {object} [configuration] - configuration options
236
+ * @return {(Command | object)} `this` command for chaining, or stored configuration
237
+ */
238
+
239
+ configureOutput(configuration) {
240
+ if (configuration === undefined) return this._outputConfiguration;
241
+
242
+ Object.assign(this._outputConfiguration, configuration);
243
+ return this;
244
+ }
245
+
246
+ /**
247
+ * Display the help or a custom message after an error occurs.
248
+ *
249
+ * @param {(boolean|string)} [displayHelp]
250
+ * @return {Command} `this` command for chaining
251
+ */
252
+ showHelpAfterError(displayHelp = true) {
253
+ if (typeof displayHelp !== 'string') displayHelp = !!displayHelp;
254
+ this._showHelpAfterError = displayHelp;
255
+ return this;
256
+ }
257
+
258
+ /**
259
+ * Display suggestion of similar commands for unknown commands, or options for unknown options.
260
+ *
261
+ * @param {boolean} [displaySuggestion]
262
+ * @return {Command} `this` command for chaining
263
+ */
264
+ showSuggestionAfterError(displaySuggestion = true) {
265
+ this._showSuggestionAfterError = !!displaySuggestion;
266
+ return this;
267
+ }
268
+
269
+ /**
270
+ * Add a prepared subcommand.
271
+ *
272
+ * See .command() for creating an attached subcommand which inherits settings from its parent.
273
+ *
274
+ * @param {Command} cmd - new subcommand
275
+ * @param {object} [opts] - configuration options
276
+ * @return {Command} `this` command for chaining
277
+ */
278
+
279
+ addCommand(cmd, opts) {
280
+ if (!cmd._name) {
281
+ throw new Error(`Command passed to .addCommand() must have a name
282
+ - specify the name in Command constructor or using .name()`);
283
+ }
284
+
285
+ opts = opts || {};
286
+ if (opts.isDefault) this._defaultCommandName = cmd._name;
287
+ if (opts.noHelp || opts.hidden) cmd._hidden = true; // modifying passed command due to existing implementation
288
+
289
+ this._registerCommand(cmd);
290
+ cmd.parent = this;
291
+ cmd._checkForBrokenPassThrough();
292
+
293
+ return this;
294
+ }
295
+
296
+ /**
297
+ * Factory routine to create a new unattached argument.
298
+ *
299
+ * See .argument() for creating an attached argument, which uses this routine to
300
+ * create the argument. You can override createArgument to return a custom argument.
301
+ *
302
+ * @param {string} name
303
+ * @param {string} [description]
304
+ * @return {Argument} new argument
305
+ */
306
+
307
+ createArgument(name, description) {
308
+ return new Argument(name, description);
309
+ }
310
+
311
+ /**
312
+ * Define argument syntax for command.
313
+ *
314
+ * The default is that the argument is required, and you can explicitly
315
+ * indicate this with <> around the name. Put [] around the name for an optional argument.
316
+ *
317
+ * @example
318
+ * program.argument('<input-file>');
319
+ * program.argument('[output-file]');
320
+ *
321
+ * @param {string} name
322
+ * @param {string} [description]
323
+ * @param {(Function|*)} [fn] - custom argument processing function
324
+ * @param {*} [defaultValue]
325
+ * @return {Command} `this` command for chaining
326
+ */
327
+ argument(name, description, fn, defaultValue) {
328
+ const argument = this.createArgument(name, description);
329
+ if (typeof fn === 'function') {
330
+ argument.default(defaultValue).argParser(fn);
331
+ } else {
332
+ argument.default(fn);
333
+ }
334
+ this.addArgument(argument);
335
+ return this;
336
+ }
337
+
338
+ /**
339
+ * Define argument syntax for command, adding multiple at once (without descriptions).
340
+ *
341
+ * See also .argument().
342
+ *
343
+ * @example
344
+ * program.arguments('<cmd> [env]');
345
+ *
346
+ * @param {string} names
347
+ * @return {Command} `this` command for chaining
348
+ */
349
+
350
+ arguments(names) {
351
+ names
352
+ .trim()
353
+ .split(/ +/)
354
+ .forEach((detail) => {
355
+ this.argument(detail);
356
+ });
357
+ return this;
358
+ }
359
+
360
+ /**
361
+ * Define argument syntax for command, adding a prepared argument.
362
+ *
363
+ * @param {Argument} argument
364
+ * @return {Command} `this` command for chaining
365
+ */
366
+ addArgument(argument) {
367
+ const previousArgument = this.registeredArguments.slice(-1)[0];
368
+ if (previousArgument && previousArgument.variadic) {
369
+ throw new Error(
370
+ `only the last argument can be variadic '${previousArgument.name()}'`,
371
+ );
372
+ }
373
+ if (
374
+ argument.required &&
375
+ argument.defaultValue !== undefined &&
376
+ argument.parseArg === undefined
377
+ ) {
378
+ throw new Error(
379
+ `a default value for a required argument is never used: '${argument.name()}'`,
380
+ );
381
+ }
382
+ this.registeredArguments.push(argument);
383
+ return this;
384
+ }
385
+
386
+ /**
387
+ * Customise or override default help command. By default a help command is automatically added if your command has subcommands.
388
+ *
389
+ * @example
390
+ * program.helpCommand('help [cmd]');
391
+ * program.helpCommand('help [cmd]', 'show help');
392
+ * program.helpCommand(false); // suppress default help command
393
+ * program.helpCommand(true); // add help command even if no subcommands
394
+ *
395
+ * @param {string|boolean} enableOrNameAndArgs - enable with custom name and/or arguments, or boolean to override whether added
396
+ * @param {string} [description] - custom description
397
+ * @return {Command} `this` command for chaining
398
+ */
399
+
400
+ helpCommand(enableOrNameAndArgs, description) {
401
+ if (typeof enableOrNameAndArgs === 'boolean') {
402
+ this._addImplicitHelpCommand = enableOrNameAndArgs;
403
+ return this;
404
+ }
405
+
406
+ enableOrNameAndArgs = enableOrNameAndArgs ?? 'help [command]';
407
+ const [, helpName, helpArgs] = enableOrNameAndArgs.match(/([^ ]+) *(.*)/);
408
+ const helpDescription = description ?? 'display help for command';
409
+
410
+ const helpCommand = this.createCommand(helpName);
411
+ helpCommand.helpOption(false);
412
+ if (helpArgs) helpCommand.arguments(helpArgs);
413
+ if (helpDescription) helpCommand.description(helpDescription);
414
+
415
+ this._addImplicitHelpCommand = true;
416
+ this._helpCommand = helpCommand;
417
+
418
+ return this;
419
+ }
420
+
421
+ /**
422
+ * Add prepared custom help command.
423
+ *
424
+ * @param {(Command|string|boolean)} helpCommand - custom help command, or deprecated enableOrNameAndArgs as for `.helpCommand()`
425
+ * @param {string} [deprecatedDescription] - deprecated custom description used with custom name only
426
+ * @return {Command} `this` command for chaining
427
+ */
428
+ addHelpCommand(helpCommand, deprecatedDescription) {
429
+ // If not passed an object, call through to helpCommand for backwards compatibility,
430
+ // as addHelpCommand was originally used like helpCommand is now.
431
+ if (typeof helpCommand !== 'object') {
432
+ this.helpCommand(helpCommand, deprecatedDescription);
433
+ return this;
434
+ }
435
+
436
+ this._addImplicitHelpCommand = true;
437
+ this._helpCommand = helpCommand;
438
+ return this;
439
+ }
440
+
441
+ /**
442
+ * Lazy create help command.
443
+ *
444
+ * @return {(Command|null)}
445
+ * @package
446
+ */
447
+ _getHelpCommand() {
448
+ const hasImplicitHelpCommand =
449
+ this._addImplicitHelpCommand ??
450
+ (this.commands.length &&
451
+ !this._actionHandler &&
452
+ !this._findCommand('help'));
453
+
454
+ if (hasImplicitHelpCommand) {
455
+ if (this._helpCommand === undefined) {
456
+ this.helpCommand(undefined, undefined); // use default name and description
457
+ }
458
+ return this._helpCommand;
459
+ }
460
+ return null;
461
+ }
462
+
463
+ /**
464
+ * Add hook for life cycle event.
465
+ *
466
+ * @param {string} event
467
+ * @param {Function} listener
468
+ * @return {Command} `this` command for chaining
469
+ */
470
+
471
+ hook(event, listener) {
472
+ const allowedValues = ['preSubcommand', 'preAction', 'postAction'];
473
+ if (!allowedValues.includes(event)) {
474
+ throw new Error(`Unexpected value for event passed to hook : '${event}'.
475
+ Expecting one of '${allowedValues.join("', '")}'`);
476
+ }
477
+ if (this._lifeCycleHooks[event]) {
478
+ this._lifeCycleHooks[event].push(listener);
479
+ } else {
480
+ this._lifeCycleHooks[event] = [listener];
481
+ }
482
+ return this;
483
+ }
484
+
485
+ /**
486
+ * Register callback to use as replacement for calling process.exit.
487
+ *
488
+ * @param {Function} [fn] optional callback which will be passed a CommanderError, defaults to throwing
489
+ * @return {Command} `this` command for chaining
490
+ */
491
+
492
+ exitOverride(fn) {
493
+ if (fn) {
494
+ this._exitCallback = fn;
495
+ } else {
496
+ this._exitCallback = (err) => {
497
+ if (err.code !== 'commander.executeSubCommandAsync') {
498
+ throw err;
499
+ } else {
500
+ // Async callback from spawn events, not useful to throw.
501
+ }
502
+ };
503
+ }
504
+ return this;
505
+ }
506
+
507
+ /**
508
+ * Call process.exit, and _exitCallback if defined.
509
+ *
510
+ * @param {number} exitCode exit code for using with process.exit
511
+ * @param {string} code an id string representing the error
512
+ * @param {string} message human-readable description of the error
513
+ * @return never
514
+ * @private
515
+ */
516
+
517
+ _exit(exitCode, code, message) {
518
+ if (this._exitCallback) {
519
+ this._exitCallback(new CommanderError(exitCode, code, message));
520
+ // Expecting this line is not reached.
521
+ }
522
+ process.exit(exitCode);
523
+ }
524
+
525
+ /**
526
+ * Register callback `fn` for the command.
527
+ *
528
+ * @example
529
+ * program
530
+ * .command('serve')
531
+ * .description('start service')
532
+ * .action(function() {
533
+ * // do work here
534
+ * });
535
+ *
536
+ * @param {Function} fn
537
+ * @return {Command} `this` command for chaining
538
+ */
539
+
540
+ action(fn) {
541
+ const listener = (args) => {
542
+ // The .action callback takes an extra parameter which is the command or options.
543
+ const expectedArgsCount = this.registeredArguments.length;
544
+ const actionArgs = args.slice(0, expectedArgsCount);
545
+ if (this._storeOptionsAsProperties) {
546
+ actionArgs[expectedArgsCount] = this; // backwards compatible "options"
547
+ } else {
548
+ actionArgs[expectedArgsCount] = this.opts();
549
+ }
550
+ actionArgs.push(this);
551
+
552
+ return fn.apply(this, actionArgs);
553
+ };
554
+ this._actionHandler = listener;
555
+ return this;
556
+ }
557
+
558
+ /**
559
+ * Factory routine to create a new unattached option.
560
+ *
561
+ * See .option() for creating an attached option, which uses this routine to
562
+ * create the option. You can override createOption to return a custom option.
563
+ *
564
+ * @param {string} flags
565
+ * @param {string} [description]
566
+ * @return {Option} new option
567
+ */
568
+
569
+ createOption(flags, description) {
570
+ return new Option(flags, description);
571
+ }
572
+
573
+ /**
574
+ * Wrap parseArgs to catch 'commander.invalidArgument'.
575
+ *
576
+ * @param {(Option | Argument)} target
577
+ * @param {string} value
578
+ * @param {*} previous
579
+ * @param {string} invalidArgumentMessage
580
+ * @private
581
+ */
582
+
583
+ _callParseArg(target, value, previous, invalidArgumentMessage) {
584
+ try {
585
+ return target.parseArg(value, previous);
586
+ } catch (err) {
587
+ if (err.code === 'commander.invalidArgument') {
588
+ const message = `${invalidArgumentMessage} ${err.message}`;
589
+ this.error(message, { exitCode: err.exitCode, code: err.code });
590
+ }
591
+ throw err;
592
+ }
593
+ }
594
+
595
+ /**
596
+ * Check for option flag conflicts.
597
+ * Register option if no conflicts found, or throw on conflict.
598
+ *
599
+ * @param {Option} option
600
+ * @private
601
+ */
602
+
603
+ _registerOption(option) {
604
+ const matchingOption =
605
+ (option.short && this._findOption(option.short)) ||
606
+ (option.long && this._findOption(option.long));
607
+ if (matchingOption) {
608
+ const matchingFlag =
609
+ option.long && this._findOption(option.long)
610
+ ? option.long
611
+ : option.short;
612
+ throw new Error(`Cannot add option '${option.flags}'${this._name && ` to command '${this._name}'`} due to conflicting flag '${matchingFlag}'
613
+ - already used by option '${matchingOption.flags}'`);
614
+ }
615
+
616
+ this.options.push(option);
617
+ }
618
+
619
+ /**
620
+ * Check for command name and alias conflicts with existing commands.
621
+ * Register command if no conflicts found, or throw on conflict.
622
+ *
623
+ * @param {Command} command
624
+ * @private
625
+ */
626
+
627
+ _registerCommand(command) {
628
+ const knownBy = (cmd) => {
629
+ return [cmd.name()].concat(cmd.aliases());
630
+ };
631
+
632
+ const alreadyUsed = knownBy(command).find((name) =>
633
+ this._findCommand(name),
634
+ );
635
+ if (alreadyUsed) {
636
+ const existingCmd = knownBy(this._findCommand(alreadyUsed)).join('|');
637
+ const newCmd = knownBy(command).join('|');
638
+ throw new Error(
639
+ `cannot add command '${newCmd}' as already have command '${existingCmd}'`,
640
+ );
641
+ }
642
+
643
+ this.commands.push(command);
644
+ }
645
+
646
+ /**
647
+ * Add an option.
648
+ *
649
+ * @param {Option} option
650
+ * @return {Command} `this` command for chaining
651
+ */
652
+ addOption(option) {
653
+ this._registerOption(option);
654
+
655
+ const oname = option.name();
656
+ const name = option.attributeName();
657
+
658
+ // store default value
659
+ if (option.negate) {
660
+ // --no-foo is special and defaults foo to true, unless a --foo option is already defined
661
+ const positiveLongFlag = option.long.replace(/^--no-/, '--');
662
+ if (!this._findOption(positiveLongFlag)) {
663
+ this.setOptionValueWithSource(
664
+ name,
665
+ option.defaultValue === undefined ? true : option.defaultValue,
666
+ 'default',
667
+ );
668
+ }
669
+ } else if (option.defaultValue !== undefined) {
670
+ this.setOptionValueWithSource(name, option.defaultValue, 'default');
671
+ }
672
+
673
+ // handler for cli and env supplied values
674
+ const handleOptionValue = (val, invalidValueMessage, valueSource) => {
675
+ // val is null for optional option used without an optional-argument.
676
+ // val is undefined for boolean and negated option.
677
+ if (val == null && option.presetArg !== undefined) {
678
+ val = option.presetArg;
679
+ }
680
+
681
+ // custom processing
682
+ const oldValue = this.getOptionValue(name);
683
+ if (val !== null && option.parseArg) {
684
+ val = this._callParseArg(option, val, oldValue, invalidValueMessage);
685
+ } else if (val !== null && option.variadic) {
686
+ val = option._concatValue(val, oldValue);
687
+ }
688
+
689
+ // Fill-in appropriate missing values. Long winded but easy to follow.
690
+ if (val == null) {
691
+ if (option.negate) {
692
+ val = false;
693
+ } else if (option.isBoolean() || option.optional) {
694
+ val = true;
695
+ } else {
696
+ val = ''; // not normal, parseArg might have failed or be a mock function for testing
697
+ }
698
+ }
699
+ this.setOptionValueWithSource(name, val, valueSource);
700
+ };
701
+
702
+ this.on('option:' + oname, (val) => {
703
+ const invalidValueMessage = `error: option '${option.flags}' argument '${val}' is invalid.`;
704
+ handleOptionValue(val, invalidValueMessage, 'cli');
705
+ });
706
+
707
+ if (option.envVar) {
708
+ this.on('optionEnv:' + oname, (val) => {
709
+ const invalidValueMessage = `error: option '${option.flags}' value '${val}' from env '${option.envVar}' is invalid.`;
710
+ handleOptionValue(val, invalidValueMessage, 'env');
711
+ });
712
+ }
713
+
714
+ return this;
715
+ }
716
+
717
+ /**
718
+ * Internal implementation shared by .option() and .requiredOption()
719
+ *
720
+ * @return {Command} `this` command for chaining
721
+ * @private
722
+ */
723
+ _optionEx(config, flags, description, fn, defaultValue) {
724
+ if (typeof flags === 'object' && flags instanceof Option) {
725
+ throw new Error(
726
+ 'To add an Option object use addOption() instead of option() or requiredOption()',
727
+ );
728
+ }
729
+ const option = this.createOption(flags, description);
730
+ option.makeOptionMandatory(!!config.mandatory);
731
+ if (typeof fn === 'function') {
732
+ option.default(defaultValue).argParser(fn);
733
+ } else if (fn instanceof RegExp) {
734
+ // deprecated
735
+ const regex = fn;
736
+ fn = (val, def) => {
737
+ const m = regex.exec(val);
738
+ return m ? m[0] : def;
739
+ };
740
+ option.default(defaultValue).argParser(fn);
741
+ } else {
742
+ option.default(fn);
743
+ }
744
+
745
+ return this.addOption(option);
746
+ }
747
+
748
+ /**
749
+ * Define option with `flags`, `description`, and optional argument parsing function or `defaultValue` or both.
750
+ *
751
+ * The `flags` string contains the short and/or long flags, separated by comma, a pipe or space. A required
752
+ * option-argument is indicated by `<>` and an optional option-argument by `[]`.
753
+ *
754
+ * See the README for more details, and see also addOption() and requiredOption().
755
+ *
756
+ * @example
757
+ * program
758
+ * .option('-p, --pepper', 'add pepper')
759
+ * .option('--pt, --pizza-type <TYPE>', 'type of pizza') // required option-argument
760
+ * .option('-c, --cheese [CHEESE]', 'add extra cheese', 'mozzarella') // optional option-argument with default
761
+ * .option('-t, --tip <VALUE>', 'add tip to purchase cost', parseFloat) // custom parse function
762
+ *
763
+ * @param {string} flags
764
+ * @param {string} [description]
765
+ * @param {(Function|*)} [parseArg] - custom option processing function or default value
766
+ * @param {*} [defaultValue]
767
+ * @return {Command} `this` command for chaining
768
+ */
769
+
770
+ option(flags, description, parseArg, defaultValue) {
771
+ return this._optionEx({}, flags, description, parseArg, defaultValue);
772
+ }
773
+
774
+ /**
775
+ * Add a required option which must have a value after parsing. This usually means
776
+ * the option must be specified on the command line. (Otherwise the same as .option().)
777
+ *
778
+ * The `flags` string contains the short and/or long flags, separated by comma, a pipe or space.
779
+ *
780
+ * @param {string} flags
781
+ * @param {string} [description]
782
+ * @param {(Function|*)} [parseArg] - custom option processing function or default value
783
+ * @param {*} [defaultValue]
784
+ * @return {Command} `this` command for chaining
785
+ */
786
+
787
+ requiredOption(flags, description, parseArg, defaultValue) {
788
+ return this._optionEx(
789
+ { mandatory: true },
790
+ flags,
791
+ description,
792
+ parseArg,
793
+ defaultValue,
794
+ );
795
+ }
796
+
797
+ /**
798
+ * Alter parsing of short flags with optional values.
799
+ *
800
+ * @example
801
+ * // for `.option('-f,--flag [value]'):
802
+ * program.combineFlagAndOptionalValue(true); // `-f80` is treated like `--flag=80`, this is the default behaviour
803
+ * program.combineFlagAndOptionalValue(false) // `-fb` is treated like `-f -b`
804
+ *
805
+ * @param {boolean} [combine] - if `true` or omitted, an optional value can be specified directly after the flag.
806
+ * @return {Command} `this` command for chaining
807
+ */
808
+ combineFlagAndOptionalValue(combine = true) {
809
+ this._combineFlagAndOptionalValue = !!combine;
810
+ return this;
811
+ }
812
+
813
+ /**
814
+ * Allow unknown options on the command line.
815
+ *
816
+ * @param {boolean} [allowUnknown] - if `true` or omitted, no error will be thrown for unknown options.
817
+ * @return {Command} `this` command for chaining
818
+ */
819
+ allowUnknownOption(allowUnknown = true) {
820
+ this._allowUnknownOption = !!allowUnknown;
821
+ return this;
822
+ }
823
+
824
+ /**
825
+ * Allow excess command-arguments on the command line. Pass false to make excess arguments an error.
826
+ *
827
+ * @param {boolean} [allowExcess] - if `true` or omitted, no error will be thrown for excess arguments.
828
+ * @return {Command} `this` command for chaining
829
+ */
830
+ allowExcessArguments(allowExcess = true) {
831
+ this._allowExcessArguments = !!allowExcess;
832
+ return this;
833
+ }
834
+
835
+ /**
836
+ * Enable positional options. Positional means global options are specified before subcommands which lets
837
+ * subcommands reuse the same option names, and also enables subcommands to turn on passThroughOptions.
838
+ * The default behaviour is non-positional and global options may appear anywhere on the command line.
839
+ *
840
+ * @param {boolean} [positional]
841
+ * @return {Command} `this` command for chaining
842
+ */
843
+ enablePositionalOptions(positional = true) {
844
+ this._enablePositionalOptions = !!positional;
845
+ return this;
846
+ }
847
+
848
+ /**
849
+ * Pass through options that come after command-arguments rather than treat them as command-options,
850
+ * so actual command-options come before command-arguments. Turning this on for a subcommand requires
851
+ * positional options to have been enabled on the program (parent commands).
852
+ * The default behaviour is non-positional and options may appear before or after command-arguments.
853
+ *
854
+ * @param {boolean} [passThrough] for unknown options.
855
+ * @return {Command} `this` command for chaining
856
+ */
857
+ passThroughOptions(passThrough = true) {
858
+ this._passThroughOptions = !!passThrough;
859
+ this._checkForBrokenPassThrough();
860
+ return this;
861
+ }
862
+
863
+ /**
864
+ * @private
865
+ */
866
+
867
+ _checkForBrokenPassThrough() {
868
+ if (
869
+ this.parent &&
870
+ this._passThroughOptions &&
871
+ !this.parent._enablePositionalOptions
872
+ ) {
873
+ throw new Error(
874
+ `passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`,
875
+ );
876
+ }
877
+ }
878
+
879
+ /**
880
+ * Whether to store option values as properties on command object,
881
+ * or store separately (specify false). In both cases the option values can be accessed using .opts().
882
+ *
883
+ * @param {boolean} [storeAsProperties=true]
884
+ * @return {Command} `this` command for chaining
885
+ */
886
+
887
+ storeOptionsAsProperties(storeAsProperties = true) {
888
+ if (this.options.length) {
889
+ throw new Error('call .storeOptionsAsProperties() before adding options');
890
+ }
891
+ if (Object.keys(this._optionValues).length) {
892
+ throw new Error(
893
+ 'call .storeOptionsAsProperties() before setting option values',
894
+ );
895
+ }
896
+ this._storeOptionsAsProperties = !!storeAsProperties;
897
+ return this;
898
+ }
899
+
900
+ /**
901
+ * Retrieve option value.
902
+ *
903
+ * @param {string} key
904
+ * @return {object} value
905
+ */
906
+
907
+ getOptionValue(key) {
908
+ if (this._storeOptionsAsProperties) {
909
+ return this[key];
910
+ }
911
+ return this._optionValues[key];
912
+ }
913
+
914
+ /**
915
+ * Store option value.
916
+ *
917
+ * @param {string} key
918
+ * @param {object} value
919
+ * @return {Command} `this` command for chaining
920
+ */
921
+
922
+ setOptionValue(key, value) {
923
+ return this.setOptionValueWithSource(key, value, undefined);
924
+ }
925
+
926
+ /**
927
+ * Store option value and where the value came from.
928
+ *
929
+ * @param {string} key
930
+ * @param {object} value
931
+ * @param {string} source - expected values are default/config/env/cli/implied
932
+ * @return {Command} `this` command for chaining
933
+ */
934
+
935
+ setOptionValueWithSource(key, value, source) {
936
+ if (this._storeOptionsAsProperties) {
937
+ this[key] = value;
938
+ } else {
939
+ this._optionValues[key] = value;
940
+ }
941
+ this._optionValueSources[key] = source;
942
+ return this;
943
+ }
944
+
945
+ /**
946
+ * Get source of option value.
947
+ * Expected values are default | config | env | cli | implied
948
+ *
949
+ * @param {string} key
950
+ * @return {string}
951
+ */
952
+
953
+ getOptionValueSource(key) {
954
+ return this._optionValueSources[key];
955
+ }
956
+
957
+ /**
958
+ * Get source of option value. See also .optsWithGlobals().
959
+ * Expected values are default | config | env | cli | implied
960
+ *
961
+ * @param {string} key
962
+ * @return {string}
963
+ */
964
+
965
+ getOptionValueSourceWithGlobals(key) {
966
+ // global overwrites local, like optsWithGlobals
967
+ let source;
968
+ this._getCommandAndAncestors().forEach((cmd) => {
969
+ if (cmd.getOptionValueSource(key) !== undefined) {
970
+ source = cmd.getOptionValueSource(key);
971
+ }
972
+ });
973
+ return source;
974
+ }
975
+
976
+ /**
977
+ * Get user arguments from implied or explicit arguments.
978
+ * Side-effects: set _scriptPath if args included script. Used for default program name, and subcommand searches.
979
+ *
980
+ * @private
981
+ */
982
+
983
+ _prepareUserArgs(argv, parseOptions) {
984
+ if (argv !== undefined && !Array.isArray(argv)) {
985
+ throw new Error('first parameter to parse must be array or undefined');
986
+ }
987
+ parseOptions = parseOptions || {};
988
+
989
+ // auto-detect argument conventions if nothing supplied
990
+ if (argv === undefined && parseOptions.from === undefined) {
991
+ if (process.versions?.electron) {
992
+ parseOptions.from = 'electron';
993
+ }
994
+ // check node specific options for scenarios where user CLI args follow executable without scriptname
995
+ const execArgv = process.execArgv ?? [];
996
+ if (
997
+ execArgv.includes('-e') ||
998
+ execArgv.includes('--eval') ||
999
+ execArgv.includes('-p') ||
1000
+ execArgv.includes('--print')
1001
+ ) {
1002
+ parseOptions.from = 'eval'; // internal usage, not documented
1003
+ }
1004
+ }
1005
+
1006
+ // default to using process.argv
1007
+ if (argv === undefined) {
1008
+ argv = process.argv;
1009
+ }
1010
+ this.rawArgs = argv.slice();
1011
+
1012
+ // extract the user args and scriptPath
1013
+ let userArgs;
1014
+ switch (parseOptions.from) {
1015
+ case undefined:
1016
+ case 'node':
1017
+ this._scriptPath = argv[1];
1018
+ userArgs = argv.slice(2);
1019
+ break;
1020
+ case 'electron':
1021
+ // @ts-ignore: because defaultApp is an unknown property
1022
+ if (process.defaultApp) {
1023
+ this._scriptPath = argv[1];
1024
+ userArgs = argv.slice(2);
1025
+ } else {
1026
+ userArgs = argv.slice(1);
1027
+ }
1028
+ break;
1029
+ case 'user':
1030
+ userArgs = argv.slice(0);
1031
+ break;
1032
+ case 'eval':
1033
+ userArgs = argv.slice(1);
1034
+ break;
1035
+ default:
1036
+ throw new Error(
1037
+ `unexpected parse option { from: '${parseOptions.from}' }`,
1038
+ );
1039
+ }
1040
+
1041
+ // Find default name for program from arguments.
1042
+ if (!this._name && this._scriptPath)
1043
+ this.nameFromFilename(this._scriptPath);
1044
+ this._name = this._name || 'program';
1045
+
1046
+ return userArgs;
1047
+ }
1048
+
1049
+ /**
1050
+ * Parse `argv`, setting options and invoking commands when defined.
1051
+ *
1052
+ * Use parseAsync instead of parse if any of your action handlers are async.
1053
+ *
1054
+ * Call with no parameters to parse `process.argv`. Detects Electron and special node options like `node --eval`. Easy mode!
1055
+ *
1056
+ * Or call with an array of strings to parse, and optionally where the user arguments start by specifying where the arguments are `from`:
1057
+ * - `'node'`: default, `argv[0]` is the application and `argv[1]` is the script being run, with user arguments after that
1058
+ * - `'electron'`: `argv[0]` is the application and `argv[1]` varies depending on whether the electron application is packaged
1059
+ * - `'user'`: just user arguments
1060
+ *
1061
+ * @example
1062
+ * program.parse(); // parse process.argv and auto-detect electron and special node flags
1063
+ * program.parse(process.argv); // assume argv[0] is app and argv[1] is script
1064
+ * program.parse(my-args, { from: 'user' }); // just user supplied arguments, nothing special about argv[0]
1065
+ *
1066
+ * @param {string[]} [argv] - optional, defaults to process.argv
1067
+ * @param {object} [parseOptions] - optionally specify style of options with from: node/user/electron
1068
+ * @param {string} [parseOptions.from] - where the args are from: 'node', 'user', 'electron'
1069
+ * @return {Command} `this` command for chaining
1070
+ */
1071
+
1072
+ parse(argv, parseOptions) {
1073
+ this._prepareForParse();
1074
+ const userArgs = this._prepareUserArgs(argv, parseOptions);
1075
+ this._parseCommand([], userArgs);
1076
+
1077
+ return this;
1078
+ }
1079
+
1080
+ /**
1081
+ * Parse `argv`, setting options and invoking commands when defined.
1082
+ *
1083
+ * Call with no parameters to parse `process.argv`. Detects Electron and special node options like `node --eval`. Easy mode!
1084
+ *
1085
+ * Or call with an array of strings to parse, and optionally where the user arguments start by specifying where the arguments are `from`:
1086
+ * - `'node'`: default, `argv[0]` is the application and `argv[1]` is the script being run, with user arguments after that
1087
+ * - `'electron'`: `argv[0]` is the application and `argv[1]` varies depending on whether the electron application is packaged
1088
+ * - `'user'`: just user arguments
1089
+ *
1090
+ * @example
1091
+ * await program.parseAsync(); // parse process.argv and auto-detect electron and special node flags
1092
+ * await program.parseAsync(process.argv); // assume argv[0] is app and argv[1] is script
1093
+ * await program.parseAsync(my-args, { from: 'user' }); // just user supplied arguments, nothing special about argv[0]
1094
+ *
1095
+ * @param {string[]} [argv]
1096
+ * @param {object} [parseOptions]
1097
+ * @param {string} parseOptions.from - where the args are from: 'node', 'user', 'electron'
1098
+ * @return {Promise}
1099
+ */
1100
+
1101
+ async parseAsync(argv, parseOptions) {
1102
+ this._prepareForParse();
1103
+ const userArgs = this._prepareUserArgs(argv, parseOptions);
1104
+ await this._parseCommand([], userArgs);
1105
+
1106
+ return this;
1107
+ }
1108
+
1109
+ _prepareForParse() {
1110
+ if (this._savedState === null) {
1111
+ this.saveStateBeforeParse();
1112
+ } else {
1113
+ this.restoreStateBeforeParse();
1114
+ }
1115
+ }
1116
+
1117
+ /**
1118
+ * Called the first time parse is called to save state and allow a restore before subsequent calls to parse.
1119
+ * Not usually called directly, but available for subclasses to save their custom state.
1120
+ *
1121
+ * This is called in a lazy way. Only commands used in parsing chain will have state saved.
1122
+ */
1123
+ saveStateBeforeParse() {
1124
+ this._savedState = {
1125
+ // name is stable if supplied by author, but may be unspecified for root command and deduced during parsing
1126
+ _name: this._name,
1127
+ // option values before parse have default values (including false for negated options)
1128
+ // shallow clones
1129
+ _optionValues: { ...this._optionValues },
1130
+ _optionValueSources: { ...this._optionValueSources },
1131
+ };
1132
+ }
1133
+
1134
+ /**
1135
+ * Restore state before parse for calls after the first.
1136
+ * Not usually called directly, but available for subclasses to save their custom state.
1137
+ *
1138
+ * This is called in a lazy way. Only commands used in parsing chain will have state restored.
1139
+ */
1140
+ restoreStateBeforeParse() {
1141
+ if (this._storeOptionsAsProperties)
1142
+ throw new Error(`Can not call parse again when storeOptionsAsProperties is true.
1143
+ - either make a new Command for each call to parse, or stop storing options as properties`);
1144
+
1145
+ // clear state from _prepareUserArgs
1146
+ this._name = this._savedState._name;
1147
+ this._scriptPath = null;
1148
+ this.rawArgs = [];
1149
+ // clear state from setOptionValueWithSource
1150
+ this._optionValues = { ...this._savedState._optionValues };
1151
+ this._optionValueSources = { ...this._savedState._optionValueSources };
1152
+ // clear state from _parseCommand
1153
+ this.args = [];
1154
+ // clear state from _processArguments
1155
+ this.processedArgs = [];
1156
+ }
1157
+
1158
+ /**
1159
+ * Throw if expected executable is missing. Add lots of help for author.
1160
+ *
1161
+ * @param {string} executableFile
1162
+ * @param {string} executableDir
1163
+ * @param {string} subcommandName
1164
+ */
1165
+ _checkForMissingExecutable(executableFile, executableDir, subcommandName) {
1166
+ if (fs.existsSync(executableFile)) return;
1167
+
1168
+ const executableDirMessage = executableDir
1169
+ ? `searched for local subcommand relative to directory '${executableDir}'`
1170
+ : 'no directory for search for local subcommand, use .executableDir() to supply a custom directory';
1171
+ const executableMissing = `'${executableFile}' does not exist
1172
+ - if '${subcommandName}' is not meant to be an executable command, remove description parameter from '.command()' and use '.description()' instead
1173
+ - if the default executable name is not suitable, use the executableFile option to supply a custom name or path
1174
+ - ${executableDirMessage}`;
1175
+ throw new Error(executableMissing);
1176
+ }
1177
+
1178
+ /**
1179
+ * Execute a sub-command executable.
1180
+ *
1181
+ * @private
1182
+ */
1183
+
1184
+ _executeSubCommand(subcommand, args) {
1185
+ args = args.slice();
1186
+ let launchWithNode = false; // Use node for source targets so do not need to get permissions correct, and on Windows.
1187
+ const sourceExt = ['.js', '.ts', '.tsx', '.mjs', '.cjs'];
1188
+
1189
+ function findFile(baseDir, baseName) {
1190
+ // Look for specified file
1191
+ const localBin = path.resolve(baseDir, baseName);
1192
+ if (fs.existsSync(localBin)) return localBin;
1193
+
1194
+ // Stop looking if candidate already has an expected extension.
1195
+ if (sourceExt.includes(path.extname(baseName))) return undefined;
1196
+
1197
+ // Try all the extensions.
1198
+ const foundExt = sourceExt.find((ext) =>
1199
+ fs.existsSync(`${localBin}${ext}`),
1200
+ );
1201
+ if (foundExt) return `${localBin}${foundExt}`;
1202
+
1203
+ return undefined;
1204
+ }
1205
+
1206
+ // Not checking for help first. Unlikely to have mandatory and executable, and can't robustly test for help flags in external command.
1207
+ this._checkForMissingMandatoryOptions();
1208
+ this._checkForConflictingOptions();
1209
+
1210
+ // executableFile and executableDir might be full path, or just a name
1211
+ let executableFile =
1212
+ subcommand._executableFile || `${this._name}-${subcommand._name}`;
1213
+ let executableDir = this._executableDir || '';
1214
+ if (this._scriptPath) {
1215
+ let resolvedScriptPath; // resolve possible symlink for installed npm binary
1216
+ try {
1217
+ resolvedScriptPath = fs.realpathSync(this._scriptPath);
1218
+ } catch {
1219
+ resolvedScriptPath = this._scriptPath;
1220
+ }
1221
+ executableDir = path.resolve(
1222
+ path.dirname(resolvedScriptPath),
1223
+ executableDir,
1224
+ );
1225
+ }
1226
+
1227
+ // Look for a local file in preference to a command in PATH.
1228
+ if (executableDir) {
1229
+ let localFile = findFile(executableDir, executableFile);
1230
+
1231
+ // Legacy search using prefix of script name instead of command name
1232
+ if (!localFile && !subcommand._executableFile && this._scriptPath) {
1233
+ const legacyName = path.basename(
1234
+ this._scriptPath,
1235
+ path.extname(this._scriptPath),
1236
+ );
1237
+ if (legacyName !== this._name) {
1238
+ localFile = findFile(
1239
+ executableDir,
1240
+ `${legacyName}-${subcommand._name}`,
1241
+ );
1242
+ }
1243
+ }
1244
+ executableFile = localFile || executableFile;
1245
+ }
1246
+
1247
+ launchWithNode = sourceExt.includes(path.extname(executableFile));
1248
+
1249
+ let proc;
1250
+ if (process.platform !== 'win32') {
1251
+ if (launchWithNode) {
1252
+ args.unshift(executableFile);
1253
+ // add executable arguments to spawn
1254
+ args = incrementNodeInspectorPort(process.execArgv).concat(args);
1255
+
1256
+ proc = childProcess.spawn(process.argv[0], args, { stdio: 'inherit' });
1257
+ } else {
1258
+ proc = childProcess.spawn(executableFile, args, { stdio: 'inherit' });
1259
+ }
1260
+ } else {
1261
+ this._checkForMissingExecutable(
1262
+ executableFile,
1263
+ executableDir,
1264
+ subcommand._name,
1265
+ );
1266
+ args.unshift(executableFile);
1267
+ // add executable arguments to spawn
1268
+ args = incrementNodeInspectorPort(process.execArgv).concat(args);
1269
+ proc = childProcess.spawn(process.execPath, args, { stdio: 'inherit' });
1270
+ }
1271
+
1272
+ if (!proc.killed) {
1273
+ // testing mainly to avoid leak warnings during unit tests with mocked spawn
1274
+ const signals = ['SIGUSR1', 'SIGUSR2', 'SIGTERM', 'SIGINT', 'SIGHUP'];
1275
+ signals.forEach((signal) => {
1276
+ process.on(signal, () => {
1277
+ if (proc.killed === false && proc.exitCode === null) {
1278
+ // @ts-ignore because signals not typed to known strings
1279
+ proc.kill(signal);
1280
+ }
1281
+ });
1282
+ });
1283
+ }
1284
+
1285
+ // By default terminate process when spawned process terminates.
1286
+ const exitCallback = this._exitCallback;
1287
+ proc.on('close', (code) => {
1288
+ code = code ?? 1; // code is null if spawned process terminated due to a signal
1289
+ if (!exitCallback) {
1290
+ process.exit(code);
1291
+ } else {
1292
+ exitCallback(
1293
+ new CommanderError(
1294
+ code,
1295
+ 'commander.executeSubCommandAsync',
1296
+ '(close)',
1297
+ ),
1298
+ );
1299
+ }
1300
+ });
1301
+ proc.on('error', (err) => {
1302
+ // @ts-ignore: because err.code is an unknown property
1303
+ if (err.code === 'ENOENT') {
1304
+ this._checkForMissingExecutable(
1305
+ executableFile,
1306
+ executableDir,
1307
+ subcommand._name,
1308
+ );
1309
+ // @ts-ignore: because err.code is an unknown property
1310
+ } else if (err.code === 'EACCES') {
1311
+ throw new Error(`'${executableFile}' not executable`);
1312
+ }
1313
+ if (!exitCallback) {
1314
+ process.exit(1);
1315
+ } else {
1316
+ const wrappedError = new CommanderError(
1317
+ 1,
1318
+ 'commander.executeSubCommandAsync',
1319
+ '(error)',
1320
+ );
1321
+ wrappedError.nestedError = err;
1322
+ exitCallback(wrappedError);
1323
+ }
1324
+ });
1325
+
1326
+ // Store the reference to the child process
1327
+ this.runningCommand = proc;
1328
+ }
1329
+
1330
+ /**
1331
+ * @private
1332
+ */
1333
+
1334
+ _dispatchSubcommand(commandName, operands, unknown) {
1335
+ const subCommand = this._findCommand(commandName);
1336
+ if (!subCommand) this.help({ error: true });
1337
+
1338
+ subCommand._prepareForParse();
1339
+ let promiseChain;
1340
+ promiseChain = this._chainOrCallSubCommandHook(
1341
+ promiseChain,
1342
+ subCommand,
1343
+ 'preSubcommand',
1344
+ );
1345
+ promiseChain = this._chainOrCall(promiseChain, () => {
1346
+ if (subCommand._executableHandler) {
1347
+ this._executeSubCommand(subCommand, operands.concat(unknown));
1348
+ } else {
1349
+ return subCommand._parseCommand(operands, unknown);
1350
+ }
1351
+ });
1352
+ return promiseChain;
1353
+ }
1354
+
1355
+ /**
1356
+ * Invoke help directly if possible, or dispatch if necessary.
1357
+ * e.g. help foo
1358
+ *
1359
+ * @private
1360
+ */
1361
+
1362
+ _dispatchHelpCommand(subcommandName) {
1363
+ if (!subcommandName) {
1364
+ this.help();
1365
+ }
1366
+ const subCommand = this._findCommand(subcommandName);
1367
+ if (subCommand && !subCommand._executableHandler) {
1368
+ subCommand.help();
1369
+ }
1370
+
1371
+ // Fallback to parsing the help flag to invoke the help.
1372
+ return this._dispatchSubcommand(
1373
+ subcommandName,
1374
+ [],
1375
+ [this._getHelpOption()?.long ?? this._getHelpOption()?.short ?? '--help'],
1376
+ );
1377
+ }
1378
+
1379
+ /**
1380
+ * Check this.args against expected this.registeredArguments.
1381
+ *
1382
+ * @private
1383
+ */
1384
+
1385
+ _checkNumberOfArguments() {
1386
+ // too few
1387
+ this.registeredArguments.forEach((arg, i) => {
1388
+ if (arg.required && this.args[i] == null) {
1389
+ this.missingArgument(arg.name());
1390
+ }
1391
+ });
1392
+ // too many
1393
+ if (
1394
+ this.registeredArguments.length > 0 &&
1395
+ this.registeredArguments[this.registeredArguments.length - 1].variadic
1396
+ ) {
1397
+ return;
1398
+ }
1399
+ if (this.args.length > this.registeredArguments.length) {
1400
+ this._excessArguments(this.args);
1401
+ }
1402
+ }
1403
+
1404
+ /**
1405
+ * Process this.args using this.registeredArguments and save as this.processedArgs!
1406
+ *
1407
+ * @private
1408
+ */
1409
+
1410
+ _processArguments() {
1411
+ const myParseArg = (argument, value, previous) => {
1412
+ // Extra processing for nice error message on parsing failure.
1413
+ let parsedValue = value;
1414
+ if (value !== null && argument.parseArg) {
1415
+ const invalidValueMessage = `error: command-argument value '${value}' is invalid for argument '${argument.name()}'.`;
1416
+ parsedValue = this._callParseArg(
1417
+ argument,
1418
+ value,
1419
+ previous,
1420
+ invalidValueMessage,
1421
+ );
1422
+ }
1423
+ return parsedValue;
1424
+ };
1425
+
1426
+ this._checkNumberOfArguments();
1427
+
1428
+ const processedArgs = [];
1429
+ this.registeredArguments.forEach((declaredArg, index) => {
1430
+ let value = declaredArg.defaultValue;
1431
+ if (declaredArg.variadic) {
1432
+ // Collect together remaining arguments for passing together as an array.
1433
+ if (index < this.args.length) {
1434
+ value = this.args.slice(index);
1435
+ if (declaredArg.parseArg) {
1436
+ value = value.reduce((processed, v) => {
1437
+ return myParseArg(declaredArg, v, processed);
1438
+ }, declaredArg.defaultValue);
1439
+ }
1440
+ } else if (value === undefined) {
1441
+ value = [];
1442
+ }
1443
+ } else if (index < this.args.length) {
1444
+ value = this.args[index];
1445
+ if (declaredArg.parseArg) {
1446
+ value = myParseArg(declaredArg, value, declaredArg.defaultValue);
1447
+ }
1448
+ }
1449
+ processedArgs[index] = value;
1450
+ });
1451
+ this.processedArgs = processedArgs;
1452
+ }
1453
+
1454
+ /**
1455
+ * Once we have a promise we chain, but call synchronously until then.
1456
+ *
1457
+ * @param {(Promise|undefined)} promise
1458
+ * @param {Function} fn
1459
+ * @return {(Promise|undefined)}
1460
+ * @private
1461
+ */
1462
+
1463
+ _chainOrCall(promise, fn) {
1464
+ // thenable
1465
+ if (promise && promise.then && typeof promise.then === 'function') {
1466
+ // already have a promise, chain callback
1467
+ return promise.then(() => fn());
1468
+ }
1469
+ // callback might return a promise
1470
+ return fn();
1471
+ }
1472
+
1473
+ /**
1474
+ *
1475
+ * @param {(Promise|undefined)} promise
1476
+ * @param {string} event
1477
+ * @return {(Promise|undefined)}
1478
+ * @private
1479
+ */
1480
+
1481
+ _chainOrCallHooks(promise, event) {
1482
+ let result = promise;
1483
+ const hooks = [];
1484
+ this._getCommandAndAncestors()
1485
+ .reverse()
1486
+ .filter((cmd) => cmd._lifeCycleHooks[event] !== undefined)
1487
+ .forEach((hookedCommand) => {
1488
+ hookedCommand._lifeCycleHooks[event].forEach((callback) => {
1489
+ hooks.push({ hookedCommand, callback });
1490
+ });
1491
+ });
1492
+ if (event === 'postAction') {
1493
+ hooks.reverse();
1494
+ }
1495
+
1496
+ hooks.forEach((hookDetail) => {
1497
+ result = this._chainOrCall(result, () => {
1498
+ return hookDetail.callback(hookDetail.hookedCommand, this);
1499
+ });
1500
+ });
1501
+ return result;
1502
+ }
1503
+
1504
+ /**
1505
+ *
1506
+ * @param {(Promise|undefined)} promise
1507
+ * @param {Command} subCommand
1508
+ * @param {string} event
1509
+ * @return {(Promise|undefined)}
1510
+ * @private
1511
+ */
1512
+
1513
+ _chainOrCallSubCommandHook(promise, subCommand, event) {
1514
+ let result = promise;
1515
+ if (this._lifeCycleHooks[event] !== undefined) {
1516
+ this._lifeCycleHooks[event].forEach((hook) => {
1517
+ result = this._chainOrCall(result, () => {
1518
+ return hook(this, subCommand);
1519
+ });
1520
+ });
1521
+ }
1522
+ return result;
1523
+ }
1524
+
1525
+ /**
1526
+ * Process arguments in context of this command.
1527
+ * Returns action result, in case it is a promise.
1528
+ *
1529
+ * @private
1530
+ */
1531
+
1532
+ _parseCommand(operands, unknown) {
1533
+ const parsed = this.parseOptions(unknown);
1534
+ this._parseOptionsEnv(); // after cli, so parseArg not called on both cli and env
1535
+ this._parseOptionsImplied();
1536
+ operands = operands.concat(parsed.operands);
1537
+ unknown = parsed.unknown;
1538
+ this.args = operands.concat(unknown);
1539
+
1540
+ if (operands && this._findCommand(operands[0])) {
1541
+ return this._dispatchSubcommand(operands[0], operands.slice(1), unknown);
1542
+ }
1543
+ if (
1544
+ this._getHelpCommand() &&
1545
+ operands[0] === this._getHelpCommand().name()
1546
+ ) {
1547
+ return this._dispatchHelpCommand(operands[1]);
1548
+ }
1549
+ if (this._defaultCommandName) {
1550
+ this._outputHelpIfRequested(unknown); // Run the help for default command from parent rather than passing to default command
1551
+ return this._dispatchSubcommand(
1552
+ this._defaultCommandName,
1553
+ operands,
1554
+ unknown,
1555
+ );
1556
+ }
1557
+ if (
1558
+ this.commands.length &&
1559
+ this.args.length === 0 &&
1560
+ !this._actionHandler &&
1561
+ !this._defaultCommandName
1562
+ ) {
1563
+ // probably missing subcommand and no handler, user needs help (and exit)
1564
+ this.help({ error: true });
1565
+ }
1566
+
1567
+ this._outputHelpIfRequested(parsed.unknown);
1568
+ this._checkForMissingMandatoryOptions();
1569
+ this._checkForConflictingOptions();
1570
+
1571
+ // We do not always call this check to avoid masking a "better" error, like unknown command.
1572
+ const checkForUnknownOptions = () => {
1573
+ if (parsed.unknown.length > 0) {
1574
+ this.unknownOption(parsed.unknown[0]);
1575
+ }
1576
+ };
1577
+
1578
+ const commandEvent = `command:${this.name()}`;
1579
+ if (this._actionHandler) {
1580
+ checkForUnknownOptions();
1581
+ this._processArguments();
1582
+
1583
+ let promiseChain;
1584
+ promiseChain = this._chainOrCallHooks(promiseChain, 'preAction');
1585
+ promiseChain = this._chainOrCall(promiseChain, () =>
1586
+ this._actionHandler(this.processedArgs),
1587
+ );
1588
+ if (this.parent) {
1589
+ promiseChain = this._chainOrCall(promiseChain, () => {
1590
+ this.parent.emit(commandEvent, operands, unknown); // legacy
1591
+ });
1592
+ }
1593
+ promiseChain = this._chainOrCallHooks(promiseChain, 'postAction');
1594
+ return promiseChain;
1595
+ }
1596
+ if (this.parent && this.parent.listenerCount(commandEvent)) {
1597
+ checkForUnknownOptions();
1598
+ this._processArguments();
1599
+ this.parent.emit(commandEvent, operands, unknown); // legacy
1600
+ } else if (operands.length) {
1601
+ if (this._findCommand('*')) {
1602
+ // legacy default command
1603
+ return this._dispatchSubcommand('*', operands, unknown);
1604
+ }
1605
+ if (this.listenerCount('command:*')) {
1606
+ // skip option check, emit event for possible misspelling suggestion
1607
+ this.emit('command:*', operands, unknown);
1608
+ } else if (this.commands.length) {
1609
+ this.unknownCommand();
1610
+ } else {
1611
+ checkForUnknownOptions();
1612
+ this._processArguments();
1613
+ }
1614
+ } else if (this.commands.length) {
1615
+ checkForUnknownOptions();
1616
+ // This command has subcommands and nothing hooked up at this level, so display help (and exit).
1617
+ this.help({ error: true });
1618
+ } else {
1619
+ checkForUnknownOptions();
1620
+ this._processArguments();
1621
+ // fall through for caller to handle after calling .parse()
1622
+ }
1623
+ }
1624
+
1625
+ /**
1626
+ * Find matching command.
1627
+ *
1628
+ * @private
1629
+ * @return {Command | undefined}
1630
+ */
1631
+ _findCommand(name) {
1632
+ if (!name) return undefined;
1633
+ return this.commands.find(
1634
+ (cmd) => cmd._name === name || cmd._aliases.includes(name),
1635
+ );
1636
+ }
1637
+
1638
+ /**
1639
+ * Return an option matching `arg` if any.
1640
+ *
1641
+ * @param {string} arg
1642
+ * @return {Option}
1643
+ * @package
1644
+ */
1645
+
1646
+ _findOption(arg) {
1647
+ return this.options.find((option) => option.is(arg));
1648
+ }
1649
+
1650
+ /**
1651
+ * Display an error message if a mandatory option does not have a value.
1652
+ * Called after checking for help flags in leaf subcommand.
1653
+ *
1654
+ * @private
1655
+ */
1656
+
1657
+ _checkForMissingMandatoryOptions() {
1658
+ // Walk up hierarchy so can call in subcommand after checking for displaying help.
1659
+ this._getCommandAndAncestors().forEach((cmd) => {
1660
+ cmd.options.forEach((anOption) => {
1661
+ if (
1662
+ anOption.mandatory &&
1663
+ cmd.getOptionValue(anOption.attributeName()) === undefined
1664
+ ) {
1665
+ cmd.missingMandatoryOptionValue(anOption);
1666
+ }
1667
+ });
1668
+ });
1669
+ }
1670
+
1671
+ /**
1672
+ * Display an error message if conflicting options are used together in this.
1673
+ *
1674
+ * @private
1675
+ */
1676
+ _checkForConflictingLocalOptions() {
1677
+ const definedNonDefaultOptions = this.options.filter((option) => {
1678
+ const optionKey = option.attributeName();
1679
+ if (this.getOptionValue(optionKey) === undefined) {
1680
+ return false;
1681
+ }
1682
+ return this.getOptionValueSource(optionKey) !== 'default';
1683
+ });
1684
+
1685
+ const optionsWithConflicting = definedNonDefaultOptions.filter(
1686
+ (option) => option.conflictsWith.length > 0,
1687
+ );
1688
+
1689
+ optionsWithConflicting.forEach((option) => {
1690
+ const conflictingAndDefined = definedNonDefaultOptions.find((defined) =>
1691
+ option.conflictsWith.includes(defined.attributeName()),
1692
+ );
1693
+ if (conflictingAndDefined) {
1694
+ this._conflictingOption(option, conflictingAndDefined);
1695
+ }
1696
+ });
1697
+ }
1698
+
1699
+ /**
1700
+ * Display an error message if conflicting options are used together.
1701
+ * Called after checking for help flags in leaf subcommand.
1702
+ *
1703
+ * @private
1704
+ */
1705
+ _checkForConflictingOptions() {
1706
+ // Walk up hierarchy so can call in subcommand after checking for displaying help.
1707
+ this._getCommandAndAncestors().forEach((cmd) => {
1708
+ cmd._checkForConflictingLocalOptions();
1709
+ });
1710
+ }
1711
+
1712
+ /**
1713
+ * Parse options from `argv` removing known options,
1714
+ * and return argv split into operands and unknown arguments.
1715
+ *
1716
+ * Side effects: modifies command by storing options. Does not reset state if called again.
1717
+ *
1718
+ * Examples:
1719
+ *
1720
+ * argv => operands, unknown
1721
+ * --known kkk op => [op], []
1722
+ * op --known kkk => [op], []
1723
+ * sub --unknown uuu op => [sub], [--unknown uuu op]
1724
+ * sub -- --unknown uuu op => [sub --unknown uuu op], []
1725
+ *
1726
+ * @param {string[]} argv
1727
+ * @return {{operands: string[], unknown: string[]}}
1728
+ */
1729
+
1730
+ parseOptions(argv) {
1731
+ const operands = []; // operands, not options or values
1732
+ const unknown = []; // first unknown option and remaining unknown args
1733
+ let dest = operands;
1734
+ const args = argv.slice();
1735
+
1736
+ function maybeOption(arg) {
1737
+ return arg.length > 1 && arg[0] === '-';
1738
+ }
1739
+
1740
+ // parse options
1741
+ let activeVariadicOption = null;
1742
+ while (args.length) {
1743
+ const arg = args.shift();
1744
+
1745
+ // literal
1746
+ if (arg === '--') {
1747
+ if (dest === unknown) dest.push(arg);
1748
+ dest.push(...args);
1749
+ break;
1750
+ }
1751
+
1752
+ if (activeVariadicOption && !maybeOption(arg)) {
1753
+ this.emit(`option:${activeVariadicOption.name()}`, arg);
1754
+ continue;
1755
+ }
1756
+ activeVariadicOption = null;
1757
+
1758
+ if (maybeOption(arg)) {
1759
+ const option = this._findOption(arg);
1760
+ // recognised option, call listener to assign value with possible custom processing
1761
+ if (option) {
1762
+ if (option.required) {
1763
+ const value = args.shift();
1764
+ if (value === undefined) this.optionMissingArgument(option);
1765
+ this.emit(`option:${option.name()}`, value);
1766
+ } else if (option.optional) {
1767
+ let value = null;
1768
+ // historical behaviour is optional value is following arg unless an option
1769
+ if (args.length > 0 && !maybeOption(args[0])) {
1770
+ value = args.shift();
1771
+ }
1772
+ this.emit(`option:${option.name()}`, value);
1773
+ } else {
1774
+ // boolean flag
1775
+ this.emit(`option:${option.name()}`);
1776
+ }
1777
+ activeVariadicOption = option.variadic ? option : null;
1778
+ continue;
1779
+ }
1780
+ }
1781
+
1782
+ // Look for combo options following single dash, eat first one if known.
1783
+ if (arg.length > 2 && arg[0] === '-' && arg[1] !== '-') {
1784
+ const option = this._findOption(`-${arg[1]}`);
1785
+ if (option) {
1786
+ if (
1787
+ option.required ||
1788
+ (option.optional && this._combineFlagAndOptionalValue)
1789
+ ) {
1790
+ // option with value following in same argument
1791
+ this.emit(`option:${option.name()}`, arg.slice(2));
1792
+ } else {
1793
+ // boolean option, emit and put back remainder of arg for further processing
1794
+ this.emit(`option:${option.name()}`);
1795
+ args.unshift(`-${arg.slice(2)}`);
1796
+ }
1797
+ continue;
1798
+ }
1799
+ }
1800
+
1801
+ // Look for known long flag with value, like --foo=bar
1802
+ if (/^--[^=]+=/.test(arg)) {
1803
+ const index = arg.indexOf('=');
1804
+ const option = this._findOption(arg.slice(0, index));
1805
+ if (option && (option.required || option.optional)) {
1806
+ this.emit(`option:${option.name()}`, arg.slice(index + 1));
1807
+ continue;
1808
+ }
1809
+ }
1810
+
1811
+ // Not a recognised option by this command.
1812
+ // Might be a command-argument, or subcommand option, or unknown option, or help command or option.
1813
+
1814
+ // An unknown option means further arguments also classified as unknown so can be reprocessed by subcommands.
1815
+ if (maybeOption(arg)) {
1816
+ dest = unknown;
1817
+ }
1818
+
1819
+ // If using positionalOptions, stop processing our options at subcommand.
1820
+ if (
1821
+ (this._enablePositionalOptions || this._passThroughOptions) &&
1822
+ operands.length === 0 &&
1823
+ unknown.length === 0
1824
+ ) {
1825
+ if (this._findCommand(arg)) {
1826
+ operands.push(arg);
1827
+ if (args.length > 0) unknown.push(...args);
1828
+ break;
1829
+ } else if (
1830
+ this._getHelpCommand() &&
1831
+ arg === this._getHelpCommand().name()
1832
+ ) {
1833
+ operands.push(arg);
1834
+ if (args.length > 0) operands.push(...args);
1835
+ break;
1836
+ } else if (this._defaultCommandName) {
1837
+ unknown.push(arg);
1838
+ if (args.length > 0) unknown.push(...args);
1839
+ break;
1840
+ }
1841
+ }
1842
+
1843
+ // If using passThroughOptions, stop processing options at first command-argument.
1844
+ if (this._passThroughOptions) {
1845
+ dest.push(arg);
1846
+ if (args.length > 0) dest.push(...args);
1847
+ break;
1848
+ }
1849
+
1850
+ // add arg
1851
+ dest.push(arg);
1852
+ }
1853
+
1854
+ return { operands, unknown };
1855
+ }
1856
+
1857
+ /**
1858
+ * Return an object containing local option values as key-value pairs.
1859
+ *
1860
+ * @return {object}
1861
+ */
1862
+ opts() {
1863
+ if (this._storeOptionsAsProperties) {
1864
+ // Preserve original behaviour so backwards compatible when still using properties
1865
+ const result = {};
1866
+ const len = this.options.length;
1867
+
1868
+ for (let i = 0; i < len; i++) {
1869
+ const key = this.options[i].attributeName();
1870
+ result[key] =
1871
+ key === this._versionOptionName ? this._version : this[key];
1872
+ }
1873
+ return result;
1874
+ }
1875
+
1876
+ return this._optionValues;
1877
+ }
1878
+
1879
+ /**
1880
+ * Return an object containing merged local and global option values as key-value pairs.
1881
+ *
1882
+ * @return {object}
1883
+ */
1884
+ optsWithGlobals() {
1885
+ // globals overwrite locals
1886
+ return this._getCommandAndAncestors().reduce(
1887
+ (combinedOptions, cmd) => Object.assign(combinedOptions, cmd.opts()),
1888
+ {},
1889
+ );
1890
+ }
1891
+
1892
+ /**
1893
+ * Display error message and exit (or call exitOverride).
1894
+ *
1895
+ * @param {string} message
1896
+ * @param {object} [errorOptions]
1897
+ * @param {string} [errorOptions.code] - an id string representing the error
1898
+ * @param {number} [errorOptions.exitCode] - used with process.exit
1899
+ */
1900
+ error(message, errorOptions) {
1901
+ // output handling
1902
+ this._outputConfiguration.outputError(
1903
+ `${message}\n`,
1904
+ this._outputConfiguration.writeErr,
1905
+ );
1906
+ if (typeof this._showHelpAfterError === 'string') {
1907
+ this._outputConfiguration.writeErr(`${this._showHelpAfterError}\n`);
1908
+ } else if (this._showHelpAfterError) {
1909
+ this._outputConfiguration.writeErr('\n');
1910
+ this.outputHelp({ error: true });
1911
+ }
1912
+
1913
+ // exit handling
1914
+ const config = errorOptions || {};
1915
+ const exitCode = config.exitCode || 1;
1916
+ const code = config.code || 'commander.error';
1917
+ this._exit(exitCode, code, message);
1918
+ }
1919
+
1920
+ /**
1921
+ * Apply any option related environment variables, if option does
1922
+ * not have a value from cli or client code.
1923
+ *
1924
+ * @private
1925
+ */
1926
+ _parseOptionsEnv() {
1927
+ this.options.forEach((option) => {
1928
+ if (option.envVar && option.envVar in process.env) {
1929
+ const optionKey = option.attributeName();
1930
+ // Priority check. Do not overwrite cli or options from unknown source (client-code).
1931
+ if (
1932
+ this.getOptionValue(optionKey) === undefined ||
1933
+ ['default', 'config', 'env'].includes(
1934
+ this.getOptionValueSource(optionKey),
1935
+ )
1936
+ ) {
1937
+ if (option.required || option.optional) {
1938
+ // option can take a value
1939
+ // keep very simple, optional always takes value
1940
+ this.emit(`optionEnv:${option.name()}`, process.env[option.envVar]);
1941
+ } else {
1942
+ // boolean
1943
+ // keep very simple, only care that envVar defined and not the value
1944
+ this.emit(`optionEnv:${option.name()}`);
1945
+ }
1946
+ }
1947
+ }
1948
+ });
1949
+ }
1950
+
1951
+ /**
1952
+ * Apply any implied option values, if option is undefined or default value.
1953
+ *
1954
+ * @private
1955
+ */
1956
+ _parseOptionsImplied() {
1957
+ const dualHelper = new DualOptions(this.options);
1958
+ const hasCustomOptionValue = (optionKey) => {
1959
+ return (
1960
+ this.getOptionValue(optionKey) !== undefined &&
1961
+ !['default', 'implied'].includes(this.getOptionValueSource(optionKey))
1962
+ );
1963
+ };
1964
+ this.options
1965
+ .filter(
1966
+ (option) =>
1967
+ option.implied !== undefined &&
1968
+ hasCustomOptionValue(option.attributeName()) &&
1969
+ dualHelper.valueFromOption(
1970
+ this.getOptionValue(option.attributeName()),
1971
+ option,
1972
+ ),
1973
+ )
1974
+ .forEach((option) => {
1975
+ Object.keys(option.implied)
1976
+ .filter((impliedKey) => !hasCustomOptionValue(impliedKey))
1977
+ .forEach((impliedKey) => {
1978
+ this.setOptionValueWithSource(
1979
+ impliedKey,
1980
+ option.implied[impliedKey],
1981
+ 'implied',
1982
+ );
1983
+ });
1984
+ });
1985
+ }
1986
+
1987
+ /**
1988
+ * Argument `name` is missing.
1989
+ *
1990
+ * @param {string} name
1991
+ * @private
1992
+ */
1993
+
1994
+ missingArgument(name) {
1995
+ const message = `error: missing required argument '${name}'`;
1996
+ this.error(message, { code: 'commander.missingArgument' });
1997
+ }
1998
+
1999
+ /**
2000
+ * `Option` is missing an argument.
2001
+ *
2002
+ * @param {Option} option
2003
+ * @private
2004
+ */
2005
+
2006
+ optionMissingArgument(option) {
2007
+ const message = `error: option '${option.flags}' argument missing`;
2008
+ this.error(message, { code: 'commander.optionMissingArgument' });
2009
+ }
2010
+
2011
+ /**
2012
+ * `Option` does not have a value, and is a mandatory option.
2013
+ *
2014
+ * @param {Option} option
2015
+ * @private
2016
+ */
2017
+
2018
+ missingMandatoryOptionValue(option) {
2019
+ const message = `error: required option '${option.flags}' not specified`;
2020
+ this.error(message, { code: 'commander.missingMandatoryOptionValue' });
2021
+ }
2022
+
2023
+ /**
2024
+ * `Option` conflicts with another option.
2025
+ *
2026
+ * @param {Option} option
2027
+ * @param {Option} conflictingOption
2028
+ * @private
2029
+ */
2030
+ _conflictingOption(option, conflictingOption) {
2031
+ // The calling code does not know whether a negated option is the source of the
2032
+ // value, so do some work to take an educated guess.
2033
+ const findBestOptionFromValue = (option) => {
2034
+ const optionKey = option.attributeName();
2035
+ const optionValue = this.getOptionValue(optionKey);
2036
+ const negativeOption = this.options.find(
2037
+ (target) => target.negate && optionKey === target.attributeName(),
2038
+ );
2039
+ const positiveOption = this.options.find(
2040
+ (target) => !target.negate && optionKey === target.attributeName(),
2041
+ );
2042
+ if (
2043
+ negativeOption &&
2044
+ ((negativeOption.presetArg === undefined && optionValue === false) ||
2045
+ (negativeOption.presetArg !== undefined &&
2046
+ optionValue === negativeOption.presetArg))
2047
+ ) {
2048
+ return negativeOption;
2049
+ }
2050
+ return positiveOption || option;
2051
+ };
2052
+
2053
+ const getErrorMessage = (option) => {
2054
+ const bestOption = findBestOptionFromValue(option);
2055
+ const optionKey = bestOption.attributeName();
2056
+ const source = this.getOptionValueSource(optionKey);
2057
+ if (source === 'env') {
2058
+ return `environment variable '${bestOption.envVar}'`;
2059
+ }
2060
+ return `option '${bestOption.flags}'`;
2061
+ };
2062
+
2063
+ const message = `error: ${getErrorMessage(option)} cannot be used with ${getErrorMessage(conflictingOption)}`;
2064
+ this.error(message, { code: 'commander.conflictingOption' });
2065
+ }
2066
+
2067
+ /**
2068
+ * Unknown option `flag`.
2069
+ *
2070
+ * @param {string} flag
2071
+ * @private
2072
+ */
2073
+
2074
+ unknownOption(flag) {
2075
+ if (this._allowUnknownOption) return;
2076
+ let suggestion = '';
2077
+
2078
+ if (flag.startsWith('--') && this._showSuggestionAfterError) {
2079
+ // Looping to pick up the global options too
2080
+ let candidateFlags = [];
2081
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
2082
+ let command = this;
2083
+ do {
2084
+ const moreFlags = command
2085
+ .createHelp()
2086
+ .visibleOptions(command)
2087
+ .filter((option) => option.long)
2088
+ .map((option) => option.long);
2089
+ candidateFlags = candidateFlags.concat(moreFlags);
2090
+ command = command.parent;
2091
+ } while (command && !command._enablePositionalOptions);
2092
+ suggestion = suggestSimilar(flag, candidateFlags);
2093
+ }
2094
+
2095
+ const message = `error: unknown option '${flag}'${suggestion}`;
2096
+ this.error(message, { code: 'commander.unknownOption' });
2097
+ }
2098
+
2099
+ /**
2100
+ * Excess arguments, more than expected.
2101
+ *
2102
+ * @param {string[]} receivedArgs
2103
+ * @private
2104
+ */
2105
+
2106
+ _excessArguments(receivedArgs) {
2107
+ if (this._allowExcessArguments) return;
2108
+
2109
+ const expected = this.registeredArguments.length;
2110
+ const s = expected === 1 ? '' : 's';
2111
+ const forSubcommand = this.parent ? ` for '${this.name()}'` : '';
2112
+ const message = `error: too many arguments${forSubcommand}. Expected ${expected} argument${s} but got ${receivedArgs.length}.`;
2113
+ this.error(message, { code: 'commander.excessArguments' });
2114
+ }
2115
+
2116
+ /**
2117
+ * Unknown command.
2118
+ *
2119
+ * @private
2120
+ */
2121
+
2122
+ unknownCommand() {
2123
+ const unknownName = this.args[0];
2124
+ let suggestion = '';
2125
+
2126
+ if (this._showSuggestionAfterError) {
2127
+ const candidateNames = [];
2128
+ this.createHelp()
2129
+ .visibleCommands(this)
2130
+ .forEach((command) => {
2131
+ candidateNames.push(command.name());
2132
+ // just visible alias
2133
+ if (command.alias()) candidateNames.push(command.alias());
2134
+ });
2135
+ suggestion = suggestSimilar(unknownName, candidateNames);
2136
+ }
2137
+
2138
+ const message = `error: unknown command '${unknownName}'${suggestion}`;
2139
+ this.error(message, { code: 'commander.unknownCommand' });
2140
+ }
2141
+
2142
+ /**
2143
+ * Get or set the program version.
2144
+ *
2145
+ * This method auto-registers the "-V, --version" option which will print the version number.
2146
+ *
2147
+ * You can optionally supply the flags and description to override the defaults.
2148
+ *
2149
+ * @param {string} [str]
2150
+ * @param {string} [flags]
2151
+ * @param {string} [description]
2152
+ * @return {(this | string | undefined)} `this` command for chaining, or version string if no arguments
2153
+ */
2154
+
2155
+ version(str, flags, description) {
2156
+ if (str === undefined) return this._version;
2157
+ this._version = str;
2158
+ flags = flags || '-V, --version';
2159
+ description = description || 'output the version number';
2160
+ const versionOption = this.createOption(flags, description);
2161
+ this._versionOptionName = versionOption.attributeName();
2162
+ this._registerOption(versionOption);
2163
+
2164
+ this.on('option:' + versionOption.name(), () => {
2165
+ this._outputConfiguration.writeOut(`${str}\n`);
2166
+ this._exit(0, 'commander.version', str);
2167
+ });
2168
+ return this;
2169
+ }
2170
+
2171
+ /**
2172
+ * Set the description.
2173
+ *
2174
+ * @param {string} [str]
2175
+ * @param {object} [argsDescription]
2176
+ * @return {(string|Command)}
2177
+ */
2178
+ description(str, argsDescription) {
2179
+ if (str === undefined && argsDescription === undefined)
2180
+ return this._description;
2181
+ this._description = str;
2182
+ if (argsDescription) {
2183
+ this._argsDescription = argsDescription;
2184
+ }
2185
+ return this;
2186
+ }
2187
+
2188
+ /**
2189
+ * Set the summary. Used when listed as subcommand of parent.
2190
+ *
2191
+ * @param {string} [str]
2192
+ * @return {(string|Command)}
2193
+ */
2194
+ summary(str) {
2195
+ if (str === undefined) return this._summary;
2196
+ this._summary = str;
2197
+ return this;
2198
+ }
2199
+
2200
+ /**
2201
+ * Set an alias for the command.
2202
+ *
2203
+ * You may call more than once to add multiple aliases. Only the first alias is shown in the auto-generated help.
2204
+ *
2205
+ * @param {string} [alias]
2206
+ * @return {(string|Command)}
2207
+ */
2208
+
2209
+ alias(alias) {
2210
+ if (alias === undefined) return this._aliases[0]; // just return first, for backwards compatibility
2211
+
2212
+ /** @type {Command} */
2213
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
2214
+ let command = this;
2215
+ if (
2216
+ this.commands.length !== 0 &&
2217
+ this.commands[this.commands.length - 1]._executableHandler
2218
+ ) {
2219
+ // assume adding alias for last added executable subcommand, rather than this
2220
+ command = this.commands[this.commands.length - 1];
2221
+ }
2222
+
2223
+ if (alias === command._name)
2224
+ throw new Error("Command alias can't be the same as its name");
2225
+ const matchingCommand = this.parent?._findCommand(alias);
2226
+ if (matchingCommand) {
2227
+ // c.f. _registerCommand
2228
+ const existingCmd = [matchingCommand.name()]
2229
+ .concat(matchingCommand.aliases())
2230
+ .join('|');
2231
+ throw new Error(
2232
+ `cannot add alias '${alias}' to command '${this.name()}' as already have command '${existingCmd}'`,
2233
+ );
2234
+ }
2235
+
2236
+ command._aliases.push(alias);
2237
+ return this;
2238
+ }
2239
+
2240
+ /**
2241
+ * Set aliases for the command.
2242
+ *
2243
+ * Only the first alias is shown in the auto-generated help.
2244
+ *
2245
+ * @param {string[]} [aliases]
2246
+ * @return {(string[]|Command)}
2247
+ */
2248
+
2249
+ aliases(aliases) {
2250
+ // Getter for the array of aliases is the main reason for having aliases() in addition to alias().
2251
+ if (aliases === undefined) return this._aliases;
2252
+
2253
+ aliases.forEach((alias) => this.alias(alias));
2254
+ return this;
2255
+ }
2256
+
2257
+ /**
2258
+ * Set / get the command usage `str`.
2259
+ *
2260
+ * @param {string} [str]
2261
+ * @return {(string|Command)}
2262
+ */
2263
+
2264
+ usage(str) {
2265
+ if (str === undefined) {
2266
+ if (this._usage) return this._usage;
2267
+
2268
+ const args = this.registeredArguments.map((arg) => {
2269
+ return humanReadableArgName(arg);
2270
+ });
2271
+ return []
2272
+ .concat(
2273
+ this.options.length || this._helpOption !== null ? '[options]' : [],
2274
+ this.commands.length ? '[command]' : [],
2275
+ this.registeredArguments.length ? args : [],
2276
+ )
2277
+ .join(' ');
2278
+ }
2279
+
2280
+ this._usage = str;
2281
+ return this;
2282
+ }
2283
+
2284
+ /**
2285
+ * Get or set the name of the command.
2286
+ *
2287
+ * @param {string} [str]
2288
+ * @return {(string|Command)}
2289
+ */
2290
+
2291
+ name(str) {
2292
+ if (str === undefined) return this._name;
2293
+ this._name = str;
2294
+ return this;
2295
+ }
2296
+
2297
+ /**
2298
+ * Set the name of the command from script filename, such as process.argv[1],
2299
+ * or require.main.filename, or __filename.
2300
+ *
2301
+ * (Used internally and public although not documented in README.)
2302
+ *
2303
+ * @example
2304
+ * program.nameFromFilename(require.main.filename);
2305
+ *
2306
+ * @param {string} filename
2307
+ * @return {Command}
2308
+ */
2309
+
2310
+ nameFromFilename(filename) {
2311
+ this._name = path.basename(filename, path.extname(filename));
2312
+
2313
+ return this;
2314
+ }
2315
+
2316
+ /**
2317
+ * Get or set the directory for searching for executable subcommands of this command.
2318
+ *
2319
+ * @example
2320
+ * program.executableDir(__dirname);
2321
+ * // or
2322
+ * program.executableDir('subcommands');
2323
+ *
2324
+ * @param {string} [path]
2325
+ * @return {(string|null|Command)}
2326
+ */
2327
+
2328
+ executableDir(path) {
2329
+ if (path === undefined) return this._executableDir;
2330
+ this._executableDir = path;
2331
+ return this;
2332
+ }
2333
+
2334
+ /**
2335
+ * Return program help documentation.
2336
+ *
2337
+ * @param {{ error: boolean }} [contextOptions] - pass {error:true} to wrap for stderr instead of stdout
2338
+ * @return {string}
2339
+ */
2340
+
2341
+ helpInformation(contextOptions) {
2342
+ const helper = this.createHelp();
2343
+ const context = this._getOutputContext(contextOptions);
2344
+ helper.prepareContext({
2345
+ error: context.error,
2346
+ helpWidth: context.helpWidth,
2347
+ outputHasColors: context.hasColors,
2348
+ });
2349
+ const text = helper.formatHelp(this, helper);
2350
+ if (context.hasColors) return text;
2351
+ return this._outputConfiguration.stripColor(text);
2352
+ }
2353
+
2354
+ /**
2355
+ * @typedef HelpContext
2356
+ * @type {object}
2357
+ * @property {boolean} error
2358
+ * @property {number} helpWidth
2359
+ * @property {boolean} hasColors
2360
+ * @property {function} write - includes stripColor if needed
2361
+ *
2362
+ * @returns {HelpContext}
2363
+ * @private
2364
+ */
2365
+
2366
+ _getOutputContext(contextOptions) {
2367
+ contextOptions = contextOptions || {};
2368
+ const error = !!contextOptions.error;
2369
+ let baseWrite;
2370
+ let hasColors;
2371
+ let helpWidth;
2372
+ if (error) {
2373
+ baseWrite = (str) => this._outputConfiguration.writeErr(str);
2374
+ hasColors = this._outputConfiguration.getErrHasColors();
2375
+ helpWidth = this._outputConfiguration.getErrHelpWidth();
2376
+ } else {
2377
+ baseWrite = (str) => this._outputConfiguration.writeOut(str);
2378
+ hasColors = this._outputConfiguration.getOutHasColors();
2379
+ helpWidth = this._outputConfiguration.getOutHelpWidth();
2380
+ }
2381
+ const write = (str) => {
2382
+ if (!hasColors) str = this._outputConfiguration.stripColor(str);
2383
+ return baseWrite(str);
2384
+ };
2385
+ return { error, write, hasColors, helpWidth };
2386
+ }
2387
+
2388
+ /**
2389
+ * Output help information for this command.
2390
+ *
2391
+ * Outputs built-in help, and custom text added using `.addHelpText()`.
2392
+ *
2393
+ * @param {{ error: boolean } | Function} [contextOptions] - pass {error:true} to write to stderr instead of stdout
2394
+ */
2395
+
2396
+ outputHelp(contextOptions) {
2397
+ let deprecatedCallback;
2398
+ if (typeof contextOptions === 'function') {
2399
+ deprecatedCallback = contextOptions;
2400
+ contextOptions = undefined;
2401
+ }
2402
+
2403
+ const outputContext = this._getOutputContext(contextOptions);
2404
+ /** @type {HelpTextEventContext} */
2405
+ const eventContext = {
2406
+ error: outputContext.error,
2407
+ write: outputContext.write,
2408
+ command: this,
2409
+ };
2410
+
2411
+ this._getCommandAndAncestors()
2412
+ .reverse()
2413
+ .forEach((command) => command.emit('beforeAllHelp', eventContext));
2414
+ this.emit('beforeHelp', eventContext);
2415
+
2416
+ let helpInformation = this.helpInformation({ error: outputContext.error });
2417
+ if (deprecatedCallback) {
2418
+ helpInformation = deprecatedCallback(helpInformation);
2419
+ if (
2420
+ typeof helpInformation !== 'string' &&
2421
+ !Buffer.isBuffer(helpInformation)
2422
+ ) {
2423
+ throw new Error('outputHelp callback must return a string or a Buffer');
2424
+ }
2425
+ }
2426
+ outputContext.write(helpInformation);
2427
+
2428
+ if (this._getHelpOption()?.long) {
2429
+ this.emit(this._getHelpOption().long); // deprecated
2430
+ }
2431
+ this.emit('afterHelp', eventContext);
2432
+ this._getCommandAndAncestors().forEach((command) =>
2433
+ command.emit('afterAllHelp', eventContext),
2434
+ );
2435
+ }
2436
+
2437
+ /**
2438
+ * You can pass in flags and a description to customise the built-in help option.
2439
+ * Pass in false to disable the built-in help option.
2440
+ *
2441
+ * @example
2442
+ * program.helpOption('-?, --help' 'show help'); // customise
2443
+ * program.helpOption(false); // disable
2444
+ *
2445
+ * @param {(string | boolean)} flags
2446
+ * @param {string} [description]
2447
+ * @return {Command} `this` command for chaining
2448
+ */
2449
+
2450
+ helpOption(flags, description) {
2451
+ // Support disabling built-in help option.
2452
+ if (typeof flags === 'boolean') {
2453
+ // true is not an expected value. Do something sensible but no unit-test.
2454
+ // istanbul ignore if
2455
+ if (flags) {
2456
+ this._helpOption = this._helpOption ?? undefined; // preserve existing option
2457
+ } else {
2458
+ this._helpOption = null; // disable
2459
+ }
2460
+ return this;
2461
+ }
2462
+
2463
+ // Customise flags and description.
2464
+ flags = flags ?? '-h, --help';
2465
+ description = description ?? 'display help for command';
2466
+ this._helpOption = this.createOption(flags, description);
2467
+
2468
+ return this;
2469
+ }
2470
+
2471
+ /**
2472
+ * Lazy create help option.
2473
+ * Returns null if has been disabled with .helpOption(false).
2474
+ *
2475
+ * @returns {(Option | null)} the help option
2476
+ * @package
2477
+ */
2478
+ _getHelpOption() {
2479
+ // Lazy create help option on demand.
2480
+ if (this._helpOption === undefined) {
2481
+ this.helpOption(undefined, undefined);
2482
+ }
2483
+ return this._helpOption;
2484
+ }
2485
+
2486
+ /**
2487
+ * Supply your own option to use for the built-in help option.
2488
+ * This is an alternative to using helpOption() to customise the flags and description etc.
2489
+ *
2490
+ * @param {Option} option
2491
+ * @return {Command} `this` command for chaining
2492
+ */
2493
+ addHelpOption(option) {
2494
+ this._helpOption = option;
2495
+ return this;
2496
+ }
2497
+
2498
+ /**
2499
+ * Output help information and exit.
2500
+ *
2501
+ * Outputs built-in help, and custom text added using `.addHelpText()`.
2502
+ *
2503
+ * @param {{ error: boolean }} [contextOptions] - pass {error:true} to write to stderr instead of stdout
2504
+ */
2505
+
2506
+ help(contextOptions) {
2507
+ this.outputHelp(contextOptions);
2508
+ let exitCode = Number(process.exitCode ?? 0); // process.exitCode does allow a string or an integer, but we prefer just a number
2509
+ if (
2510
+ exitCode === 0 &&
2511
+ contextOptions &&
2512
+ typeof contextOptions !== 'function' &&
2513
+ contextOptions.error
2514
+ ) {
2515
+ exitCode = 1;
2516
+ }
2517
+ // message: do not have all displayed text available so only passing placeholder.
2518
+ this._exit(exitCode, 'commander.help', '(outputHelp)');
2519
+ }
2520
+
2521
+ /**
2522
+ * // Do a little typing to coordinate emit and listener for the help text events.
2523
+ * @typedef HelpTextEventContext
2524
+ * @type {object}
2525
+ * @property {boolean} error
2526
+ * @property {Command} command
2527
+ * @property {function} write
2528
+ */
2529
+
2530
+ /**
2531
+ * Add additional text to be displayed with the built-in help.
2532
+ *
2533
+ * Position is 'before' or 'after' to affect just this command,
2534
+ * and 'beforeAll' or 'afterAll' to affect this command and all its subcommands.
2535
+ *
2536
+ * @param {string} position - before or after built-in help
2537
+ * @param {(string | Function)} text - string to add, or a function returning a string
2538
+ * @return {Command} `this` command for chaining
2539
+ */
2540
+
2541
+ addHelpText(position, text) {
2542
+ const allowedValues = ['beforeAll', 'before', 'after', 'afterAll'];
2543
+ if (!allowedValues.includes(position)) {
2544
+ throw new Error(`Unexpected value for position to addHelpText.
2545
+ Expecting one of '${allowedValues.join("', '")}'`);
2546
+ }
2547
+
2548
+ const helpEvent = `${position}Help`;
2549
+ this.on(helpEvent, (/** @type {HelpTextEventContext} */ context) => {
2550
+ let helpStr;
2551
+ if (typeof text === 'function') {
2552
+ helpStr = text({ error: context.error, command: context.command });
2553
+ } else {
2554
+ helpStr = text;
2555
+ }
2556
+ // Ignore falsy value when nothing to output.
2557
+ if (helpStr) {
2558
+ context.write(`${helpStr}\n`);
2559
+ }
2560
+ });
2561
+ return this;
2562
+ }
2563
+
2564
+ /**
2565
+ * Output help information if help flags specified
2566
+ *
2567
+ * @param {Array} args - array of options to search for help flags
2568
+ * @private
2569
+ */
2570
+
2571
+ _outputHelpIfRequested(args) {
2572
+ const helpOption = this._getHelpOption();
2573
+ const helpRequested = helpOption && args.find((arg) => helpOption.is(arg));
2574
+ if (helpRequested) {
2575
+ this.outputHelp();
2576
+ // (Do not have all displayed text available so only passing placeholder.)
2577
+ this._exit(0, 'commander.helpDisplayed', '(outputHelp)');
2578
+ }
2579
+ }
2580
+ }
2581
+
2582
+ /**
2583
+ * Scan arguments and increment port number for inspect calls (to avoid conflicts when spawning new command).
2584
+ *
2585
+ * @param {string[]} args - array of arguments from node.execArgv
2586
+ * @returns {string[]}
2587
+ * @private
2588
+ */
2589
+
2590
+ function incrementNodeInspectorPort(args) {
2591
+ // Testing for these options:
2592
+ // --inspect[=[host:]port]
2593
+ // --inspect-brk[=[host:]port]
2594
+ // --inspect-port=[host:]port
2595
+ return args.map((arg) => {
2596
+ if (!arg.startsWith('--inspect')) {
2597
+ return arg;
2598
+ }
2599
+ let debugOption;
2600
+ let debugHost = '127.0.0.1';
2601
+ let debugPort = '9229';
2602
+ let match;
2603
+ if ((match = arg.match(/^(--inspect(-brk)?)$/)) !== null) {
2604
+ // e.g. --inspect
2605
+ debugOption = match[1];
2606
+ } else if (
2607
+ (match = arg.match(/^(--inspect(-brk|-port)?)=([^:]+)$/)) !== null
2608
+ ) {
2609
+ debugOption = match[1];
2610
+ if (/^\d+$/.test(match[3])) {
2611
+ // e.g. --inspect=1234
2612
+ debugPort = match[3];
2613
+ } else {
2614
+ // e.g. --inspect=localhost
2615
+ debugHost = match[3];
2616
+ }
2617
+ } else if (
2618
+ (match = arg.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/)) !== null
2619
+ ) {
2620
+ // e.g. --inspect=localhost:1234
2621
+ debugOption = match[1];
2622
+ debugHost = match[3];
2623
+ debugPort = match[4];
2624
+ }
2625
+
2626
+ if (debugOption && debugPort !== '0') {
2627
+ return `${debugOption}=${debugHost}:${parseInt(debugPort) + 1}`;
2628
+ }
2629
+ return arg;
2630
+ });
2631
+ }
2632
+
2633
+ /**
2634
+ * @returns {boolean | undefined}
2635
+ * @package
2636
+ */
2637
+ function useColor() {
2638
+ // Test for common conventions.
2639
+ // NB: the observed behaviour is in combination with how author adds color! For example:
2640
+ // - we do not test NODE_DISABLE_COLORS, but util:styletext does
2641
+ // - we do test NO_COLOR, but Chalk does not
2642
+ //
2643
+ // References:
2644
+ // https://no-color.org
2645
+ // https://bixense.com/clicolors/
2646
+ // https://github.com/nodejs/node/blob/0a00217a5f67ef4a22384cfc80eb6dd9a917fdc1/lib/internal/tty.js#L109
2647
+ // https://github.com/chalk/supports-color/blob/c214314a14bcb174b12b3014b2b0a8de375029ae/index.js#L33
2648
+ // (https://force-color.org recent web page from 2023, does not match major javascript implementations)
2649
+
2650
+ if (
2651
+ process.env.NO_COLOR ||
2652
+ process.env.FORCE_COLOR === '0' ||
2653
+ process.env.FORCE_COLOR === 'false'
2654
+ )
2655
+ return false;
2656
+ if (process.env.FORCE_COLOR || process.env.CLICOLOR_FORCE !== undefined)
2657
+ return true;
2658
+ return undefined;
2659
+ }
2660
+
2661
+ exports.Command = Command;
2662
+ exports.useColor = useColor; // exporting for tests