@bemoje/cli 0.0.4 → 0.0.5

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 (707) hide show
  1. package/.eslintrc.json +5 -0
  2. package/.swcrc +32 -0
  3. package/dist/cjs/arg/ArgumentBuilder.js +45 -0
  4. package/dist/cjs/arg/ArgumentBuilder.js.map +1 -0
  5. package/dist/cjs/arg/ArgumentParserSelector.js +15 -0
  6. package/dist/cjs/arg/ArgumentParserSelector.js.map +1 -0
  7. package/dist/cjs/arg/ArgumentReader.js +38 -0
  8. package/dist/cjs/arg/ArgumentReader.js.map +1 -0
  9. package/dist/cjs/arg/ArgumentValidatorSelector.js +16 -0
  10. package/dist/cjs/arg/ArgumentValidatorSelector.js.map +1 -0
  11. package/dist/cjs/cmd/CLI.js +16 -0
  12. package/dist/cjs/cmd/CLI.js.map +1 -0
  13. package/dist/cjs/cmd/CommandBuilder.js +1098 -0
  14. package/dist/cjs/cmd/CommandBuilder.js.map +1 -0
  15. package/dist/cjs/cmd/CommandBuilderMetaData.js +43 -0
  16. package/dist/cjs/cmd/CommandBuilderMetaData.js.map +1 -0
  17. package/dist/cjs/cmd/CommandFeatureSelector.js +112 -0
  18. package/dist/cjs/cmd/CommandFeatureSelector.js.map +1 -0
  19. package/dist/cjs/cmd/DefaultHelpConfig.js +141 -0
  20. package/dist/cjs/cmd/DefaultHelpConfig.js.map +1 -0
  21. package/dist/cjs/cmd/asdas.js +27 -0
  22. package/dist/cjs/cmd/asdas.js.map +1 -0
  23. package/dist/cjs/core/OutputManager.js +99 -0
  24. package/dist/cjs/core/OutputManager.js.map +1 -0
  25. package/dist/cjs/core/ParserSelector.js +36 -0
  26. package/dist/cjs/core/ParserSelector.js.map +1 -0
  27. package/dist/cjs/core/ValidatorSelector.js +36 -0
  28. package/dist/cjs/core/ValidatorSelector.js.map +1 -0
  29. package/dist/cjs/core/splitCombinedArgvShorts.js +15 -0
  30. package/dist/cjs/core/splitCombinedArgvShorts.js.map +1 -0
  31. package/dist/cjs/db/AbstractJsonFileSection.js +190 -0
  32. package/dist/cjs/db/AbstractJsonFileSection.js.map +1 -0
  33. package/dist/cjs/db/AppDataSection.js +48 -0
  34. package/dist/cjs/db/AppDataSection.js.map +1 -0
  35. package/dist/cjs/db/ConfigSection.js +71 -0
  36. package/dist/cjs/db/ConfigSection.js.map +1 -0
  37. package/dist/cjs/db/JsonFile.js +55 -0
  38. package/dist/cjs/db/JsonFile.js.map +1 -0
  39. package/dist/cjs/db/PresetsSection.js +92 -0
  40. package/dist/cjs/db/PresetsSection.js.map +1 -0
  41. package/dist/cjs/index.js +120 -0
  42. package/dist/cjs/index.js.map +1 -0
  43. package/dist/cjs/opt/OptionArgumentParserSelector.js +16 -0
  44. package/dist/cjs/opt/OptionArgumentParserSelector.js.map +1 -0
  45. package/dist/cjs/opt/OptionArgumentValidatorSelector.js +19 -0
  46. package/dist/cjs/opt/OptionArgumentValidatorSelector.js.map +1 -0
  47. package/dist/cjs/opt/OptionBuilder.js +88 -0
  48. package/dist/cjs/opt/OptionBuilder.js.map +1 -0
  49. package/dist/cjs/opt/OptionHelpers.js +57 -0
  50. package/dist/cjs/opt/OptionHelpers.js.map +1 -0
  51. package/dist/cjs/opt/OptionReader.js +66 -0
  52. package/dist/cjs/opt/OptionReader.js.map +1 -0
  53. package/dist/cjs/proto/overrideCommanderPrototype.js +37 -0
  54. package/dist/cjs/proto/overrideCommanderPrototype.js.map +1 -0
  55. package/dist/cjs/types/IConfig.js +3 -0
  56. package/dist/cjs/types/IConfig.js.map +1 -0
  57. package/dist/cjs/types/IPreset.js +3 -0
  58. package/dist/cjs/types/IPreset.js.map +1 -0
  59. package/dist/cjs/util/array/arrLast.js +21 -0
  60. package/dist/cjs/util/array/arrLast.js.map +1 -0
  61. package/dist/cjs/util/array/arrSome.js +26 -0
  62. package/dist/cjs/util/array/arrSome.js.map +1 -0
  63. package/dist/cjs/util/array/types/ArrayPredicate.js +3 -0
  64. package/dist/cjs/util/array/types/ArrayPredicate.js.map +1 -0
  65. package/dist/cjs/util/db/JsonDB.js +145 -0
  66. package/dist/cjs/util/db/JsonDB.js.map +1 -0
  67. package/dist/cjs/util/errors/ErrorParser.js +164 -0
  68. package/dist/cjs/util/errors/ErrorParser.js.map +1 -0
  69. package/dist/cjs/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js +3 -0
  70. package/dist/cjs/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js.map +1 -0
  71. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js +32 -0
  72. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js.map +1 -0
  73. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js +25 -0
  74. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js.map +1 -0
  75. package/dist/cjs/util/fs/readFile/readFileSafeSync.js +28 -0
  76. package/dist/cjs/util/fs/readFile/readFileSafeSync.js.map +1 -0
  77. package/dist/cjs/util/fs/readFile/readFileSync.js +20 -0
  78. package/dist/cjs/util/fs/readFile/readFileSync.js.map +1 -0
  79. package/dist/cjs/util/fs/readJsonFile/readJsonFileSafeSync.js +24 -0
  80. package/dist/cjs/util/fs/readJsonFile/readJsonFileSafeSync.js.map +1 -0
  81. package/dist/cjs/util/fs/removeFile/removeFile.js +6 -0
  82. package/dist/cjs/util/fs/removeFile/removeFile.js.map +1 -0
  83. package/dist/cjs/util/fs/tempFile/tempFileSync.js +28 -0
  84. package/dist/cjs/util/fs/tempFile/tempFileSync.js.map +1 -0
  85. package/dist/cjs/util/fs/types/IReadJsonFileOptions.js +3 -0
  86. package/dist/cjs/util/fs/types/IReadJsonFileOptions.js.map +1 -0
  87. package/dist/cjs/util/fs/writeFile/writeFileSafeSync.js +6 -0
  88. package/dist/cjs/util/fs/writeFile/writeFileSafeSync.js.map +1 -0
  89. package/dist/cjs/util/fs/writeFile/writeFileSync.js +6 -0
  90. package/dist/cjs/util/fs/writeFile/writeFileSync.js.map +1 -0
  91. package/dist/cjs/util/fs/writeJsonFile/writeJsonFileSafe.js +6 -0
  92. package/dist/cjs/util/fs/writeJsonFile/writeJsonFileSafe.js.map +1 -0
  93. package/dist/cjs/util/function/MethodDisabler.js +94 -0
  94. package/dist/cjs/util/function/MethodDisabler.js.map +1 -0
  95. package/dist/cjs/util/function/funSetName.js +21 -0
  96. package/dist/cjs/util/function/funSetName.js.map +1 -0
  97. package/dist/cjs/util/node/execInherit.js +19 -0
  98. package/dist/cjs/util/node/execInherit.js.map +1 -0
  99. package/dist/cjs/util/node/formatTableForTerminal.js +21 -0
  100. package/dist/cjs/util/node/formatTableForTerminal.js.map +1 -0
  101. package/dist/cjs/util/object/arrAssign.js +6 -0
  102. package/dist/cjs/util/object/arrAssign.js.map +1 -0
  103. package/dist/cjs/util/object/createArrayMerger.js +20 -0
  104. package/dist/cjs/util/object/createArrayMerger.js.map +1 -0
  105. package/dist/cjs/util/object/createObjectMerger.js +20 -0
  106. package/dist/cjs/util/object/createObjectMerger.js.map +1 -0
  107. package/dist/cjs/util/object/objAssign.js +6 -0
  108. package/dist/cjs/util/object/objAssign.js.map +1 -0
  109. package/dist/cjs/util/object/objUpdatePropertyDescriptors.js +28 -0
  110. package/dist/cjs/util/object/objUpdatePropertyDescriptors.js.map +1 -0
  111. package/dist/cjs/util/object/realizeLazyProperty.js +14 -0
  112. package/dist/cjs/util/object/realizeLazyProperty.js.map +1 -0
  113. package/dist/cjs/util/object/setNonEnumerable.js +25 -0
  114. package/dist/cjs/util/object/setNonEnumerable.js.map +1 -0
  115. package/dist/cjs/util/os/defaultOpenInEditorCommand.js +18 -0
  116. package/dist/cjs/util/os/defaultOpenInEditorCommand.js.map +1 -0
  117. package/dist/cjs/util/os/isOSX.js +13 -0
  118. package/dist/cjs/util/os/isOSX.js.map +1 -0
  119. package/dist/cjs/util/os/isVsCodeInstalled.js +19 -0
  120. package/dist/cjs/util/os/isVsCodeInstalled.js.map +1 -0
  121. package/dist/cjs/util/os/isWindows.js +16 -0
  122. package/dist/cjs/util/os/isWindows.js.map +1 -0
  123. package/dist/cjs/util/path/getTempDataPath.js +20 -0
  124. package/dist/cjs/util/path/getTempDataPath.js.map +1 -0
  125. package/dist/cjs/util/regex/regexEscapeString.js +18 -0
  126. package/dist/cjs/util/regex/regexEscapeString.js.map +1 -0
  127. package/dist/cjs/util/string/strEnsureStartsWith.js +19 -0
  128. package/dist/cjs/util/string/strEnsureStartsWith.js.map +1 -0
  129. package/dist/cjs/util/string/strFirstCharToUpperCase.js +16 -0
  130. package/dist/cjs/util/string/strFirstCharToUpperCase.js.map +1 -0
  131. package/dist/cjs/util/string/strIsLowerCase.js +18 -0
  132. package/dist/cjs/util/string/strIsLowerCase.js.map +1 -0
  133. package/dist/cjs/util/string/strIsUpperCase.js +18 -0
  134. package/dist/cjs/util/string/strIsUpperCase.js.map +1 -0
  135. package/dist/cjs/util/string/strSplitCamelCase.js +55 -0
  136. package/dist/cjs/util/string/strSplitCamelCase.js.map +1 -0
  137. package/dist/cjs/util/string-parsers/createBooleanParser.js +21 -0
  138. package/dist/cjs/util/string-parsers/createBooleanParser.js.map +1 -0
  139. package/dist/cjs/util/string-parsers/createTypedListParser.js +22 -0
  140. package/dist/cjs/util/string-parsers/createTypedListParser.js.map +1 -0
  141. package/dist/cjs/util/string-parsers/parseBoolean.js +15 -0
  142. package/dist/cjs/util/string-parsers/parseBoolean.js.map +1 -0
  143. package/dist/cjs/util/string-parsers/parseInteger.js +17 -0
  144. package/dist/cjs/util/string-parsers/parseInteger.js.map +1 -0
  145. package/dist/cjs/util/string-parsers/parseNumber.js +13 -0
  146. package/dist/cjs/util/string-parsers/parseNumber.js.map +1 -0
  147. package/dist/cjs/util/string-parsers/parseString.js +8 -0
  148. package/dist/cjs/util/string-parsers/parseString.js.map +1 -0
  149. package/dist/cjs/util/types/Any.js +3 -0
  150. package/dist/cjs/util/types/Any.js.map +1 -0
  151. package/dist/cjs/util/types/DeepArray.js +3 -0
  152. package/dist/cjs/util/types/DeepArray.js.map +1 -0
  153. package/dist/cjs/util/types/DeepObject.js +3 -0
  154. package/dist/cjs/util/types/DeepObject.js.map +1 -0
  155. package/dist/cjs/util/types/JsonArray.js +3 -0
  156. package/dist/cjs/util/types/JsonArray.js.map +1 -0
  157. package/dist/cjs/util/types/JsonDefinedPrimitive.js +6 -0
  158. package/dist/cjs/util/types/JsonDefinedPrimitive.js.map +1 -0
  159. package/dist/cjs/util/types/JsonObject.js +3 -0
  160. package/dist/cjs/util/types/JsonObject.js.map +1 -0
  161. package/dist/cjs/util/types/JsonRawPrimitive.js +3 -0
  162. package/dist/cjs/util/types/JsonRawPrimitive.js.map +1 -0
  163. package/dist/cjs/util/types/JsonValue.js +3 -0
  164. package/dist/cjs/util/types/JsonValue.js.map +1 -0
  165. package/dist/cjs/util/types/ObjectKey.js +3 -0
  166. package/dist/cjs/util/types/ObjectKey.js.map +1 -0
  167. package/dist/cjs/util/types/TConstructor.js +3 -0
  168. package/dist/cjs/util/types/TConstructor.js.map +1 -0
  169. package/dist/cjs/util/types/TFunction.js +3 -0
  170. package/dist/cjs/util/types/TFunction.js.map +1 -0
  171. package/dist/cjs/util/types/TFunctionNoNew.js +3 -0
  172. package/dist/cjs/util/types/TFunctionNoNew.js.map +1 -0
  173. package/dist/cjs/util/types/TPlainObject.js +3 -0
  174. package/dist/cjs/util/types/TPlainObject.js.map +1 -0
  175. package/dist/cjs/util/types/TPrimitive.js +3 -0
  176. package/dist/cjs/util/types/TPrimitive.js.map +1 -0
  177. package/dist/cjs/util/types/TStringParser.js +3 -0
  178. package/dist/cjs/util/types/TStringParser.js.map +1 -0
  179. package/dist/cjs/util/types/TValidator.js +3 -0
  180. package/dist/cjs/util/types/TValidator.js.map +1 -0
  181. package/dist/cjs/util/validation/createTypedArrayValidator.js +26 -0
  182. package/dist/cjs/util/validation/createTypedArrayValidator.js.map +1 -0
  183. package/dist/cjs/util/validation/ensureThat.js +12 -0
  184. package/dist/cjs/util/validation/ensureThat.js.map +1 -0
  185. package/dist/cjs/util/validation/isArray.js +5 -0
  186. package/dist/cjs/util/validation/isArray.js.map +1 -0
  187. package/dist/cjs/util/validation/isBoolean.js +8 -0
  188. package/dist/cjs/util/validation/isBoolean.js.map +1 -0
  189. package/dist/cjs/util/validation/isFunction.js +17 -0
  190. package/dist/cjs/util/validation/isFunction.js.map +1 -0
  191. package/dist/cjs/util/validation/isNamedFunction.js +11 -0
  192. package/dist/cjs/util/validation/isNamedFunction.js.map +1 -0
  193. package/dist/cjs/util/validation/isNamedFunctionArray.js +9 -0
  194. package/dist/cjs/util/validation/isNamedFunctionArray.js.map +1 -0
  195. package/dist/cjs/util/validation/isObject.js +22 -0
  196. package/dist/cjs/util/validation/isObject.js.map +1 -0
  197. package/dist/cjs/util/validation/isPlainObject.js +19 -0
  198. package/dist/cjs/util/validation/isPlainObject.js.map +1 -0
  199. package/dist/cjs/util/validation/isPrimitive.js +18 -0
  200. package/dist/cjs/util/validation/isPrimitive.js.map +1 -0
  201. package/dist/cjs/util/validation/isString.js +8 -0
  202. package/dist/cjs/util/validation/isString.js.map +1 -0
  203. package/dist/cjs/util/validation/isStringArray.js +12 -0
  204. package/dist/cjs/util/validation/isStringArray.js.map +1 -0
  205. package/dist/cjs/util/validation/isStringWithNoSpacesOrDashes.js +9 -0
  206. package/dist/cjs/util/validation/isStringWithNoSpacesOrDashes.js.map +1 -0
  207. package/dist/cjs/util/validation/numbers/isInteger.js +17 -0
  208. package/dist/cjs/util/validation/numbers/isInteger.js.map +1 -0
  209. package/dist/cjs/util/validation/numbers/isValidNumber.js +22 -0
  210. package/dist/cjs/util/validation/numbers/isValidNumber.js.map +1 -0
  211. package/dist/esm/arg/ArgumentBuilder.js +41 -0
  212. package/dist/esm/arg/ArgumentBuilder.js.map +1 -0
  213. package/dist/esm/arg/ArgumentParserSelector.js +11 -0
  214. package/dist/esm/arg/ArgumentParserSelector.js.map +1 -0
  215. package/dist/esm/arg/ArgumentReader.js +34 -0
  216. package/dist/esm/arg/ArgumentReader.js.map +1 -0
  217. package/dist/esm/arg/ArgumentValidatorSelector.js +12 -0
  218. package/dist/esm/arg/ArgumentValidatorSelector.js.map +1 -0
  219. package/dist/esm/cmd/CLI.js +12 -0
  220. package/dist/esm/cmd/CLI.js.map +1 -0
  221. package/dist/esm/cmd/CommandBuilder.js +1091 -0
  222. package/dist/esm/cmd/CommandBuilder.js.map +1 -0
  223. package/dist/esm/cmd/CommandBuilderMetaData.js +39 -0
  224. package/dist/esm/cmd/CommandBuilderMetaData.js.map +1 -0
  225. package/dist/esm/cmd/CommandFeatureSelector.js +108 -0
  226. package/dist/esm/cmd/CommandFeatureSelector.js.map +1 -0
  227. package/dist/esm/cmd/DefaultHelpConfig.js +135 -0
  228. package/dist/esm/cmd/DefaultHelpConfig.js.map +1 -0
  229. package/dist/esm/cmd/asdas.js +25 -0
  230. package/dist/esm/cmd/asdas.js.map +1 -0
  231. package/dist/esm/core/OutputManager.js +92 -0
  232. package/dist/esm/core/OutputManager.js.map +1 -0
  233. package/dist/esm/core/ParserSelector.js +32 -0
  234. package/dist/esm/core/ParserSelector.js.map +1 -0
  235. package/dist/esm/core/ValidatorSelector.js +32 -0
  236. package/dist/esm/core/ValidatorSelector.js.map +1 -0
  237. package/dist/esm/core/splitCombinedArgvShorts.js +11 -0
  238. package/dist/esm/core/splitCombinedArgvShorts.js.map +1 -0
  239. package/dist/esm/db/AbstractJsonFileSection.js +186 -0
  240. package/dist/esm/db/AbstractJsonFileSection.js.map +1 -0
  241. package/dist/esm/db/AppDataSection.js +44 -0
  242. package/dist/esm/db/AppDataSection.js.map +1 -0
  243. package/dist/esm/db/ConfigSection.js +67 -0
  244. package/dist/esm/db/ConfigSection.js.map +1 -0
  245. package/dist/esm/db/JsonFile.js +51 -0
  246. package/dist/esm/db/JsonFile.js.map +1 -0
  247. package/dist/esm/db/PresetsSection.js +88 -0
  248. package/dist/esm/db/PresetsSection.js.map +1 -0
  249. package/dist/esm/index.js +104 -0
  250. package/dist/esm/index.js.map +1 -0
  251. package/dist/esm/opt/OptionArgumentParserSelector.js +12 -0
  252. package/dist/esm/opt/OptionArgumentParserSelector.js.map +1 -0
  253. package/dist/esm/opt/OptionArgumentValidatorSelector.js +15 -0
  254. package/dist/esm/opt/OptionArgumentValidatorSelector.js.map +1 -0
  255. package/dist/esm/opt/OptionBuilder.js +84 -0
  256. package/dist/esm/opt/OptionBuilder.js.map +1 -0
  257. package/dist/esm/opt/OptionHelpers.js +54 -0
  258. package/dist/esm/opt/OptionHelpers.js.map +1 -0
  259. package/dist/esm/opt/OptionReader.js +62 -0
  260. package/dist/esm/opt/OptionReader.js.map +1 -0
  261. package/dist/esm/proto/overrideCommanderPrototype.js +34 -0
  262. package/dist/esm/proto/overrideCommanderPrototype.js.map +1 -0
  263. package/dist/esm/types/IConfig.js +2 -0
  264. package/dist/esm/types/IConfig.js.map +1 -0
  265. package/dist/esm/types/IPreset.js +2 -0
  266. package/dist/esm/types/IPreset.js.map +1 -0
  267. package/dist/esm/util/array/arrLast.js +17 -0
  268. package/dist/esm/util/array/arrLast.js.map +1 -0
  269. package/dist/esm/util/array/arrSome.js +22 -0
  270. package/dist/esm/util/array/arrSome.js.map +1 -0
  271. package/dist/esm/util/array/types/ArrayPredicate.js +2 -0
  272. package/dist/esm/util/array/types/ArrayPredicate.js.map +1 -0
  273. package/dist/esm/util/db/JsonDB.js +141 -0
  274. package/dist/esm/util/db/JsonDB.js.map +1 -0
  275. package/dist/esm/util/errors/ErrorParser.js +154 -0
  276. package/dist/esm/util/errors/ErrorParser.js.map +1 -0
  277. package/dist/esm/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js +2 -0
  278. package/dist/esm/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js.map +1 -0
  279. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js +28 -0
  280. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js.map +1 -0
  281. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js +21 -0
  282. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js.map +1 -0
  283. package/dist/esm/util/fs/readFile/readFileSafeSync.js +21 -0
  284. package/dist/esm/util/fs/readFile/readFileSafeSync.js.map +1 -0
  285. package/dist/esm/util/fs/readFile/readFileSync.js +13 -0
  286. package/dist/esm/util/fs/readFile/readFileSync.js.map +1 -0
  287. package/dist/esm/util/fs/readJsonFile/readJsonFileSafeSync.js +17 -0
  288. package/dist/esm/util/fs/readJsonFile/readJsonFileSafeSync.js.map +1 -0
  289. package/dist/esm/util/fs/removeFile/removeFile.js +2 -0
  290. package/dist/esm/util/fs/removeFile/removeFile.js.map +1 -0
  291. package/dist/esm/util/fs/tempFile/tempFileSync.js +21 -0
  292. package/dist/esm/util/fs/tempFile/tempFileSync.js.map +1 -0
  293. package/dist/esm/util/fs/types/IReadJsonFileOptions.js +2 -0
  294. package/dist/esm/util/fs/types/IReadJsonFileOptions.js.map +1 -0
  295. package/dist/esm/util/fs/writeFile/writeFileSafeSync.js +2 -0
  296. package/dist/esm/util/fs/writeFile/writeFileSafeSync.js.map +1 -0
  297. package/dist/esm/util/fs/writeFile/writeFileSync.js +2 -0
  298. package/dist/esm/util/fs/writeFile/writeFileSync.js.map +1 -0
  299. package/dist/esm/util/fs/writeJsonFile/writeJsonFileSafe.js +2 -0
  300. package/dist/esm/util/fs/writeJsonFile/writeJsonFileSafe.js.map +1 -0
  301. package/dist/esm/util/function/MethodDisabler.js +90 -0
  302. package/dist/esm/util/function/MethodDisabler.js.map +1 -0
  303. package/dist/esm/util/function/funSetName.js +17 -0
  304. package/dist/esm/util/function/funSetName.js.map +1 -0
  305. package/dist/esm/util/node/execInherit.js +15 -0
  306. package/dist/esm/util/node/execInherit.js.map +1 -0
  307. package/dist/esm/util/node/formatTableForTerminal.js +14 -0
  308. package/dist/esm/util/node/formatTableForTerminal.js.map +1 -0
  309. package/dist/esm/util/object/arrAssign.js +3 -0
  310. package/dist/esm/util/object/arrAssign.js.map +1 -0
  311. package/dist/esm/util/object/createArrayMerger.js +16 -0
  312. package/dist/esm/util/object/createArrayMerger.js.map +1 -0
  313. package/dist/esm/util/object/createObjectMerger.js +16 -0
  314. package/dist/esm/util/object/createObjectMerger.js.map +1 -0
  315. package/dist/esm/util/object/objAssign.js +3 -0
  316. package/dist/esm/util/object/objAssign.js.map +1 -0
  317. package/dist/esm/util/object/objUpdatePropertyDescriptors.js +24 -0
  318. package/dist/esm/util/object/objUpdatePropertyDescriptors.js.map +1 -0
  319. package/dist/esm/util/object/realizeLazyProperty.js +10 -0
  320. package/dist/esm/util/object/realizeLazyProperty.js.map +1 -0
  321. package/dist/esm/util/object/setNonEnumerable.js +21 -0
  322. package/dist/esm/util/object/setNonEnumerable.js.map +1 -0
  323. package/dist/esm/util/os/defaultOpenInEditorCommand.js +14 -0
  324. package/dist/esm/util/os/defaultOpenInEditorCommand.js.map +1 -0
  325. package/dist/esm/util/os/isOSX.js +9 -0
  326. package/dist/esm/util/os/isOSX.js.map +1 -0
  327. package/dist/esm/util/os/isVsCodeInstalled.js +15 -0
  328. package/dist/esm/util/os/isVsCodeInstalled.js.map +1 -0
  329. package/dist/esm/util/os/isWindows.js +12 -0
  330. package/dist/esm/util/os/isWindows.js.map +1 -0
  331. package/dist/esm/util/path/getTempDataPath.js +13 -0
  332. package/dist/esm/util/path/getTempDataPath.js.map +1 -0
  333. package/dist/esm/util/regex/regexEscapeString.js +14 -0
  334. package/dist/esm/util/regex/regexEscapeString.js.map +1 -0
  335. package/dist/esm/util/string/strEnsureStartsWith.js +15 -0
  336. package/dist/esm/util/string/strEnsureStartsWith.js.map +1 -0
  337. package/dist/esm/util/string/strFirstCharToUpperCase.js +12 -0
  338. package/dist/esm/util/string/strFirstCharToUpperCase.js.map +1 -0
  339. package/dist/esm/util/string/strIsLowerCase.js +14 -0
  340. package/dist/esm/util/string/strIsLowerCase.js.map +1 -0
  341. package/dist/esm/util/string/strIsUpperCase.js +14 -0
  342. package/dist/esm/util/string/strIsUpperCase.js.map +1 -0
  343. package/dist/esm/util/string/strSplitCamelCase.js +51 -0
  344. package/dist/esm/util/string/strSplitCamelCase.js.map +1 -0
  345. package/dist/esm/util/string-parsers/createBooleanParser.js +17 -0
  346. package/dist/esm/util/string-parsers/createBooleanParser.js.map +1 -0
  347. package/dist/esm/util/string-parsers/createTypedListParser.js +18 -0
  348. package/dist/esm/util/string-parsers/createTypedListParser.js.map +1 -0
  349. package/dist/esm/util/string-parsers/parseBoolean.js +12 -0
  350. package/dist/esm/util/string-parsers/parseBoolean.js.map +1 -0
  351. package/dist/esm/util/string-parsers/parseInteger.js +13 -0
  352. package/dist/esm/util/string-parsers/parseInteger.js.map +1 -0
  353. package/dist/esm/util/string-parsers/parseNumber.js +9 -0
  354. package/dist/esm/util/string-parsers/parseNumber.js.map +1 -0
  355. package/dist/esm/util/string-parsers/parseString.js +4 -0
  356. package/dist/esm/util/string-parsers/parseString.js.map +1 -0
  357. package/dist/esm/util/types/Any.js +2 -0
  358. package/dist/esm/util/types/Any.js.map +1 -0
  359. package/dist/esm/util/types/DeepArray.js +2 -0
  360. package/dist/esm/util/types/DeepArray.js.map +1 -0
  361. package/dist/esm/util/types/DeepObject.js +2 -0
  362. package/dist/esm/util/types/DeepObject.js.map +1 -0
  363. package/dist/esm/util/types/JsonArray.js +2 -0
  364. package/dist/esm/util/types/JsonArray.js.map +1 -0
  365. package/dist/esm/util/types/JsonDefinedPrimitive.js +5 -0
  366. package/dist/esm/util/types/JsonDefinedPrimitive.js.map +1 -0
  367. package/dist/esm/util/types/JsonObject.js +2 -0
  368. package/dist/esm/util/types/JsonObject.js.map +1 -0
  369. package/dist/esm/util/types/JsonRawPrimitive.js +2 -0
  370. package/dist/esm/util/types/JsonRawPrimitive.js.map +1 -0
  371. package/dist/esm/util/types/JsonValue.js +2 -0
  372. package/dist/esm/util/types/JsonValue.js.map +1 -0
  373. package/dist/esm/util/types/ObjectKey.js +2 -0
  374. package/dist/esm/util/types/ObjectKey.js.map +1 -0
  375. package/dist/esm/util/types/TConstructor.js +2 -0
  376. package/dist/esm/util/types/TConstructor.js.map +1 -0
  377. package/dist/esm/util/types/TFunction.js +2 -0
  378. package/dist/esm/util/types/TFunction.js.map +1 -0
  379. package/dist/esm/util/types/TFunctionNoNew.js +2 -0
  380. package/dist/esm/util/types/TFunctionNoNew.js.map +1 -0
  381. package/dist/esm/util/types/TPlainObject.js +2 -0
  382. package/dist/esm/util/types/TPlainObject.js.map +1 -0
  383. package/dist/esm/util/types/TPrimitive.js +2 -0
  384. package/dist/esm/util/types/TPrimitive.js.map +1 -0
  385. package/dist/esm/util/types/TStringParser.js +2 -0
  386. package/dist/esm/util/types/TStringParser.js.map +1 -0
  387. package/dist/esm/util/types/TValidator.js +2 -0
  388. package/dist/esm/util/types/TValidator.js.map +1 -0
  389. package/dist/esm/util/validation/createTypedArrayValidator.js +22 -0
  390. package/dist/esm/util/validation/createTypedArrayValidator.js.map +1 -0
  391. package/dist/esm/util/validation/ensureThat.js +8 -0
  392. package/dist/esm/util/validation/ensureThat.js.map +1 -0
  393. package/dist/esm/util/validation/isArray.js +2 -0
  394. package/dist/esm/util/validation/isArray.js.map +1 -0
  395. package/dist/esm/util/validation/isBoolean.js +4 -0
  396. package/dist/esm/util/validation/isBoolean.js.map +1 -0
  397. package/dist/esm/util/validation/isFunction.js +13 -0
  398. package/dist/esm/util/validation/isFunction.js.map +1 -0
  399. package/dist/esm/util/validation/isNamedFunction.js +7 -0
  400. package/dist/esm/util/validation/isNamedFunction.js.map +1 -0
  401. package/dist/esm/util/validation/isNamedFunctionArray.js +5 -0
  402. package/dist/esm/util/validation/isNamedFunctionArray.js.map +1 -0
  403. package/dist/esm/util/validation/isObject.js +18 -0
  404. package/dist/esm/util/validation/isObject.js.map +1 -0
  405. package/dist/esm/util/validation/isPlainObject.js +15 -0
  406. package/dist/esm/util/validation/isPlainObject.js.map +1 -0
  407. package/dist/esm/util/validation/isPrimitive.js +14 -0
  408. package/dist/esm/util/validation/isPrimitive.js.map +1 -0
  409. package/dist/esm/util/validation/isString.js +4 -0
  410. package/dist/esm/util/validation/isString.js.map +1 -0
  411. package/dist/esm/util/validation/isStringArray.js +8 -0
  412. package/dist/esm/util/validation/isStringArray.js.map +1 -0
  413. package/dist/esm/util/validation/isStringWithNoSpacesOrDashes.js +5 -0
  414. package/dist/esm/util/validation/isStringWithNoSpacesOrDashes.js.map +1 -0
  415. package/dist/esm/util/validation/numbers/isInteger.js +14 -0
  416. package/dist/esm/util/validation/numbers/isInteger.js.map +1 -0
  417. package/dist/esm/util/validation/numbers/isValidNumber.js +18 -0
  418. package/dist/esm/util/validation/numbers/isValidNumber.js.map +1 -0
  419. package/{src → dist/types}/arg/ArgumentBuilder.d.ts +1 -1
  420. package/{src → dist/types}/arg/ArgumentParserSelector.d.ts +2 -2
  421. package/{src → dist/types}/arg/ArgumentReader.d.ts +3 -3
  422. package/{src → dist/types}/arg/ArgumentValidatorSelector.d.ts +2 -2
  423. package/dist/types/cmd/CLI.d.ts +2 -0
  424. package/{src → dist/types}/cmd/CommandBuilder.d.ts +26 -28
  425. package/{src → dist/types}/cmd/CommandBuilderMetaData.d.ts +7 -7
  426. package/{src → dist/types}/cmd/CommandFeatureSelector.d.ts +1 -1
  427. package/dist/types/cmd/DefaultHelpConfig.d.ts +28 -0
  428. package/dist/types/cmd/asdas.d.ts +6 -0
  429. package/{src → dist/types}/core/OutputManager.d.ts +1 -1
  430. package/{src → dist/types}/core/ParserSelector.d.ts +3 -3
  431. package/{src → dist/types}/core/ValidatorSelector.d.ts +2 -2
  432. package/{src → dist/types}/db/AbstractJsonFileSection.d.ts +3 -3
  433. package/{src → dist/types}/db/AppDataSection.d.ts +1 -1
  434. package/{src → dist/types}/db/ConfigSection.d.ts +4 -4
  435. package/{src → dist/types}/db/PresetsSection.d.ts +2 -2
  436. package/{src → dist/types}/index.d.ts +1 -0
  437. package/{src → dist/types}/opt/OptionArgumentParserSelector.d.ts +1 -1
  438. package/{src → dist/types}/opt/OptionArgumentValidatorSelector.d.ts +2 -2
  439. package/{src → dist/types}/opt/OptionBuilder.d.ts +2 -1
  440. package/{src → dist/types}/opt/OptionHelpers.d.ts +2 -2
  441. package/{src → dist/types}/opt/OptionReader.d.ts +7 -7
  442. package/dist/types/proto/overrideCommanderPrototype.d.ts +8 -0
  443. package/{src → dist/types}/types/IConfig.d.ts +3 -3
  444. package/{src → dist/types}/types/IPreset.d.ts +4 -3
  445. package/{src → dist/types}/util/db/JsonDB.d.ts +2 -2
  446. package/{src → dist/types}/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.d.ts +1 -1
  447. package/{src → dist/types}/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.d.ts +1 -1
  448. package/{src → dist/types}/util/fs/readJsonFile/readJsonFileSafeSync.d.ts +1 -1
  449. package/{src → dist/types}/util/fs/tempFile/tempFileSync.d.ts +1 -1
  450. package/{src → dist/types}/util/function/MethodDisabler.d.ts +3 -3
  451. package/{src → dist/types}/util/object/createObjectMerger.d.ts +1 -1
  452. package/{src → dist/types}/util/object/objUpdatePropertyDescriptors.d.ts +1 -1
  453. package/{src → dist/types}/util/object/setNonEnumerable.d.ts +1 -1
  454. package/{src → dist/types}/util/string-parsers/createTypedListParser.d.ts +1 -1
  455. package/{src → dist/types}/util/types/DeepArray.d.ts +2 -2
  456. package/{src → dist/types}/util/types/DeepObject.d.ts +2 -2
  457. package/{src → dist/types}/util/types/JsonArray.d.ts +2 -2
  458. package/{src → dist/types}/util/types/JsonObject.d.ts +2 -2
  459. package/{src → dist/types}/util/types/JsonRawPrimitive.d.ts +1 -1
  460. package/{src → dist/types}/util/types/JsonValue.d.ts +3 -3
  461. package/{src → dist/types}/util/types/TConstructor.d.ts +1 -1
  462. package/dist/types/util/types/TFunction.d.ts +4 -0
  463. package/{src → dist/types}/util/types/TFunctionNoNew.d.ts +1 -1
  464. package/{src → dist/types}/util/types/TPlainObject.d.ts +1 -1
  465. package/dist/types/util/types/TValidator.d.ts +2 -0
  466. package/{src → dist/types}/util/validation/ensureThat.d.ts +2 -2
  467. package/{src → dist/types}/util/validation/isFunction.d.ts +1 -1
  468. package/{src → dist/types}/util/validation/isNamedFunction.d.ts +1 -1
  469. package/{src → dist/types}/util/validation/isPlainObject.d.ts +2 -2
  470. package/{src → dist/types}/util/validation/isPrimitive.d.ts +1 -1
  471. package/jest.config.ts +11 -0
  472. package/notes/tsc.md +1 -0
  473. package/package.json +13 -6
  474. package/project.json +43 -0
  475. package/scripts/_example/CommandBuilder.example.ts +96 -0
  476. package/scripts/_example/CommandBuilder.example2.ts +31 -0
  477. package/scripts/_example/CommandBuilder.example3.ts +20 -0
  478. package/scripts/_example/bFindIn.ts +207 -0
  479. package/scripts/currentBemojeUtils.txt +41 -0
  480. package/scripts/rollupUtils.ts +184 -0
  481. package/src/arg/ArgumentBuilder.test.ts +102 -0
  482. package/src/arg/ArgumentBuilder.ts +47 -0
  483. package/src/arg/ArgumentParserSelector.test.ts +53 -0
  484. package/src/arg/ArgumentParserSelector.ts +14 -0
  485. package/src/arg/ArgumentReader.test.ts +60 -0
  486. package/src/arg/ArgumentReader.ts +33 -0
  487. package/src/arg/ArgumentValidatorSelector.test.ts +80 -0
  488. package/src/arg/ArgumentValidatorSelector.ts +14 -0
  489. package/src/cmd/CLI.test.ts +14 -0
  490. package/src/cmd/CLI.ts +13 -0
  491. package/src/cmd/CommandBuilder.test.ts +611 -0
  492. package/src/cmd/CommandBuilder.ts +1175 -0
  493. package/src/cmd/CommandBuilderMetaData.test.ts +54 -0
  494. package/src/cmd/CommandBuilderMetaData.ts +44 -0
  495. package/src/cmd/CommandFeatureSelector.test.ts +185 -0
  496. package/src/cmd/CommandFeatureSelector.ts +113 -0
  497. package/src/cmd/DefaultHelpConfig.test.ts +22 -0
  498. package/src/cmd/DefaultHelpConfig.ts +141 -0
  499. package/src/cmd/asdas.ts +40 -0
  500. package/src/core/OutputManager.test.ts +129 -0
  501. package/src/core/OutputManager.ts +103 -0
  502. package/src/core/ParserSelector.test.ts +7 -0
  503. package/src/core/ParserSelector.ts +38 -0
  504. package/src/core/ValidatorSelector.test.ts +7 -0
  505. package/src/core/ValidatorSelector.ts +38 -0
  506. package/src/core/splitCombinedArgvShorts.test.ts +9 -0
  507. package/src/core/splitCombinedArgvShorts.ts +10 -0
  508. package/src/db/AbstractJsonFileSection.test.ts +274 -0
  509. package/src/db/AbstractJsonFileSection.ts +218 -0
  510. package/src/db/AppDataSection.test.ts +69 -0
  511. package/src/db/AppDataSection.ts +46 -0
  512. package/src/db/ConfigSection.test.ts +95 -0
  513. package/src/db/ConfigSection.ts +74 -0
  514. package/src/db/JsonFile.test.ts +56 -0
  515. package/src/db/JsonFile.ts +52 -0
  516. package/src/db/PresetsSection.test.ts +130 -0
  517. package/src/db/PresetsSection.ts +92 -0
  518. package/src/index.ts +103 -0
  519. package/src/opt/OptionArgumentParserSelector.test.ts +54 -0
  520. package/src/opt/OptionArgumentParserSelector.ts +14 -0
  521. package/src/opt/OptionArgumentValidatorSelector.test.ts +90 -0
  522. package/src/opt/OptionArgumentValidatorSelector.ts +16 -0
  523. package/src/opt/OptionBuilder.test.ts +229 -0
  524. package/src/opt/OptionBuilder.ts +85 -0
  525. package/src/opt/OptionHelpers.test.ts +229 -0
  526. package/src/opt/OptionHelpers.ts +57 -0
  527. package/src/opt/OptionReader.test.ts +106 -0
  528. package/src/opt/OptionReader.ts +61 -0
  529. package/src/proto/overrideCommanderPrototype.ts +42 -0
  530. package/src/types/IConfig.ts +25 -0
  531. package/src/types/IPreset.ts +16 -0
  532. package/src/util/array/arrLast.test.ts +25 -0
  533. package/src/util/array/arrLast.ts +15 -0
  534. package/src/util/array/arrSome.test.ts +78 -0
  535. package/src/util/array/arrSome.ts +23 -0
  536. package/src/util/array/types/ArrayPredicate.ts +10 -0
  537. package/src/util/db/JsonDB.test.ts +214 -0
  538. package/src/util/db/JsonDB.ts +138 -0
  539. package/src/util/errors/ErrorParser.ts +165 -0
  540. package/src/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.ts +15 -0
  541. package/src/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.ts +30 -0
  542. package/src/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.ts +25 -0
  543. package/src/util/fs/readFile/readFileSafeSync.ts +20 -0
  544. package/src/util/fs/readFile/readFileSync.ts +13 -0
  545. package/src/util/fs/readJsonFile/readJsonFileSafeSync.ts +17 -0
  546. package/src/util/fs/removeFile/removeFile.ts +1 -0
  547. package/src/util/fs/tempFile/tempFileSync.ts +21 -0
  548. package/src/util/fs/types/IReadJsonFileOptions.ts +1 -0
  549. package/src/util/fs/writeFile/writeFileSafeSync.ts +1 -0
  550. package/src/util/fs/writeFile/writeFileSync.ts +1 -0
  551. package/src/util/fs/writeJsonFile/writeJsonFileSafe.ts +1 -0
  552. package/src/util/function/MethodDisabler.test.ts +112 -0
  553. package/src/util/function/MethodDisabler.ts +94 -0
  554. package/src/util/function/funSetName.test.ts +12 -0
  555. package/src/util/function/funSetName.ts +16 -0
  556. package/src/util/node/execInherit.ts +14 -0
  557. package/src/util/node/formatTableForTerminal.ts +12 -0
  558. package/src/util/object/arrAssign.ts +3 -0
  559. package/src/util/object/createArrayMerger.test.ts +11 -0
  560. package/src/util/object/createArrayMerger.ts +15 -0
  561. package/src/util/object/createObjectMerger.test.ts +11 -0
  562. package/src/util/object/createObjectMerger.ts +17 -0
  563. package/src/util/object/objAssign.ts +3 -0
  564. package/src/util/object/objUpdatePropertyDescriptors.test.ts +40 -0
  565. package/src/util/object/objUpdatePropertyDescriptors.ts +29 -0
  566. package/src/util/object/realizeLazyProperty.ts +9 -0
  567. package/src/util/object/setNonEnumerable.test.ts +63 -0
  568. package/src/util/object/setNonEnumerable.ts +22 -0
  569. package/src/util/os/defaultOpenInEditorCommand.ts +14 -0
  570. package/src/util/os/isOSX.ts +9 -0
  571. package/src/util/os/isVsCodeInstalled.test.ts +7 -0
  572. package/src/util/os/isVsCodeInstalled.ts +14 -0
  573. package/src/util/os/isWindows.ts +12 -0
  574. package/src/util/path/getTempDataPath.test.ts +9 -0
  575. package/src/util/path/getTempDataPath.ts +14 -0
  576. package/src/util/regex/regexEscapeString.test.ts +35 -0
  577. package/src/util/regex/regexEscapeString.ts +13 -0
  578. package/src/util/string/strEnsureStartsWith.test.ts +13 -0
  579. package/src/util/string/strEnsureStartsWith.ts +14 -0
  580. package/src/util/string/strFirstCharToUpperCase.test.ts +33 -0
  581. package/src/util/string/strFirstCharToUpperCase.ts +11 -0
  582. package/src/util/string/strIsLowerCase.test.ts +42 -0
  583. package/src/util/string/strIsLowerCase.ts +13 -0
  584. package/src/util/string/strIsUpperCase.test.ts +48 -0
  585. package/src/util/string/strIsUpperCase.ts +13 -0
  586. package/src/util/string/strSplitCamelCase.test.ts +54 -0
  587. package/src/util/string/strSplitCamelCase.ts +51 -0
  588. package/src/util/string-parsers/createBooleanParser.test.ts +58 -0
  589. package/src/util/string-parsers/createBooleanParser.ts +21 -0
  590. package/src/util/string-parsers/createTypedListParser.test.ts +19 -0
  591. package/src/util/string-parsers/createTypedListParser.ts +19 -0
  592. package/src/util/string-parsers/parseBoolean.test.ts +30 -0
  593. package/src/util/string-parsers/parseBoolean.ts +12 -0
  594. package/src/util/string-parsers/parseInteger.test.ts +52 -0
  595. package/src/util/string-parsers/parseInteger.ts +9 -0
  596. package/src/util/string-parsers/parseNumber.test.ts +53 -0
  597. package/src/util/string-parsers/parseNumber.ts +6 -0
  598. package/src/util/string-parsers/parseString.test.ts +7 -0
  599. package/src/util/string-parsers/parseString.ts +3 -0
  600. package/src/util/types/Any.ts +2 -0
  601. package/src/util/types/DeepArray.ts +12 -0
  602. package/src/util/types/DeepObject.ts +16 -0
  603. package/src/util/types/JsonArray.ts +8 -0
  604. package/src/util/types/JsonDefinedPrimitive.ts +5 -0
  605. package/src/util/types/JsonObject.ts +8 -0
  606. package/src/util/types/JsonRawPrimitive.ts +7 -0
  607. package/src/util/types/JsonValue.ts +14 -0
  608. package/src/util/types/ObjectKey.ts +1 -0
  609. package/src/util/types/TConstructor.ts +6 -0
  610. package/src/util/types/TFunction.ts +5 -0
  611. package/src/util/types/TFunctionNoNew.ts +3 -0
  612. package/src/util/types/TPlainObject.ts +4 -0
  613. package/src/util/types/TPrimitive.ts +1 -0
  614. package/src/util/types/TStringParser.ts +1 -0
  615. package/src/util/types/TValidator.ts +3 -0
  616. package/src/util/validation/createTypedArrayValidator.test.ts +34 -0
  617. package/src/util/validation/createTypedArrayValidator.ts +25 -0
  618. package/src/util/validation/ensureThat.test.ts +37 -0
  619. package/src/util/validation/ensureThat.ts +14 -0
  620. package/src/util/validation/isArray.test.ts +7 -0
  621. package/src/util/validation/isArray.ts +1 -0
  622. package/src/util/validation/isBoolean.test.ts +31 -0
  623. package/src/util/validation/isBoolean.ts +3 -0
  624. package/src/util/validation/isFunction.test.ts +54 -0
  625. package/src/util/validation/isFunction.ts +14 -0
  626. package/src/util/validation/isNamedFunction.test.ts +28 -0
  627. package/src/util/validation/isNamedFunction.ts +8 -0
  628. package/src/util/validation/isNamedFunctionArray.test.ts +14 -0
  629. package/src/util/validation/isNamedFunctionArray.ts +5 -0
  630. package/src/util/validation/isObject.test.ts +57 -0
  631. package/src/util/validation/isObject.ts +17 -0
  632. package/src/util/validation/isPlainObject.test.ts +21 -0
  633. package/src/util/validation/isPlainObject.ts +14 -0
  634. package/src/util/validation/isPrimitive.ts +15 -0
  635. package/src/util/validation/isString.test.ts +23 -0
  636. package/src/util/validation/isString.ts +3 -0
  637. package/src/util/validation/isStringArray.test.ts +24 -0
  638. package/src/util/validation/isStringArray.ts +8 -0
  639. package/src/util/validation/isStringWithNoSpacesOrDashes.test.ts +28 -0
  640. package/src/util/validation/isStringWithNoSpacesOrDashes.ts +5 -0
  641. package/src/util/validation/numbers/isInteger.test.ts +25 -0
  642. package/src/util/validation/numbers/isInteger.ts +13 -0
  643. package/src/util/validation/numbers/isValidNumber.test.ts +20 -0
  644. package/src/util/validation/numbers/isValidNumber.ts +17 -0
  645. package/tsconfig.json +32 -0
  646. package/tsconfig.lib.json +18 -0
  647. package/tsconfig.spec.json +10 -0
  648. package/index.cjs.d.ts +0 -1
  649. package/index.cjs.js +0 -3231
  650. package/index.esm.js +0 -3119
  651. package/src/cmd/CLI.d.ts +0 -2
  652. package/src/cmd/DefaultHelpConfig.d.ts +0 -2
  653. package/src/proto/overrideCommanderPrototype.d.ts +0 -8
  654. package/src/util/types/TFunction.d.ts +0 -4
  655. package/src/util/types/TValidator.d.ts +0 -1
  656. /package/{src → dist/types}/core/splitCombinedArgvShorts.d.ts +0 -0
  657. /package/{src → dist/types}/db/JsonFile.d.ts +0 -0
  658. /package/{src → dist/types}/util/array/arrLast.d.ts +0 -0
  659. /package/{src → dist/types}/util/array/arrSome.d.ts +0 -0
  660. /package/{src → dist/types}/util/array/types/ArrayPredicate.d.ts +0 -0
  661. /package/{src → dist/types}/util/errors/ErrorParser.d.ts +0 -0
  662. /package/{src → dist/types}/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.d.ts +0 -0
  663. /package/{src → dist/types}/util/fs/readFile/readFileSafeSync.d.ts +0 -0
  664. /package/{src → dist/types}/util/fs/readFile/readFileSync.d.ts +0 -0
  665. /package/{src → dist/types}/util/fs/removeFile/removeFile.d.ts +0 -0
  666. /package/{src → dist/types}/util/fs/types/IReadJsonFileOptions.d.ts +0 -0
  667. /package/{src → dist/types}/util/fs/writeFile/writeFileSafeSync.d.ts +0 -0
  668. /package/{src → dist/types}/util/fs/writeFile/writeFileSync.d.ts +0 -0
  669. /package/{src → dist/types}/util/fs/writeJsonFile/writeJsonFileSafe.d.ts +0 -0
  670. /package/{src → dist/types}/util/function/funSetName.d.ts +0 -0
  671. /package/{src → dist/types}/util/node/execInherit.d.ts +0 -0
  672. /package/{src → dist/types}/util/node/formatTableForTerminal.d.ts +0 -0
  673. /package/{src → dist/types}/util/object/arrAssign.d.ts +0 -0
  674. /package/{src → dist/types}/util/object/createArrayMerger.d.ts +0 -0
  675. /package/{src → dist/types}/util/object/objAssign.d.ts +0 -0
  676. /package/{src → dist/types}/util/object/realizeLazyProperty.d.ts +0 -0
  677. /package/{src → dist/types}/util/os/defaultOpenInEditorCommand.d.ts +0 -0
  678. /package/{src → dist/types}/util/os/isOSX.d.ts +0 -0
  679. /package/{src → dist/types}/util/os/isVsCodeInstalled.d.ts +0 -0
  680. /package/{src → dist/types}/util/os/isWindows.d.ts +0 -0
  681. /package/{src → dist/types}/util/path/getTempDataPath.d.ts +0 -0
  682. /package/{src → dist/types}/util/regex/regexEscapeString.d.ts +0 -0
  683. /package/{src → dist/types}/util/string/strEnsureStartsWith.d.ts +0 -0
  684. /package/{src → dist/types}/util/string/strFirstCharToUpperCase.d.ts +0 -0
  685. /package/{src → dist/types}/util/string/strIsLowerCase.d.ts +0 -0
  686. /package/{src → dist/types}/util/string/strIsUpperCase.d.ts +0 -0
  687. /package/{src → dist/types}/util/string/strSplitCamelCase.d.ts +0 -0
  688. /package/{src → dist/types}/util/string-parsers/createBooleanParser.d.ts +0 -0
  689. /package/{src → dist/types}/util/string-parsers/parseBoolean.d.ts +0 -0
  690. /package/{src → dist/types}/util/string-parsers/parseInteger.d.ts +0 -0
  691. /package/{src → dist/types}/util/string-parsers/parseNumber.d.ts +0 -0
  692. /package/{src → dist/types}/util/string-parsers/parseString.d.ts +0 -0
  693. /package/{src → dist/types}/util/types/Any.d.ts +0 -0
  694. /package/{src → dist/types}/util/types/JsonDefinedPrimitive.d.ts +0 -0
  695. /package/{src → dist/types}/util/types/ObjectKey.d.ts +0 -0
  696. /package/{src → dist/types}/util/types/TPrimitive.d.ts +0 -0
  697. /package/{src → dist/types}/util/types/TStringParser.d.ts +0 -0
  698. /package/{src → dist/types}/util/validation/createTypedArrayValidator.d.ts +0 -0
  699. /package/{src → dist/types}/util/validation/isArray.d.ts +0 -0
  700. /package/{src → dist/types}/util/validation/isBoolean.d.ts +0 -0
  701. /package/{src → dist/types}/util/validation/isNamedFunctionArray.d.ts +0 -0
  702. /package/{src → dist/types}/util/validation/isObject.d.ts +0 -0
  703. /package/{src → dist/types}/util/validation/isString.d.ts +0 -0
  704. /package/{src → dist/types}/util/validation/isStringArray.d.ts +0 -0
  705. /package/{src → dist/types}/util/validation/isStringWithNoSpacesOrDashes.d.ts +0 -0
  706. /package/{src → dist/types}/util/validation/numbers/isInteger.d.ts +0 -0
  707. /package/{src → dist/types}/util/validation/numbers/isValidNumber.d.ts +0 -0
@@ -0,0 +1,1091 @@
1
+ /* eslint-disable @typescript-eslint/ban-types */
2
+ import colors from 'ansi-colors';
3
+ import fs from 'fs-extra';
4
+ import isAsyncFunction from 'is-async-function';
5
+ import os from 'os';
6
+ import path from 'path';
7
+ import { ArgumentBuilder } from '../arg/ArgumentBuilder';
8
+ import { arrAssign } from '../util/object/arrAssign';
9
+ import { arrLast } from '../util/array/arrLast';
10
+ import { arrSome } from '../util/array/arrSome';
11
+ import { CommandBuilderMetaData } from './CommandBuilderMetaData';
12
+ import { commanderBackRefs } from '../proto/overrideCommanderPrototype';
13
+ import { CommandFeatureSelector } from './CommandFeatureSelector';
14
+ import { DefaultHelpConfig } from './DefaultHelpConfig';
15
+ import { ensureThat } from '../util/validation/ensureThat';
16
+ import { formatTableForTerminal } from '../util/node/formatTableForTerminal';
17
+ import { isArray } from '../util/validation/isArray';
18
+ import { isObject } from '../util/validation/isObject';
19
+ import { isString } from '../util/validation/isString';
20
+ import { isStringArray } from '../util/validation/isStringArray';
21
+ import { isStringWithNoSpacesOrDashes } from '../util/validation/isStringWithNoSpacesOrDashes';
22
+ import { JsonFile } from '../db/JsonFile';
23
+ import { objAssign } from '../util/object/objAssign';
24
+ import { OptionBuilder } from '../opt/OptionBuilder';
25
+ import { OptionHelpers } from '../opt/OptionHelpers';
26
+ import { OutputManager } from '../core/OutputManager';
27
+ import { realizeLazyProperty } from '../util/object/realizeLazyProperty';
28
+ import { removeFile } from '../util/fs/removeFile/removeFile';
29
+ import { setNonEnumerable } from '../util/object/setNonEnumerable';
30
+ import { splitCombinedArgvShorts } from '../core/splitCombinedArgvShorts';
31
+ import { Command, CommanderError, InvalidArgumentError, } from '@commander-js/extra-typings';
32
+ /**
33
+ * Wrapper around the @see Command class, for more intuitive construction.
34
+ */
35
+ export class CommandBuilder {
36
+ static dataDirectory = path.join(os.homedir(), 'config', 'cli');
37
+ features = new CommandFeatureSelector(this);
38
+ parent = null;
39
+ $;
40
+ meta = new CommandBuilderMetaData();
41
+ get db() {
42
+ return realizeLazyProperty(this, 'db', new JsonFile(this));
43
+ }
44
+ constructor(name, callback, parent, isNative = false) {
45
+ this.meta.isNative = isNative;
46
+ this.$ = new Command(name);
47
+ commanderBackRefs.set(this.$, this);
48
+ if (parent) {
49
+ this.parent = parent;
50
+ this.parent.meta.subcommands.push(this);
51
+ this.parent.$.addCommand(this.$);
52
+ }
53
+ this.initializeHelp();
54
+ if (callback)
55
+ callback.call(this, this);
56
+ if (this.parent) {
57
+ this.$.copyInheritedSettings(this.parent.$);
58
+ this.features.inheritFrom(this.parent.features);
59
+ this.inheritParentHiddenGlobals();
60
+ }
61
+ if (!this.meta.isNative) {
62
+ this.assertCommandNameNotReserved(this.name);
63
+ this.addUtilCommands();
64
+ }
65
+ if (this.isRoot) {
66
+ for (const child of this.getChildrenIterator({ includeSelf: true })) {
67
+ if (child.features.isAutoAssignSubCommandAliasesEnabled) {
68
+ child.assignSubCommandAliases();
69
+ if (!child.meta.isNative) {
70
+ child.assertNoDuplicateCommandNames();
71
+ }
72
+ }
73
+ if (child.features.isAutoAssignMissingOptionFlagsEnabled) {
74
+ child.assignMissingOptionFlags();
75
+ if (!child.meta.isNative) {
76
+ child.assertNoDuplicateOptionNames();
77
+ }
78
+ }
79
+ }
80
+ }
81
+ }
82
+ setRecommended() {
83
+ this.enableBuiltinOptions({ debug: true, disableStderr: true, disableStdout: true });
84
+ this.autoAssignMissingOptionFlags();
85
+ this.autoAssignSubCommandAliases();
86
+ this.presetsEnabled();
87
+ }
88
+ deleteDataFile() {
89
+ const filepath = this.dataFilepath;
90
+ if (fs.existsSync(filepath))
91
+ removeFile(filepath);
92
+ }
93
+ version(string) {
94
+ this.$.version(string);
95
+ const opt = this.options.find((o) => o.attributeName() === 'version');
96
+ if (opt)
97
+ this.meta.globalOptions.push(opt);
98
+ return this;
99
+ }
100
+ description(...lines) {
101
+ const description = lines.join('\n');
102
+ const summary = description.split(/(\. ?|\n|$)/)[0];
103
+ this.$.summary(summary + '.');
104
+ this.$.description(description);
105
+ return this;
106
+ }
107
+ alias(alias) {
108
+ this.assertCommandNameNotReserved(alias);
109
+ this.$.alias(alias);
110
+ return this;
111
+ }
112
+ aliases(...aliases) {
113
+ aliases.forEach((alias) => this.assertCommandNameNotReserved(alias));
114
+ this.$.aliases(aliases);
115
+ return this;
116
+ }
117
+ enableBuiltinOptions(options) {
118
+ if (!options || options.debug)
119
+ this.globalOption('-D, --debug', 'Output debugging information.');
120
+ if (!options || options.disableColor)
121
+ this.globalOption('-C, --disable-color', 'Disable color in terminal output.');
122
+ if (!options || options.disableStderr)
123
+ this.globalOption('-E, --disable-stderr', 'Mute all output to stderr.');
124
+ if (!options || options.disableStdout)
125
+ this.globalOption('-O, --disable-stdout', 'Mute all output to stdout.');
126
+ return this;
127
+ }
128
+ argument(name, cb) {
129
+ const ins = new ArgumentBuilder(this, name);
130
+ this.$.addArgument(ins.$);
131
+ if (typeof cb === 'function') {
132
+ cb(ins, this);
133
+ }
134
+ else if (typeof cb === 'string') {
135
+ ins.description(cb);
136
+ }
137
+ return this;
138
+ }
139
+ option(flags, cb) {
140
+ const ins = new OptionBuilder(this, flags);
141
+ if (this.hasIdenticalParentOption(ins.$))
142
+ return this;
143
+ this.$.addOption(ins.$);
144
+ if (typeof cb === 'function') {
145
+ cb(ins, this);
146
+ }
147
+ else if (typeof cb === 'string') {
148
+ ins.description(cb);
149
+ }
150
+ return this;
151
+ }
152
+ globalOption(flags, cb) {
153
+ return this.option(flags, (ins) => {
154
+ const opt = ins.$;
155
+ this.meta.globalOptions.push(opt);
156
+ if (typeof cb === 'function') {
157
+ cb(ins, this);
158
+ }
159
+ else if (typeof cb === 'string') {
160
+ ins.description(cb);
161
+ }
162
+ if (opt.hidden)
163
+ this.meta.hiddenGlobalOptions.add(opt);
164
+ });
165
+ }
166
+ command(name, cb) {
167
+ new CommandBuilder(name, cb, this);
168
+ return this;
169
+ }
170
+ nativeCommand(name, cb) {
171
+ new CommandBuilder(name, cb, this, true);
172
+ return this;
173
+ }
174
+ action(fn) {
175
+ const isAsync = isAsyncFunction(fn) || /^\(.+\) ?=> ?tslib_1\.__awaiter\(/.test(fn.toString().trim());
176
+ Object.defineProperty(this.meta, 'actionHandler', { value: fn, configurable: false, writable: false });
177
+ this.initializeActionWrapper(isAsync);
178
+ return this;
179
+ }
180
+ errorHandler(fn) {
181
+ Object.defineProperty(this.meta, 'errorHandler', { value: fn, configurable: true });
182
+ return this;
183
+ }
184
+ appData(key, value) {
185
+ this.features.appData(true);
186
+ this.db.appData.defineProperty(key, value);
187
+ return this;
188
+ }
189
+ config(key, entry) {
190
+ this.features.config(true);
191
+ this.db.config.defineProperty(key, entry);
192
+ return this;
193
+ }
194
+ preset(name, preset) {
195
+ this.features.presets();
196
+ this.meta.presetOptionKeys.push(name);
197
+ this.db.presets.defineProperty(name, {
198
+ description: preset.description,
199
+ presets: preset.presets ?? [],
200
+ args: preset.args ?? [],
201
+ options: preset.options ?? {},
202
+ });
203
+ return this;
204
+ }
205
+ presetsEnabled(boolean = true) {
206
+ this.features.presets(boolean);
207
+ return this;
208
+ }
209
+ autoAssignMissingOptionFlags(boolean = true) {
210
+ this.features.autoAssignMissingOptionFlags(boolean);
211
+ return this;
212
+ }
213
+ autoAssignSubCommandAliases(boolean = true) {
214
+ this.features.autoAssignSubCommandAliases(boolean);
215
+ return this;
216
+ }
217
+ allowExcessArguments(bool = true) {
218
+ this.$.allowExcessArguments(bool);
219
+ return this;
220
+ }
221
+ allowUnknownOption(bool = true) {
222
+ this.$.allowUnknownOption(bool);
223
+ return this;
224
+ }
225
+ /**
226
+ * Register callback to use as replacement for calling process.exit.
227
+ */
228
+ exitOverride(callback) {
229
+ this.$.exitOverride(callback);
230
+ return this;
231
+ }
232
+ throwInsteadOfProcessExit() {
233
+ const onErr = (err) => {
234
+ throw err;
235
+ };
236
+ this.exitOverride(onErr);
237
+ this.errorHandler(onErr);
238
+ }
239
+ /**
240
+ * Add hook for life cycle event.
241
+ */
242
+ hook(event, listener) {
243
+ this.$.hook(event, listener);
244
+ return this;
245
+ }
246
+ /**
247
+ * You can customise the help by overriding Help properties using configureHelp(),
248
+ * or with a subclass of Help by overriding createHelp().
249
+ */
250
+ configureHelp(configuration) {
251
+ this.$.configureHelp(configuration);
252
+ return this;
253
+ }
254
+ /**
255
+ * Display the help or a custom message after an error occurs.
256
+ */
257
+ showHelpAfterError(displayHelp) {
258
+ this.$.showHelpAfterError(displayHelp);
259
+ return this;
260
+ }
261
+ /**
262
+ * Display suggestion of similar commands for unknown commands, or options for unknown options.
263
+ */
264
+ showSuggestionAfterError(displaySuggestion) {
265
+ this.$.showSuggestionAfterError(displaySuggestion);
266
+ return this;
267
+ }
268
+ /**
269
+ * Add additional text to be displayed with the built-in help.
270
+ *
271
+ * Position is 'before' or 'after' to affect just this command,
272
+ * and 'beforeAll' or 'afterAll' to affect this command and all its subcommands.
273
+ */
274
+ addHelpText(position, text) {
275
+ this.$.addHelpText(position, text);
276
+ return this;
277
+ }
278
+ throwCommanderError(message, exitCode = 1, type = 'error') {
279
+ throw new CommanderError(exitCode, type, message);
280
+ }
281
+ hideGlobalOptions(...names) {
282
+ const globals = this.getGlobalOptions();
283
+ names = names.length ? names : globals.map((opt) => opt.attributeName());
284
+ for (const name of names) {
285
+ if (!name)
286
+ continue;
287
+ let found = false;
288
+ for (const opt of globals) {
289
+ if (opt.attributeName() === name) {
290
+ this.meta.hiddenGlobalOptions.add(opt);
291
+ found = true;
292
+ break;
293
+ }
294
+ }
295
+ if (!found)
296
+ this.throwCommanderError(`Unknown global option name: ${name} for command, ${this.name}`);
297
+ }
298
+ return this;
299
+ }
300
+ unhideGlobalOptions(...names) {
301
+ const globals = this.getGlobalOptions();
302
+ names = names.length ? names : globals.map((opt) => opt.attributeName());
303
+ for (const name of names) {
304
+ if (!name)
305
+ continue;
306
+ let found = false;
307
+ for (const opt of globals) {
308
+ if (opt.attributeName() === name) {
309
+ this.meta.hiddenGlobalOptions.delete(opt);
310
+ found = true;
311
+ break;
312
+ }
313
+ }
314
+ if (!found)
315
+ this.throwCommanderError(`Unknown global option name: ${name} for command, ${this.name}`);
316
+ }
317
+ return this;
318
+ }
319
+ /**
320
+ * Set the directory for searching for executable subcommands of this command.
321
+ */
322
+ executableDir(path) {
323
+ this.$.executableDir(path);
324
+ return this;
325
+ }
326
+ /**
327
+ * Store option value.
328
+ */
329
+ setOptionValue(key, value) {
330
+ this.$.setOptionValue(key, value);
331
+ return this;
332
+ }
333
+ /**
334
+ * Store option value and where the value came from.
335
+ */
336
+ setOptionValueWithSource(key, value, source) {
337
+ this.$.setOptionValueWithSource(key, value, source);
338
+ return this;
339
+ }
340
+ setDataFilepath(filepath) {
341
+ Object.defineProperty(this, 'dataFilepath', { value: filepath });
342
+ if (Object.hasOwn(this, 'db') && Object.hasOwn(this.db, 'db')) {
343
+ this.db.db.setFilepath(filepath);
344
+ }
345
+ }
346
+ /**
347
+ * Display error message and exit (or call exitOverride).
348
+ */
349
+ outputError(message, options) {
350
+ this.$.error(message, options);
351
+ }
352
+ /**
353
+ * Output help information for this command.
354
+ */
355
+ outputHelp() {
356
+ console.log(this.getRenderedHelp());
357
+ }
358
+ /**
359
+ * Display error message and exit (or call exitOverride).
360
+ */
361
+ outputDebugMessage(event, getProps = () => ({})) {
362
+ OutputManager.getInstance().outputDebug(() => ({ event, cmd: this.getPrefixString(), ...getProps() }));
363
+ }
364
+ parseArguments(args) {
365
+ const last = this.arguments.length - 1;
366
+ return args.map((arg, i) => {
367
+ if (!arg)
368
+ return arg;
369
+ const parse = this.meta.argParsers[i > last ? last : i];
370
+ return parse ? (Array.isArray(arg) ? arg.map(parse) : parse(arg)) : arg;
371
+ });
372
+ }
373
+ /**
374
+ * Parses (and validates) options using the parsers defined in the command builder.
375
+ */
376
+ parseOptions(opts) {
377
+ for (const [key, value] of Object.entries(opts)) {
378
+ const parse = this.meta.optParsers[key];
379
+ opts[key] = parse ? (Array.isArray(value) ? value.map(parse) : parse(value)) : value;
380
+ }
381
+ return opts;
382
+ }
383
+ /**
384
+ * Validate ALREADY PARSED args using the validators defined in the command builder.
385
+ */
386
+ assertValidArguments(parsedArgs) {
387
+ const last = this.arguments.length - 1;
388
+ parsedArgs.forEach((arg, i) => {
389
+ if (arg == null)
390
+ return;
391
+ const index = i > last ? last : i;
392
+ const validators = this.meta.argValidators[index];
393
+ if (!validators)
394
+ return;
395
+ for (const isValid of validators) {
396
+ ensureThat(arg, isValid, { Err: InvalidArgumentError });
397
+ }
398
+ });
399
+ return parsedArgs;
400
+ }
401
+ /**
402
+ * Validate ALREADY PARSED options using the validators defined in the command builder.
403
+ */
404
+ assertValidOptions(parsedOptions) {
405
+ for (const [key, value] of Object.entries(parsedOptions)) {
406
+ if (!this.meta.optValidators[key])
407
+ continue;
408
+ if (value == null)
409
+ continue;
410
+ for (const isValid of this.meta.optValidators[key]) {
411
+ ensureThat(value, isValid);
412
+ }
413
+ }
414
+ return parsedOptions;
415
+ }
416
+ assertValidPreset(key, preset) {
417
+ const { description, presets, args, options } = preset;
418
+ ensureThat(key, isStringWithNoSpacesOrDashes);
419
+ ensureThat(description, isString);
420
+ ensureThat(presets, isStringArray);
421
+ ensureThat(args, isArray);
422
+ this.assertPresetArgsOptional(args);
423
+ this.assertValidArguments(args);
424
+ ensureThat(options, isObject);
425
+ this.assertValidOptions(options);
426
+ }
427
+ get name() {
428
+ return this.$.name();
429
+ }
430
+ /**
431
+ * Get the command at the root of the command tree.
432
+ */
433
+ get root() {
434
+ if (this.isRoot)
435
+ return this;
436
+ return this.getAncestors().pop();
437
+ }
438
+ get isRoot() {
439
+ return !this.parent;
440
+ }
441
+ get arguments() {
442
+ return this.$.registeredArguments;
443
+ }
444
+ get options() {
445
+ return this.$.options;
446
+ }
447
+ get commander() {
448
+ return this.$;
449
+ }
450
+ get hasGrandChildren() {
451
+ return this.meta.subcommands.some((sub) => !!sub.meta.subcommands.length);
452
+ }
453
+ /**
454
+ * Returns whether a command's last argument is variadic.
455
+ */
456
+ get isLastArgVariadic() {
457
+ if (!this.arguments.length)
458
+ return false;
459
+ return arrLast(this.arguments).variadic;
460
+ }
461
+ get dataFilepath() {
462
+ return path.join(CommandBuilder.dataDirectory, this.root.name + '.json');
463
+ }
464
+ /**
465
+ * Get the executable search directory.
466
+ */
467
+ getExecutableDir() {
468
+ return this.$.executableDir();
469
+ }
470
+ /**
471
+ * Retrieve option value.
472
+ */
473
+ getOptionValue(key) {
474
+ return this.$.getOptionValue(key);
475
+ }
476
+ /**
477
+ * Get source of option value.
478
+ */
479
+ getOptionValueSource(key) {
480
+ return this.$.getOptionValueSource(key);
481
+ }
482
+ /**
483
+ * Get source of option value. See also .optsWithGlobals().
484
+ */
485
+ getOptionValueSourceWithGlobals(key) {
486
+ return this.$.getOptionValueSourceWithGlobals(key);
487
+ }
488
+ getActionHandler() {
489
+ return this.meta.actionHandler;
490
+ }
491
+ getDescription() {
492
+ return this.$.description();
493
+ }
494
+ getSummary() {
495
+ return this.$.summary();
496
+ }
497
+ getVersion() {
498
+ return this.$.version();
499
+ }
500
+ getAlias() {
501
+ return this.$.alias();
502
+ }
503
+ getAliases() {
504
+ return this.$.aliases();
505
+ }
506
+ /**
507
+ * Get a commands prefix array based on all its parent/ancestor commands.
508
+ */
509
+ getPrefixArray() {
510
+ return this.getAncestors({ includeSelf: true })
511
+ .reverse()
512
+ .map((node) => node.name);
513
+ }
514
+ /**
515
+ * Get a commands prefix string based on all its parent/ancestor commands.
516
+ */
517
+ getPrefixString() {
518
+ return this.getPrefixArray().join(' ');
519
+ }
520
+ getGlobalOptions() {
521
+ const result = [];
522
+ for (const anc of this.getAncestors({ includeSelf: true }).reverse()) {
523
+ for (const gopt of anc.meta.globalOptions) {
524
+ if (!this.meta.hiddenGlobalOptions.has(gopt)) {
525
+ result.push(gopt);
526
+ }
527
+ }
528
+ }
529
+ return result;
530
+ }
531
+ getOwnAndGlobalOptions() {
532
+ return this.options.concat(this.getGlobalOptions());
533
+ }
534
+ *getChildrenIterator(options) {
535
+ if (options?.includeSelf)
536
+ yield this;
537
+ for (const sub of this.meta.subcommands) {
538
+ yield sub;
539
+ yield* sub.getChildrenIterator();
540
+ }
541
+ }
542
+ getChildren(options) {
543
+ return [...this.getChildrenIterator(options)];
544
+ }
545
+ *getAncestorsIterator(options) {
546
+ if (options?.includeSelf)
547
+ yield this;
548
+ let node = this.parent;
549
+ while (node) {
550
+ yield node;
551
+ node = node.parent;
552
+ }
553
+ }
554
+ /**
555
+ * Get a command's ancestors, optionally starting from the command itself.
556
+ */
557
+ getAncestors(options) {
558
+ return [...this.getAncestorsIterator(options)];
559
+ }
560
+ *getSiblingsIterator() {
561
+ if (!this.parent)
562
+ return;
563
+ for (const sub of this.parent.meta.subcommands) {
564
+ if (sub === this)
565
+ continue;
566
+ yield sub;
567
+ }
568
+ }
569
+ /**
570
+ * Returns an array of sibling CommandBuilder objects.
571
+ */
572
+ getSiblings() {
573
+ return [...this.getSiblingsIterator()];
574
+ }
575
+ getClosestNonNativeParent() {
576
+ for (const anc of this.getAncestorsIterator({ includeSelf: true })) {
577
+ if (!anc.meta.isNative)
578
+ return anc;
579
+ }
580
+ this.throwCommanderError('No non-native parent found');
581
+ }
582
+ getRenderedHelp() {
583
+ return this.$.helpInformation();
584
+ }
585
+ getOptsWithGlobalsParsed() {
586
+ return this.parseOptions(this.$.optsWithGlobals());
587
+ }
588
+ getParsedValidArgsOptsWithPresets() {
589
+ const [presetArgs, presetOpts, presetOrder] = this.getPresetArgsAndOpts();
590
+ const args = this.getParsedValidArgsWithPresets(presetArgs);
591
+ const opts = this.getParsedValidOptsWithPresets(presetOpts);
592
+ this.debugLogArgsOpts(args, opts, presetArgs, presetOpts, presetOrder);
593
+ return [args, opts];
594
+ }
595
+ getParsedValidArgsWithPresets(presetArgs) {
596
+ const result = arrAssign([], ...presetArgs, this.parseArguments(this.$.args));
597
+ this.combineVariadicArgs(result);
598
+ this.assertValidArguments(result);
599
+ return this.padArgsWithUndefinedUntilExpectedLength(result);
600
+ }
601
+ getParsedValidOptsWithPresets(presetOpts) {
602
+ const parsed = this.getOptsWithGlobalsParsed();
603
+ const opts = presetOpts.length ? objAssign({}, ...presetOpts, parsed) : parsed;
604
+ this.deleteOptionsWithDefaultOrNoValue(opts);
605
+ this.assertValidOptions(opts);
606
+ return opts;
607
+ }
608
+ getPresetArgsAndOpts() {
609
+ if (!this.features.isPresetsEnabled)
610
+ return [[], [], []];
611
+ const presets = this.db.presets.getAll();
612
+ const opts = this.$.optsWithGlobals();
613
+ const selectedPresets = Object.keys(presets).filter((name) => opts[name] === true);
614
+ const presetOrder = Object.keys(opts).filter((key) => selectedPresets.includes(key));
615
+ const presetArgs = presetOrder.map((name) => presets[name].args);
616
+ const presetOpts = presetOrder.map((name) => presets[name].options);
617
+ return [presetArgs, presetOpts, presetOrder];
618
+ }
619
+ combineVariadicArgs(result) {
620
+ if (this.isLastArgVariadic && result.length && !Array.isArray(arrLast(result))) {
621
+ const rest = result.splice(this.arguments.length - 1);
622
+ result.push(rest.filter((arg) => arg != null));
623
+ }
624
+ return result;
625
+ }
626
+ debugLogArgsOpts(args, opts, presetArgs, presetOpts, presetOrder) {
627
+ if (opts['debug']) {
628
+ if (this.features.isPresetsEnabled) {
629
+ this.outputDebugMessage('parsePresets', () => ({ presetOrder, presetArgs, presetOpts }));
630
+ }
631
+ this.outputDebugMessage('parseArgsOpts', () => {
632
+ return {
633
+ args,
634
+ opts,
635
+ command: [this.root.name, ...this.meta.rawArgs].join(' '),
636
+ };
637
+ });
638
+ }
639
+ }
640
+ deleteOptionsWithDefaultOrNoValue(opts) {
641
+ const names = new Set(this.getOwnAndGlobalOptions().map((o) => o.attributeName()));
642
+ for (const [key, value] of Object.entries(opts)) {
643
+ if (!names.has(key) || value === false || value == null) {
644
+ setNonEnumerable(opts, key);
645
+ }
646
+ }
647
+ for (const key of this.meta.presetOptionKeys) {
648
+ if (Object.hasOwn(opts, key)) {
649
+ setNonEnumerable(opts, key);
650
+ }
651
+ }
652
+ return opts;
653
+ }
654
+ handleOutputOptions() {
655
+ const opts = this.$.optsWithGlobals();
656
+ const om = OutputManager.getInstance().reset();
657
+ if (opts['disableColor'])
658
+ om.colors.enabled = false;
659
+ if (opts['disableStderr'])
660
+ om.stderr.disable();
661
+ if (opts['disableStdout'])
662
+ om.stdout.disable();
663
+ if (opts['debug']) {
664
+ om.debug.enable();
665
+ om.drainDebugMessageQueue();
666
+ }
667
+ }
668
+ padArgsWithUndefinedUntilExpectedLength(args) {
669
+ while (args.length < this.arguments.length)
670
+ args.push(undefined);
671
+ return args;
672
+ }
673
+ assertPresetArgsOptional(args) {
674
+ args.forEach((arg, i) => {
675
+ if (arg != null && i < this.arguments.length && this.arguments[i].required) {
676
+ this.throwCommanderError(`Cannot preset required arguments.`);
677
+ }
678
+ });
679
+ }
680
+ addUtilCommands() {
681
+ if (!this.hasGrandChildren &&
682
+ !this.features.isConfigEnabled &&
683
+ !this.features.isPresetsEnabled &&
684
+ !this.features.isAppDataEnabled) {
685
+ return;
686
+ }
687
+ this.nativeCommand('util', (u) => {
688
+ const cmd = u.getClosestNonNativeParent();
689
+ u.alias('u');
690
+ u.description('Utility commands.');
691
+ if (cmd.features.isConfigEnabled) {
692
+ u.nativeCommand('config', createConfigCommand);
693
+ }
694
+ if (cmd.features.isPresetsEnabled && cmd.meta.hasCustomActionHandler) {
695
+ u.nativeCommand('presets', createPresetsCommand);
696
+ }
697
+ if (cmd.hasGrandChildren) {
698
+ u.nativeCommand('list', createUtilListCommand);
699
+ }
700
+ if (cmd.features.isConfigEnabled || cmd.features.isPresetsEnabled || cmd.features.isAppDataEnabled) {
701
+ u.nativeCommand('filepath', createUtilFilepathCommand);
702
+ }
703
+ function createUtilFilepathCommand(f) {
704
+ f.alias('f');
705
+ f.description('Print filepath to JSON file containing user data, eg. config and presets.');
706
+ f.action(async () => console.log(cmd.dataFilepath));
707
+ }
708
+ function createUtilListCommand(l) {
709
+ l.alias('l');
710
+ l.description('List nested subcommands.');
711
+ l.option('--all', 'Include utility commands.');
712
+ l.action(async (opts) => {
713
+ const filter = opts.all
714
+ ? undefined
715
+ : (prefix) => {
716
+ return !/ (config|presets|util)( .+)?$/gi.test(prefix);
717
+ };
718
+ const table = [];
719
+ for (const c of cmd.getChildrenIterator({ includeSelf: true })) {
720
+ const prefix = c.getPrefixString();
721
+ if (filter && !filter(prefix))
722
+ continue;
723
+ table.push([prefix, c.getSummary()]);
724
+ }
725
+ const ansi = table.map((row) => {
726
+ const arr = row[0].split(' ');
727
+ const last = arr.pop();
728
+ let col = colors.magenta;
729
+ if (row[1].startsWith('[Preset]')) {
730
+ col = colors.green;
731
+ }
732
+ else if (/ (util|config|presets) /.test(row[0])) {
733
+ col = colors.gray;
734
+ }
735
+ else if (/ (util|config|presets)/.test(row[0])) {
736
+ col = colors.dim;
737
+ }
738
+ row[0] = arr.map(colors.dim).concat(col(last)).join(' ');
739
+ return row;
740
+ });
741
+ console.log(formatTableForTerminal(ansi, ['Command', 'Summary']));
742
+ });
743
+ }
744
+ function createPresetsCommand(p) {
745
+ const db = cmd.db.presets;
746
+ p.alias('p');
747
+ p.description('Edit presets in your text editor', '', 'A preset consists of pre-set arguments and/or options for a command.', 'Additionally, a preset can have other presets as dependencies.', 'When running the command, multiple presets can be stacked.', 'Required arguments cannot be pre-set.');
748
+ p.nativeCommand('edit', (e) => {
749
+ e.alias('e');
750
+ e.description('Edit as JSON in a text editor.');
751
+ e.option('--editor [cmd]', 'The command to launch your preferred text editor.');
752
+ e.action(async (opts) => {
753
+ db.edit(opts.editor);
754
+ console.info(db.getAll());
755
+ });
756
+ });
757
+ p.nativeCommand('list', (l) => {
758
+ l.alias('l');
759
+ l.description('List all presets.');
760
+ l.action(async () => console.dir(db.getAll(), { depth: null }));
761
+ });
762
+ for (const [key, preset] of Object.entries(db.getAll())) {
763
+ if (key === 'defaults')
764
+ continue;
765
+ cmd.option(`--${key}`, (o) => {
766
+ o.description('[Preset]: ' + preset.description);
767
+ const implied = { defaults: true };
768
+ const recurse = (preset) => {
769
+ if (implied[preset])
770
+ return;
771
+ implied[preset] = true;
772
+ db.get(preset).presets.forEach((k) => recurse(k));
773
+ };
774
+ recurse(key);
775
+ o.implies(implied);
776
+ });
777
+ }
778
+ }
779
+ function createConfigCommand(c) {
780
+ const db = cmd.db.config;
781
+ c.alias('c');
782
+ c.description('Manage configuration file.');
783
+ c.nativeCommand('edit', (e) => {
784
+ e.alias('e');
785
+ e.description('Edit as JSON in a text editor.');
786
+ e.option('--editor [cmd]', 'The command to launch your preferred text editor.');
787
+ e.action(async (opts) => {
788
+ db.edit(opts.editor);
789
+ console.info(db.getAll());
790
+ });
791
+ });
792
+ c.nativeCommand('list', (l) => {
793
+ l.alias('l');
794
+ l.description('Print entire config with details.');
795
+ l.action(async () => {
796
+ const result = db.keys.map((key) => ({
797
+ key,
798
+ description: db.descriptions[key],
799
+ value: db.get(key),
800
+ defaultValue: db.defaultValues,
801
+ }));
802
+ console.dir(result, { depth: null });
803
+ });
804
+ });
805
+ c.nativeCommand('get', (g) => {
806
+ g.alias('g');
807
+ g.description('Print value(s) from the config.');
808
+ g.argument('[key]', 'The key to print the value of. Omit to print all values.');
809
+ g.action(async (key) => console.log(key ? db.get(key) : db.getAll()));
810
+ });
811
+ c.nativeCommand('set', (s) => {
812
+ s.alias('s');
813
+ s.description('Set a value in the config.');
814
+ s.argument('<key>', 'The key to set the value of.');
815
+ s.argument('<value>', 'The new value.');
816
+ s.action(async (key, val) => {
817
+ const parse = db.parsers[key];
818
+ const value = typeof parse === 'function' ? parse(val) : val;
819
+ db.set(key, value);
820
+ console.info({ [key]: value });
821
+ });
822
+ });
823
+ c.nativeCommand('reset', (r) => {
824
+ r.alias('r');
825
+ r.description('Reset to defaults.');
826
+ r.argument('[key]', 'The key for which to reset the value. Omit to reset entire config.');
827
+ r.action(async (key) => {
828
+ if (key)
829
+ db.reset(key);
830
+ else
831
+ db.resetAll();
832
+ console.info(db.getAll());
833
+ });
834
+ });
835
+ /*
836
+ config.option('--editor [cmd]', (o) => {
837
+ o.description('The command to launch your preferred text editor.')
838
+ })
839
+ config.argument('[action]', (a) => {
840
+ a.description('The action to perform.')
841
+ a.choices(['edit', 'list', 'get', 'set', 'reset'])
842
+ a.default('edit')
843
+ })
844
+ config.argument('[key]', (a) => {
845
+ a.description('Property key (if applicable)')
846
+ })
847
+ config.argument('[value]', (a) => {
848
+ a.description('Value to set (if applicable)')
849
+ })
850
+ config.action(
851
+ async (action: string, key: string, value: string, opts: { editor: string }, config: CommandBuilder) => {
852
+ const cmd = config.getClosestNonNativeParent()
853
+ const cfg = cmd.db.config
854
+ if (!action || action === 'edit') {
855
+ cfg.edit(opts.editor)
856
+ return console.info(cfg.getAll())
857
+ } else if (action === 'list') {
858
+ return console.dir(
859
+ cfg.keys.map((key: string) => {
860
+ return {
861
+ key,
862
+ description: cfg.descriptions[key],
863
+ value: cfg.get(key),
864
+ defaultValue: cfg.defaultValues,
865
+ }
866
+ })
867
+ )
868
+ } else if (action === 'get') {
869
+ if (key) return console.log(cfg.get(key))
870
+ else return console.log(cfg.getAll())
871
+ } else if (action === 'set') {
872
+ const from = cfg.get(key)
873
+ const parse = cfg.parsers[key]
874
+ const to = typeof parse === 'function' ? cfg.parsers[key](value) : value
875
+ cfg.set(key, to)
876
+ return console.info({ changed: key, from, to })
877
+ } else if (action === 'reset') {
878
+ if (key) cfg.reset(key)
879
+ else cfg.resetAll()
880
+ return console.info(cfg.getAll())
881
+ }
882
+ }
883
+ )*/
884
+ }
885
+ });
886
+ }
887
+ /**
888
+ * Makes aliases for the command.
889
+ * The idea is to be able to navigate the command tree by only typing the first letter(s) of the command names.
890
+ *
891
+ * Example: A command 'cola' would get these aliases: ['c', 'co', 'col'].
892
+ * However, if there are namespace clashes with sibling subcommands that start with the same letter,
893
+ * eg. like 'cola' and 'coal' where the first two letters clash, cola's aliases are reduced to only ['col'] and similarly for 'coal'.
894
+ *
895
+ * This method creates the aliases, ensuring there are no clashes with sublings, why it is important that the
896
+ * entire command tree is built before invoking this method.
897
+ */
898
+ assignSubCommandAliases() {
899
+ if (this.getAlias() || this.name.length <= 1)
900
+ return this;
901
+ const sibAliases = this.getSiblings()
902
+ .map((sib) => sib.getAliases())
903
+ .flat();
904
+ for (let i = 0; i < this.name.length - 1; i++) {
905
+ let cmdAlias = this.name.substring(0, i + 1);
906
+ let isClash = arrSome(sibAliases, (sibAlias) => {
907
+ return cmdAlias === sibAlias;
908
+ });
909
+ if (isClash && i === 0) {
910
+ cmdAlias = cmdAlias.charAt(0).toUpperCase();
911
+ isClash = arrSome(sibAliases, (sibAlias) => {
912
+ return cmdAlias === sibAlias;
913
+ });
914
+ }
915
+ if (isClash)
916
+ continue;
917
+ this.alias(cmdAlias);
918
+ return this;
919
+ }
920
+ return this;
921
+ }
922
+ /**
923
+ * Automatically set 'short' and 'long' names to options that don't have one assigned yet.
924
+ *
925
+ * First, it tries to assign a short name based on the first letter of the option's attribute name
926
+ * Both lower and upper case are tried. If these is not available, the next letter of the option name is tried.
927
+ *
928
+ * If none of the letters of the option name are available, the option is skipped until all other
929
+ * options have had letters from their names attempted assigned.
930
+ * Those that remain are assigned the first available letter of the alphabet + 0-9.
931
+ * If there are 64 options for the command and no more alphanumeric characters are available,
932
+ * the option is not assigned a short name.
933
+ */
934
+ assignMissingOptionFlags() {
935
+ const taken = new Set();
936
+ for (const anc of this.getAncestorsIterator({ includeSelf: true })) {
937
+ anc.options.forEach((opt) => {
938
+ if (!opt.short)
939
+ return;
940
+ taken.add(opt.short.replace(/^-/g, ''));
941
+ });
942
+ }
943
+ const failed = new Set();
944
+ // assign letter from option name
945
+ this.options.forEach((opt) => {
946
+ if (opt.short)
947
+ return;
948
+ const name = opt.attributeName();
949
+ for (let c = 0; c < name.length; c++) {
950
+ let char = name.charAt(c).toLowerCase();
951
+ if (taken.has(char)) {
952
+ char = char.toUpperCase();
953
+ if (taken.has(char))
954
+ continue;
955
+ }
956
+ OptionHelpers.setShort(opt, char);
957
+ taken.add(char);
958
+ return;
959
+ }
960
+ failed.add(opt);
961
+ });
962
+ // assign random alphanumeric character.
963
+ const name = 'abcdefghijklmnopqrstuvwxyz1234567890';
964
+ failed.forEach((opt) => {
965
+ for (let c = 0; c < name.length; c++) {
966
+ let char = name.charAt(c);
967
+ if (taken.has(char)) {
968
+ char = char.toUpperCase();
969
+ if (taken.has(char))
970
+ continue;
971
+ }
972
+ OptionHelpers.setShort(opt, char);
973
+ taken.add(char);
974
+ return;
975
+ }
976
+ });
977
+ }
978
+ assertNoDuplicateCommandNames() {
979
+ const names = this.$.commands.map((sub) => sub.aliases().concat(sub.name())).flat();
980
+ if (names.length !== new Set(names).size) {
981
+ this.throwCommanderError(`Duplicate subcommand names/aliases found for command, ${this.name}: ${names.join(', ')}`);
982
+ }
983
+ }
984
+ hasIdenticalParentOption(option) {
985
+ const flags = option.flags;
986
+ for (const anc of this.getAncestorsIterator({ includeSelf: true })) {
987
+ for (const opt of anc.$.options) {
988
+ if (flags === opt.flags) {
989
+ return true;
990
+ }
991
+ }
992
+ }
993
+ return false;
994
+ }
995
+ assertNoDuplicateOptionNames() {
996
+ const throwErr = (cmd, opt, anc) => {
997
+ this.throwCommanderError(`Duplicate option names > cmd: ${cmd.name}, ${anc ? `anc: ${anc.name}, ` : ''}opt: ${opt}`);
998
+ };
999
+ const set = new Set();
1000
+ for (const opt of this.options) {
1001
+ if (opt.name() === 'help')
1002
+ continue;
1003
+ if (opt.short) {
1004
+ if (set.has(opt.short))
1005
+ throwErr(this, opt.short);
1006
+ set.add(opt.short);
1007
+ }
1008
+ if (opt.long) {
1009
+ if (set.has(opt.long))
1010
+ throwErr(this, opt.long);
1011
+ set.add(opt.long);
1012
+ }
1013
+ if (opt.attributeName()) {
1014
+ if (set.has(opt.attributeName()))
1015
+ throwErr(this, opt.attributeName());
1016
+ set.add(opt.attributeName());
1017
+ }
1018
+ }
1019
+ for (const anc of this.getAncestorsIterator()) {
1020
+ for (const opt of anc.$.options) {
1021
+ if (opt.short && set.has(opt.short)) {
1022
+ if (opt.short !== 'V')
1023
+ continue;
1024
+ throwErr(this, opt.short, anc);
1025
+ }
1026
+ if (opt.long && set.has(opt.long)) {
1027
+ throwErr(this, opt.long, anc);
1028
+ }
1029
+ if (opt.attributeName() && set.has(opt.attributeName())) {
1030
+ throwErr(this, opt.attributeName(), anc);
1031
+ }
1032
+ }
1033
+ }
1034
+ }
1035
+ initializeActionWrapper(isAsync = false) {
1036
+ if (isAsync) {
1037
+ this.$.action(async () => {
1038
+ try {
1039
+ this.handleOutputOptions();
1040
+ const [args, opts] = this.getParsedValidArgsOptsWithPresets();
1041
+ if (opts['help'])
1042
+ return this.outputHelp();
1043
+ const owg = this.$.optsWithGlobals();
1044
+ await this.meta.actionHandler.call(this, ...args, opts, this);
1045
+ }
1046
+ catch (error) {
1047
+ this.meta.errorHandler.call(this, error, this);
1048
+ }
1049
+ });
1050
+ }
1051
+ else {
1052
+ this.$.action(() => {
1053
+ try {
1054
+ this.handleOutputOptions();
1055
+ const [args, opts] = this.getParsedValidArgsOptsWithPresets();
1056
+ if (opts['help'])
1057
+ return this.outputHelp();
1058
+ const owg = this.$.optsWithGlobals();
1059
+ this.meta.actionHandler.call(this, ...args, opts, this);
1060
+ }
1061
+ catch (error) {
1062
+ this.meta.errorHandler.call(this, error, this);
1063
+ }
1064
+ });
1065
+ }
1066
+ }
1067
+ initializeHelp() {
1068
+ if (this.isRoot)
1069
+ this.globalOption('-h, --help', 'show help');
1070
+ this.$.addHelpCommand('?', 'show help');
1071
+ this.$.configureHelp(DefaultHelpConfig);
1072
+ }
1073
+ inheritParentHiddenGlobals() {
1074
+ if (!this.parent)
1075
+ return;
1076
+ for (const opt of this.parent.meta.hiddenGlobalOptions) {
1077
+ this.meta.hiddenGlobalOptions.add(opt);
1078
+ }
1079
+ }
1080
+ assertCommandNameNotReserved(name) {
1081
+ if (this.isRoot)
1082
+ return;
1083
+ if (this.meta.isNative)
1084
+ return;
1085
+ if (name === 'u' || name === 'util') {
1086
+ this.throwCommanderError(`Name '${name}' is reserved and is not available as name or alias.`);
1087
+ }
1088
+ }
1089
+ }
1090
+ process.argv = splitCombinedArgvShorts(process.argv.slice());
1091
+ //# sourceMappingURL=CommandBuilder.js.map