@bemoje/cli 0.0.4 → 0.0.6

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 (698) hide show
  1. package/.eslintrc.json +5 -0
  2. package/.swcrc +32 -0
  3. package/dist/cjs/_example/bFindIn.js +189 -0
  4. package/dist/cjs/_example/bFindIn.js.map +1 -0
  5. package/dist/cjs/arg/ArgumentBuilder.js +45 -0
  6. package/dist/cjs/arg/ArgumentBuilder.js.map +1 -0
  7. package/dist/cjs/arg/ArgumentParserSelector.js +15 -0
  8. package/dist/cjs/arg/ArgumentParserSelector.js.map +1 -0
  9. package/dist/cjs/arg/ArgumentReader.js +38 -0
  10. package/dist/cjs/arg/ArgumentReader.js.map +1 -0
  11. package/dist/cjs/arg/ArgumentValidatorSelector.js +16 -0
  12. package/dist/cjs/arg/ArgumentValidatorSelector.js.map +1 -0
  13. package/dist/cjs/cmd/CommandBuilder.js +1080 -0
  14. package/dist/cjs/cmd/CommandBuilder.js.map +1 -0
  15. package/dist/cjs/cmd/CommandBuilderMetaData.js +44 -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 +119 -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/types/IConfig.js +3 -0
  54. package/dist/cjs/types/IConfig.js.map +1 -0
  55. package/dist/cjs/types/IPreset.js +3 -0
  56. package/dist/cjs/types/IPreset.js.map +1 -0
  57. package/dist/cjs/util/array/arrLast.js +21 -0
  58. package/dist/cjs/util/array/arrLast.js.map +1 -0
  59. package/dist/cjs/util/array/arrSome.js +26 -0
  60. package/dist/cjs/util/array/arrSome.js.map +1 -0
  61. package/dist/cjs/util/array/types/ArrayPredicate.js +3 -0
  62. package/dist/cjs/util/array/types/ArrayPredicate.js.map +1 -0
  63. package/dist/cjs/util/db/JsonDB.js +145 -0
  64. package/dist/cjs/util/db/JsonDB.js.map +1 -0
  65. package/dist/cjs/util/errors/ErrorParser.js +164 -0
  66. package/dist/cjs/util/errors/ErrorParser.js.map +1 -0
  67. package/dist/cjs/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js +3 -0
  68. package/dist/cjs/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js.map +1 -0
  69. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js +32 -0
  70. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js.map +1 -0
  71. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js +25 -0
  72. package/dist/cjs/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js.map +1 -0
  73. package/dist/cjs/util/fs/readFile/readFileSafeSync.js +28 -0
  74. package/dist/cjs/util/fs/readFile/readFileSafeSync.js.map +1 -0
  75. package/dist/cjs/util/fs/readFile/readFileSync.js +20 -0
  76. package/dist/cjs/util/fs/readFile/readFileSync.js.map +1 -0
  77. package/dist/cjs/util/fs/readJsonFile/readJsonFileSafeSync.js +24 -0
  78. package/dist/cjs/util/fs/readJsonFile/readJsonFileSafeSync.js.map +1 -0
  79. package/dist/cjs/util/fs/removeFile/removeFile.js +6 -0
  80. package/dist/cjs/util/fs/removeFile/removeFile.js.map +1 -0
  81. package/dist/cjs/util/fs/tempFile/tempFileSync.js +28 -0
  82. package/dist/cjs/util/fs/tempFile/tempFileSync.js.map +1 -0
  83. package/dist/cjs/util/fs/types/IReadJsonFileOptions.js +3 -0
  84. package/dist/cjs/util/fs/types/IReadJsonFileOptions.js.map +1 -0
  85. package/dist/cjs/util/fs/writeFile/writeFileSafeSync.js +6 -0
  86. package/dist/cjs/util/fs/writeFile/writeFileSafeSync.js.map +1 -0
  87. package/dist/cjs/util/fs/writeFile/writeFileSync.js +6 -0
  88. package/dist/cjs/util/fs/writeFile/writeFileSync.js.map +1 -0
  89. package/dist/cjs/util/fs/writeJsonFile/writeJsonFileSafe.js +6 -0
  90. package/dist/cjs/util/fs/writeJsonFile/writeJsonFileSafe.js.map +1 -0
  91. package/dist/cjs/util/function/MethodDisabler.js +94 -0
  92. package/dist/cjs/util/function/MethodDisabler.js.map +1 -0
  93. package/dist/cjs/util/function/funSetName.js +21 -0
  94. package/dist/cjs/util/function/funSetName.js.map +1 -0
  95. package/dist/cjs/util/node/execInherit.js +19 -0
  96. package/dist/cjs/util/node/execInherit.js.map +1 -0
  97. package/dist/cjs/util/node/formatTableForTerminal.js +21 -0
  98. package/dist/cjs/util/node/formatTableForTerminal.js.map +1 -0
  99. package/dist/cjs/util/object/arrAssign.js +6 -0
  100. package/dist/cjs/util/object/arrAssign.js.map +1 -0
  101. package/dist/cjs/util/object/createArrayMerger.js +20 -0
  102. package/dist/cjs/util/object/createArrayMerger.js.map +1 -0
  103. package/dist/cjs/util/object/createObjectMerger.js +20 -0
  104. package/dist/cjs/util/object/createObjectMerger.js.map +1 -0
  105. package/dist/cjs/util/object/objAssign.js +6 -0
  106. package/dist/cjs/util/object/objAssign.js.map +1 -0
  107. package/dist/cjs/util/object/objUpdatePropertyDescriptors.js +28 -0
  108. package/dist/cjs/util/object/objUpdatePropertyDescriptors.js.map +1 -0
  109. package/dist/cjs/util/object/realizeLazyProperty.js +14 -0
  110. package/dist/cjs/util/object/realizeLazyProperty.js.map +1 -0
  111. package/dist/cjs/util/object/setNonEnumerable.js +25 -0
  112. package/dist/cjs/util/object/setNonEnumerable.js.map +1 -0
  113. package/dist/cjs/util/os/defaultOpenInEditorCommand.js +18 -0
  114. package/dist/cjs/util/os/defaultOpenInEditorCommand.js.map +1 -0
  115. package/dist/cjs/util/os/isOSX.js +13 -0
  116. package/dist/cjs/util/os/isOSX.js.map +1 -0
  117. package/dist/cjs/util/os/isVsCodeInstalled.js +19 -0
  118. package/dist/cjs/util/os/isVsCodeInstalled.js.map +1 -0
  119. package/dist/cjs/util/os/isWindows.js +16 -0
  120. package/dist/cjs/util/os/isWindows.js.map +1 -0
  121. package/dist/cjs/util/path/getTempDataPath.js +20 -0
  122. package/dist/cjs/util/path/getTempDataPath.js.map +1 -0
  123. package/dist/cjs/util/regex/regexEscapeString.js +18 -0
  124. package/dist/cjs/util/regex/regexEscapeString.js.map +1 -0
  125. package/dist/cjs/util/string/strEnsureStartsWith.js +19 -0
  126. package/dist/cjs/util/string/strEnsureStartsWith.js.map +1 -0
  127. package/dist/cjs/util/string/strFirstCharToUpperCase.js +16 -0
  128. package/dist/cjs/util/string/strFirstCharToUpperCase.js.map +1 -0
  129. package/dist/cjs/util/string/strIsLowerCase.js +18 -0
  130. package/dist/cjs/util/string/strIsLowerCase.js.map +1 -0
  131. package/dist/cjs/util/string/strIsUpperCase.js +18 -0
  132. package/dist/cjs/util/string/strIsUpperCase.js.map +1 -0
  133. package/dist/cjs/util/string/strSplitCamelCase.js +55 -0
  134. package/dist/cjs/util/string/strSplitCamelCase.js.map +1 -0
  135. package/dist/cjs/util/string-parsers/createBooleanParser.js +21 -0
  136. package/dist/cjs/util/string-parsers/createBooleanParser.js.map +1 -0
  137. package/dist/cjs/util/string-parsers/createTypedListParser.js +22 -0
  138. package/dist/cjs/util/string-parsers/createTypedListParser.js.map +1 -0
  139. package/dist/cjs/util/string-parsers/parseBoolean.js +15 -0
  140. package/dist/cjs/util/string-parsers/parseBoolean.js.map +1 -0
  141. package/dist/cjs/util/string-parsers/parseInteger.js +17 -0
  142. package/dist/cjs/util/string-parsers/parseInteger.js.map +1 -0
  143. package/dist/cjs/util/string-parsers/parseNumber.js +13 -0
  144. package/dist/cjs/util/string-parsers/parseNumber.js.map +1 -0
  145. package/dist/cjs/util/string-parsers/parseString.js +8 -0
  146. package/dist/cjs/util/string-parsers/parseString.js.map +1 -0
  147. package/dist/cjs/util/types/Any.js +3 -0
  148. package/dist/cjs/util/types/Any.js.map +1 -0
  149. package/dist/cjs/util/types/DeepArray.js +3 -0
  150. package/dist/cjs/util/types/DeepArray.js.map +1 -0
  151. package/dist/cjs/util/types/DeepObject.js +3 -0
  152. package/dist/cjs/util/types/DeepObject.js.map +1 -0
  153. package/dist/cjs/util/types/JsonArray.js +3 -0
  154. package/dist/cjs/util/types/JsonArray.js.map +1 -0
  155. package/dist/cjs/util/types/JsonDefinedPrimitive.js +6 -0
  156. package/dist/cjs/util/types/JsonDefinedPrimitive.js.map +1 -0
  157. package/dist/cjs/util/types/JsonObject.js +3 -0
  158. package/dist/cjs/util/types/JsonObject.js.map +1 -0
  159. package/dist/cjs/util/types/JsonRawPrimitive.js +3 -0
  160. package/dist/cjs/util/types/JsonRawPrimitive.js.map +1 -0
  161. package/dist/cjs/util/types/JsonValue.js +3 -0
  162. package/dist/cjs/util/types/JsonValue.js.map +1 -0
  163. package/dist/cjs/util/types/ObjectKey.js +3 -0
  164. package/dist/cjs/util/types/ObjectKey.js.map +1 -0
  165. package/dist/cjs/util/types/TConstructor.js +3 -0
  166. package/dist/cjs/util/types/TConstructor.js.map +1 -0
  167. package/dist/cjs/util/types/TFunction.js +3 -0
  168. package/dist/cjs/util/types/TFunction.js.map +1 -0
  169. package/dist/cjs/util/types/TFunctionNoNew.js +3 -0
  170. package/dist/cjs/util/types/TFunctionNoNew.js.map +1 -0
  171. package/dist/cjs/util/types/TPlainObject.js +3 -0
  172. package/dist/cjs/util/types/TPlainObject.js.map +1 -0
  173. package/dist/cjs/util/types/TPrimitive.js +3 -0
  174. package/dist/cjs/util/types/TPrimitive.js.map +1 -0
  175. package/dist/cjs/util/types/TStringParser.js +3 -0
  176. package/dist/cjs/util/types/TStringParser.js.map +1 -0
  177. package/dist/cjs/util/types/TValidator.js +3 -0
  178. package/dist/cjs/util/types/TValidator.js.map +1 -0
  179. package/dist/cjs/util/validation/createTypedArrayValidator.js +26 -0
  180. package/dist/cjs/util/validation/createTypedArrayValidator.js.map +1 -0
  181. package/dist/cjs/util/validation/ensureThat.js +12 -0
  182. package/dist/cjs/util/validation/ensureThat.js.map +1 -0
  183. package/dist/cjs/util/validation/isArray.js +5 -0
  184. package/dist/cjs/util/validation/isArray.js.map +1 -0
  185. package/dist/cjs/util/validation/isBoolean.js +8 -0
  186. package/dist/cjs/util/validation/isBoolean.js.map +1 -0
  187. package/dist/cjs/util/validation/isFunction.js +17 -0
  188. package/dist/cjs/util/validation/isFunction.js.map +1 -0
  189. package/dist/cjs/util/validation/isNamedFunction.js +11 -0
  190. package/dist/cjs/util/validation/isNamedFunction.js.map +1 -0
  191. package/dist/cjs/util/validation/isNamedFunctionArray.js +9 -0
  192. package/dist/cjs/util/validation/isNamedFunctionArray.js.map +1 -0
  193. package/dist/cjs/util/validation/isObject.js +22 -0
  194. package/dist/cjs/util/validation/isObject.js.map +1 -0
  195. package/dist/cjs/util/validation/isPlainObject.js +19 -0
  196. package/dist/cjs/util/validation/isPlainObject.js.map +1 -0
  197. package/dist/cjs/util/validation/isPrimitive.js +18 -0
  198. package/dist/cjs/util/validation/isPrimitive.js.map +1 -0
  199. package/dist/cjs/util/validation/isString.js +8 -0
  200. package/dist/cjs/util/validation/isString.js.map +1 -0
  201. package/dist/cjs/util/validation/isStringArray.js +12 -0
  202. package/dist/cjs/util/validation/isStringArray.js.map +1 -0
  203. package/dist/cjs/util/validation/isStringWithNoSpacesOrDashes.js +9 -0
  204. package/dist/cjs/util/validation/isStringWithNoSpacesOrDashes.js.map +1 -0
  205. package/dist/cjs/util/validation/numbers/isInteger.js +17 -0
  206. package/dist/cjs/util/validation/numbers/isInteger.js.map +1 -0
  207. package/dist/cjs/util/validation/numbers/isValidNumber.js +22 -0
  208. package/dist/cjs/util/validation/numbers/isValidNumber.js.map +1 -0
  209. package/dist/esm/_example/bFindIn.js +187 -0
  210. package/dist/esm/_example/bFindIn.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/CommandBuilder.js +1073 -0
  220. package/dist/esm/cmd/CommandBuilder.js.map +1 -0
  221. package/dist/esm/cmd/CommandBuilderMetaData.js +40 -0
  222. package/dist/esm/cmd/CommandBuilderMetaData.js.map +1 -0
  223. package/dist/esm/cmd/CommandFeatureSelector.js +108 -0
  224. package/dist/esm/cmd/CommandFeatureSelector.js.map +1 -0
  225. package/dist/esm/cmd/DefaultHelpConfig.js +135 -0
  226. package/dist/esm/cmd/DefaultHelpConfig.js.map +1 -0
  227. package/dist/esm/cmd/asdas.js +25 -0
  228. package/dist/esm/cmd/asdas.js.map +1 -0
  229. package/dist/esm/core/OutputManager.js +92 -0
  230. package/dist/esm/core/OutputManager.js.map +1 -0
  231. package/dist/esm/core/ParserSelector.js +32 -0
  232. package/dist/esm/core/ParserSelector.js.map +1 -0
  233. package/dist/esm/core/ValidatorSelector.js +32 -0
  234. package/dist/esm/core/ValidatorSelector.js.map +1 -0
  235. package/dist/esm/core/splitCombinedArgvShorts.js +11 -0
  236. package/dist/esm/core/splitCombinedArgvShorts.js.map +1 -0
  237. package/dist/esm/db/AbstractJsonFileSection.js +186 -0
  238. package/dist/esm/db/AbstractJsonFileSection.js.map +1 -0
  239. package/dist/esm/db/AppDataSection.js +44 -0
  240. package/dist/esm/db/AppDataSection.js.map +1 -0
  241. package/dist/esm/db/ConfigSection.js +67 -0
  242. package/dist/esm/db/ConfigSection.js.map +1 -0
  243. package/dist/esm/db/JsonFile.js +51 -0
  244. package/dist/esm/db/JsonFile.js.map +1 -0
  245. package/dist/esm/db/PresetsSection.js +88 -0
  246. package/dist/esm/db/PresetsSection.js.map +1 -0
  247. package/dist/esm/index.js +103 -0
  248. package/dist/esm/index.js.map +1 -0
  249. package/dist/esm/opt/OptionArgumentParserSelector.js +12 -0
  250. package/dist/esm/opt/OptionArgumentParserSelector.js.map +1 -0
  251. package/dist/esm/opt/OptionArgumentValidatorSelector.js +15 -0
  252. package/dist/esm/opt/OptionArgumentValidatorSelector.js.map +1 -0
  253. package/dist/esm/opt/OptionBuilder.js +84 -0
  254. package/dist/esm/opt/OptionBuilder.js.map +1 -0
  255. package/dist/esm/opt/OptionHelpers.js +54 -0
  256. package/dist/esm/opt/OptionHelpers.js.map +1 -0
  257. package/dist/esm/opt/OptionReader.js +62 -0
  258. package/dist/esm/opt/OptionReader.js.map +1 -0
  259. package/dist/esm/types/IConfig.js +2 -0
  260. package/dist/esm/types/IConfig.js.map +1 -0
  261. package/dist/esm/types/IPreset.js +2 -0
  262. package/dist/esm/types/IPreset.js.map +1 -0
  263. package/dist/esm/util/array/arrLast.js +17 -0
  264. package/dist/esm/util/array/arrLast.js.map +1 -0
  265. package/dist/esm/util/array/arrSome.js +22 -0
  266. package/dist/esm/util/array/arrSome.js.map +1 -0
  267. package/dist/esm/util/array/types/ArrayPredicate.js +2 -0
  268. package/dist/esm/util/array/types/ArrayPredicate.js.map +1 -0
  269. package/dist/esm/util/db/JsonDB.js +141 -0
  270. package/dist/esm/util/db/JsonDB.js.map +1 -0
  271. package/dist/esm/util/errors/ErrorParser.js +154 -0
  272. package/dist/esm/util/errors/ErrorParser.js.map +1 -0
  273. package/dist/esm/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js +2 -0
  274. package/dist/esm/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.js.map +1 -0
  275. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js +28 -0
  276. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.js.map +1 -0
  277. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js +21 -0
  278. package/dist/esm/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.js.map +1 -0
  279. package/dist/esm/util/fs/readFile/readFileSafeSync.js +21 -0
  280. package/dist/esm/util/fs/readFile/readFileSafeSync.js.map +1 -0
  281. package/dist/esm/util/fs/readFile/readFileSync.js +13 -0
  282. package/dist/esm/util/fs/readFile/readFileSync.js.map +1 -0
  283. package/dist/esm/util/fs/readJsonFile/readJsonFileSafeSync.js +17 -0
  284. package/dist/esm/util/fs/readJsonFile/readJsonFileSafeSync.js.map +1 -0
  285. package/dist/esm/util/fs/removeFile/removeFile.js +2 -0
  286. package/dist/esm/util/fs/removeFile/removeFile.js.map +1 -0
  287. package/dist/esm/util/fs/tempFile/tempFileSync.js +21 -0
  288. package/dist/esm/util/fs/tempFile/tempFileSync.js.map +1 -0
  289. package/dist/esm/util/fs/types/IReadJsonFileOptions.js +2 -0
  290. package/dist/esm/util/fs/types/IReadJsonFileOptions.js.map +1 -0
  291. package/dist/esm/util/fs/writeFile/writeFileSafeSync.js +2 -0
  292. package/dist/esm/util/fs/writeFile/writeFileSafeSync.js.map +1 -0
  293. package/dist/esm/util/fs/writeFile/writeFileSync.js +2 -0
  294. package/dist/esm/util/fs/writeFile/writeFileSync.js.map +1 -0
  295. package/dist/esm/util/fs/writeJsonFile/writeJsonFileSafe.js +2 -0
  296. package/dist/esm/util/fs/writeJsonFile/writeJsonFileSafe.js.map +1 -0
  297. package/dist/esm/util/function/MethodDisabler.js +90 -0
  298. package/dist/esm/util/function/MethodDisabler.js.map +1 -0
  299. package/dist/esm/util/function/funSetName.js +17 -0
  300. package/dist/esm/util/function/funSetName.js.map +1 -0
  301. package/dist/esm/util/node/execInherit.js +15 -0
  302. package/dist/esm/util/node/execInherit.js.map +1 -0
  303. package/dist/esm/util/node/formatTableForTerminal.js +14 -0
  304. package/dist/esm/util/node/formatTableForTerminal.js.map +1 -0
  305. package/dist/esm/util/object/arrAssign.js +3 -0
  306. package/dist/esm/util/object/arrAssign.js.map +1 -0
  307. package/dist/esm/util/object/createArrayMerger.js +16 -0
  308. package/dist/esm/util/object/createArrayMerger.js.map +1 -0
  309. package/dist/esm/util/object/createObjectMerger.js +16 -0
  310. package/dist/esm/util/object/createObjectMerger.js.map +1 -0
  311. package/dist/esm/util/object/objAssign.js +3 -0
  312. package/dist/esm/util/object/objAssign.js.map +1 -0
  313. package/dist/esm/util/object/objUpdatePropertyDescriptors.js +24 -0
  314. package/dist/esm/util/object/objUpdatePropertyDescriptors.js.map +1 -0
  315. package/dist/esm/util/object/realizeLazyProperty.js +10 -0
  316. package/dist/esm/util/object/realizeLazyProperty.js.map +1 -0
  317. package/dist/esm/util/object/setNonEnumerable.js +21 -0
  318. package/dist/esm/util/object/setNonEnumerable.js.map +1 -0
  319. package/dist/esm/util/os/defaultOpenInEditorCommand.js +14 -0
  320. package/dist/esm/util/os/defaultOpenInEditorCommand.js.map +1 -0
  321. package/dist/esm/util/os/isOSX.js +9 -0
  322. package/dist/esm/util/os/isOSX.js.map +1 -0
  323. package/dist/esm/util/os/isVsCodeInstalled.js +15 -0
  324. package/dist/esm/util/os/isVsCodeInstalled.js.map +1 -0
  325. package/dist/esm/util/os/isWindows.js +12 -0
  326. package/dist/esm/util/os/isWindows.js.map +1 -0
  327. package/dist/esm/util/path/getTempDataPath.js +13 -0
  328. package/dist/esm/util/path/getTempDataPath.js.map +1 -0
  329. package/dist/esm/util/regex/regexEscapeString.js +14 -0
  330. package/dist/esm/util/regex/regexEscapeString.js.map +1 -0
  331. package/dist/esm/util/string/strEnsureStartsWith.js +15 -0
  332. package/dist/esm/util/string/strEnsureStartsWith.js.map +1 -0
  333. package/dist/esm/util/string/strFirstCharToUpperCase.js +12 -0
  334. package/dist/esm/util/string/strFirstCharToUpperCase.js.map +1 -0
  335. package/dist/esm/util/string/strIsLowerCase.js +14 -0
  336. package/dist/esm/util/string/strIsLowerCase.js.map +1 -0
  337. package/dist/esm/util/string/strIsUpperCase.js +14 -0
  338. package/dist/esm/util/string/strIsUpperCase.js.map +1 -0
  339. package/dist/esm/util/string/strSplitCamelCase.js +51 -0
  340. package/dist/esm/util/string/strSplitCamelCase.js.map +1 -0
  341. package/dist/esm/util/string-parsers/createBooleanParser.js +17 -0
  342. package/dist/esm/util/string-parsers/createBooleanParser.js.map +1 -0
  343. package/dist/esm/util/string-parsers/createTypedListParser.js +18 -0
  344. package/dist/esm/util/string-parsers/createTypedListParser.js.map +1 -0
  345. package/dist/esm/util/string-parsers/parseBoolean.js +12 -0
  346. package/dist/esm/util/string-parsers/parseBoolean.js.map +1 -0
  347. package/dist/esm/util/string-parsers/parseInteger.js +13 -0
  348. package/dist/esm/util/string-parsers/parseInteger.js.map +1 -0
  349. package/dist/esm/util/string-parsers/parseNumber.js +9 -0
  350. package/dist/esm/util/string-parsers/parseNumber.js.map +1 -0
  351. package/dist/esm/util/string-parsers/parseString.js +4 -0
  352. package/dist/esm/util/string-parsers/parseString.js.map +1 -0
  353. package/dist/esm/util/types/Any.js +2 -0
  354. package/dist/esm/util/types/Any.js.map +1 -0
  355. package/dist/esm/util/types/DeepArray.js +2 -0
  356. package/dist/esm/util/types/DeepArray.js.map +1 -0
  357. package/dist/esm/util/types/DeepObject.js +2 -0
  358. package/dist/esm/util/types/DeepObject.js.map +1 -0
  359. package/dist/esm/util/types/JsonArray.js +2 -0
  360. package/dist/esm/util/types/JsonArray.js.map +1 -0
  361. package/dist/esm/util/types/JsonDefinedPrimitive.js +5 -0
  362. package/dist/esm/util/types/JsonDefinedPrimitive.js.map +1 -0
  363. package/dist/esm/util/types/JsonObject.js +2 -0
  364. package/dist/esm/util/types/JsonObject.js.map +1 -0
  365. package/dist/esm/util/types/JsonRawPrimitive.js +2 -0
  366. package/dist/esm/util/types/JsonRawPrimitive.js.map +1 -0
  367. package/dist/esm/util/types/JsonValue.js +2 -0
  368. package/dist/esm/util/types/JsonValue.js.map +1 -0
  369. package/dist/esm/util/types/ObjectKey.js +2 -0
  370. package/dist/esm/util/types/ObjectKey.js.map +1 -0
  371. package/dist/esm/util/types/TConstructor.js +2 -0
  372. package/dist/esm/util/types/TConstructor.js.map +1 -0
  373. package/dist/esm/util/types/TFunction.js +2 -0
  374. package/dist/esm/util/types/TFunction.js.map +1 -0
  375. package/dist/esm/util/types/TFunctionNoNew.js +2 -0
  376. package/dist/esm/util/types/TFunctionNoNew.js.map +1 -0
  377. package/dist/esm/util/types/TPlainObject.js +2 -0
  378. package/dist/esm/util/types/TPlainObject.js.map +1 -0
  379. package/dist/esm/util/types/TPrimitive.js +2 -0
  380. package/dist/esm/util/types/TPrimitive.js.map +1 -0
  381. package/dist/esm/util/types/TStringParser.js +2 -0
  382. package/dist/esm/util/types/TStringParser.js.map +1 -0
  383. package/dist/esm/util/types/TValidator.js +2 -0
  384. package/dist/esm/util/types/TValidator.js.map +1 -0
  385. package/dist/esm/util/validation/createTypedArrayValidator.js +22 -0
  386. package/dist/esm/util/validation/createTypedArrayValidator.js.map +1 -0
  387. package/dist/esm/util/validation/ensureThat.js +8 -0
  388. package/dist/esm/util/validation/ensureThat.js.map +1 -0
  389. package/dist/esm/util/validation/isArray.js +2 -0
  390. package/dist/esm/util/validation/isArray.js.map +1 -0
  391. package/dist/esm/util/validation/isBoolean.js +4 -0
  392. package/dist/esm/util/validation/isBoolean.js.map +1 -0
  393. package/dist/esm/util/validation/isFunction.js +13 -0
  394. package/dist/esm/util/validation/isFunction.js.map +1 -0
  395. package/dist/esm/util/validation/isNamedFunction.js +7 -0
  396. package/dist/esm/util/validation/isNamedFunction.js.map +1 -0
  397. package/dist/esm/util/validation/isNamedFunctionArray.js +5 -0
  398. package/dist/esm/util/validation/isNamedFunctionArray.js.map +1 -0
  399. package/dist/esm/util/validation/isObject.js +18 -0
  400. package/dist/esm/util/validation/isObject.js.map +1 -0
  401. package/dist/esm/util/validation/isPlainObject.js +15 -0
  402. package/dist/esm/util/validation/isPlainObject.js.map +1 -0
  403. package/dist/esm/util/validation/isPrimitive.js +14 -0
  404. package/dist/esm/util/validation/isPrimitive.js.map +1 -0
  405. package/dist/esm/util/validation/isString.js +4 -0
  406. package/dist/esm/util/validation/isString.js.map +1 -0
  407. package/dist/esm/util/validation/isStringArray.js +8 -0
  408. package/dist/esm/util/validation/isStringArray.js.map +1 -0
  409. package/dist/esm/util/validation/isStringWithNoSpacesOrDashes.js +5 -0
  410. package/dist/esm/util/validation/isStringWithNoSpacesOrDashes.js.map +1 -0
  411. package/dist/esm/util/validation/numbers/isInteger.js +14 -0
  412. package/dist/esm/util/validation/numbers/isInteger.js.map +1 -0
  413. package/dist/esm/util/validation/numbers/isValidNumber.js +18 -0
  414. package/dist/esm/util/validation/numbers/isValidNumber.js.map +1 -0
  415. package/dist/types/_example/bFindIn.d.ts +1 -0
  416. package/{src → dist/types}/arg/ArgumentBuilder.d.ts +1 -1
  417. package/{src → dist/types}/arg/ArgumentParserSelector.d.ts +2 -2
  418. package/{src → dist/types}/arg/ArgumentReader.d.ts +3 -3
  419. package/{src → dist/types}/arg/ArgumentValidatorSelector.d.ts +2 -2
  420. package/{src → dist/types}/cmd/CommandBuilder.d.ts +32 -28
  421. package/{src → dist/types}/cmd/CommandBuilderMetaData.d.ts +8 -7
  422. package/{src → dist/types}/cmd/CommandFeatureSelector.d.ts +1 -1
  423. package/dist/types/cmd/DefaultHelpConfig.d.ts +28 -0
  424. package/dist/types/cmd/asdas.d.ts +6 -0
  425. package/{src → dist/types}/core/OutputManager.d.ts +1 -1
  426. package/{src → dist/types}/core/ParserSelector.d.ts +3 -3
  427. package/{src → dist/types}/core/ValidatorSelector.d.ts +2 -2
  428. package/{src → dist/types}/db/AbstractJsonFileSection.d.ts +3 -3
  429. package/{src → dist/types}/db/AppDataSection.d.ts +1 -1
  430. package/{src → dist/types}/db/ConfigSection.d.ts +4 -4
  431. package/{src → dist/types}/db/PresetsSection.d.ts +2 -2
  432. package/{src → dist/types}/index.d.ts +2 -2
  433. package/{src → dist/types}/opt/OptionArgumentParserSelector.d.ts +1 -1
  434. package/{src → dist/types}/opt/OptionArgumentValidatorSelector.d.ts +2 -2
  435. package/{src → dist/types}/opt/OptionBuilder.d.ts +2 -1
  436. package/{src → dist/types}/opt/OptionHelpers.d.ts +2 -2
  437. package/{src → dist/types}/opt/OptionReader.d.ts +7 -7
  438. package/{src → dist/types}/types/IConfig.d.ts +3 -3
  439. package/{src → dist/types}/types/IPreset.d.ts +4 -3
  440. package/{src → dist/types}/util/db/JsonDB.d.ts +2 -2
  441. package/{src → dist/types}/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.d.ts +1 -1
  442. package/{src → dist/types}/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.d.ts +1 -1
  443. package/{src → dist/types}/util/fs/readJsonFile/readJsonFileSafeSync.d.ts +1 -1
  444. package/{src → dist/types}/util/fs/tempFile/tempFileSync.d.ts +1 -1
  445. package/{src → dist/types}/util/function/MethodDisabler.d.ts +3 -3
  446. package/{src → dist/types}/util/object/createObjectMerger.d.ts +1 -1
  447. package/{src → dist/types}/util/object/objUpdatePropertyDescriptors.d.ts +1 -1
  448. package/{src → dist/types}/util/object/setNonEnumerable.d.ts +1 -1
  449. package/{src → dist/types}/util/string-parsers/createTypedListParser.d.ts +1 -1
  450. package/{src → dist/types}/util/types/DeepArray.d.ts +2 -2
  451. package/{src → dist/types}/util/types/DeepObject.d.ts +2 -2
  452. package/{src → dist/types}/util/types/JsonArray.d.ts +2 -2
  453. package/{src → dist/types}/util/types/JsonObject.d.ts +2 -2
  454. package/{src → dist/types}/util/types/JsonRawPrimitive.d.ts +1 -1
  455. package/{src → dist/types}/util/types/JsonValue.d.ts +3 -3
  456. package/{src → dist/types}/util/types/TConstructor.d.ts +1 -1
  457. package/dist/types/util/types/TFunction.d.ts +4 -0
  458. package/{src → dist/types}/util/types/TFunctionNoNew.d.ts +1 -1
  459. package/{src → dist/types}/util/types/TPlainObject.d.ts +1 -1
  460. package/dist/types/util/types/TValidator.d.ts +2 -0
  461. package/{src → dist/types}/util/validation/ensureThat.d.ts +2 -2
  462. package/{src → dist/types}/util/validation/isFunction.d.ts +1 -1
  463. package/{src → dist/types}/util/validation/isNamedFunction.d.ts +1 -1
  464. package/{src → dist/types}/util/validation/isPlainObject.d.ts +2 -2
  465. package/{src → dist/types}/util/validation/isPrimitive.d.ts +1 -1
  466. package/jest.config.ts +11 -0
  467. package/notes/tsc.md +1 -0
  468. package/package.json +13 -6
  469. package/project.json +44 -0
  470. package/scripts/currentBemojeUtils.txt +41 -0
  471. package/scripts/rollupUtils.ts +184 -0
  472. package/src/_example/CommandBuilder.example.ts +92 -0
  473. package/src/_example/CommandBuilder.example2.ts +30 -0
  474. package/src/_example/bFindIn.ts +200 -0
  475. package/src/arg/ArgumentBuilder.test.ts +102 -0
  476. package/src/arg/ArgumentBuilder.ts +47 -0
  477. package/src/arg/ArgumentParserSelector.test.ts +53 -0
  478. package/src/arg/ArgumentParserSelector.ts +14 -0
  479. package/src/arg/ArgumentReader.test.ts +60 -0
  480. package/src/arg/ArgumentReader.ts +33 -0
  481. package/src/arg/ArgumentValidatorSelector.test.ts +80 -0
  482. package/src/arg/ArgumentValidatorSelector.ts +14 -0
  483. package/src/cmd/CommandBuilder.test.ts +611 -0
  484. package/src/cmd/CommandBuilder.ts +1164 -0
  485. package/src/cmd/CommandBuilderMetaData.test.ts +54 -0
  486. package/src/cmd/CommandBuilderMetaData.ts +45 -0
  487. package/src/cmd/CommandFeatureSelector.test.ts +185 -0
  488. package/src/cmd/CommandFeatureSelector.ts +113 -0
  489. package/src/cmd/DefaultHelpConfig.test.ts +22 -0
  490. package/src/cmd/DefaultHelpConfig.ts +141 -0
  491. package/src/cmd/asdas.ts +40 -0
  492. package/src/core/OutputManager.test.ts +129 -0
  493. package/src/core/OutputManager.ts +103 -0
  494. package/src/core/ParserSelector.test.ts +7 -0
  495. package/src/core/ParserSelector.ts +38 -0
  496. package/src/core/ValidatorSelector.test.ts +7 -0
  497. package/src/core/ValidatorSelector.ts +38 -0
  498. package/src/core/splitCombinedArgvShorts.test.ts +9 -0
  499. package/src/core/splitCombinedArgvShorts.ts +10 -0
  500. package/src/db/AbstractJsonFileSection.test.ts +274 -0
  501. package/src/db/AbstractJsonFileSection.ts +218 -0
  502. package/src/db/AppDataSection.test.ts +69 -0
  503. package/src/db/AppDataSection.ts +46 -0
  504. package/src/db/ConfigSection.test.ts +95 -0
  505. package/src/db/ConfigSection.ts +74 -0
  506. package/src/db/JsonFile.test.ts +56 -0
  507. package/src/db/JsonFile.ts +52 -0
  508. package/src/db/PresetsSection.test.ts +130 -0
  509. package/src/db/PresetsSection.ts +92 -0
  510. package/src/index.ts +102 -0
  511. package/src/opt/OptionArgumentParserSelector.test.ts +55 -0
  512. package/src/opt/OptionArgumentParserSelector.ts +14 -0
  513. package/src/opt/OptionArgumentValidatorSelector.test.ts +89 -0
  514. package/src/opt/OptionArgumentValidatorSelector.ts +16 -0
  515. package/src/opt/OptionBuilder.test.ts +229 -0
  516. package/src/opt/OptionBuilder.ts +85 -0
  517. package/src/opt/OptionHelpers.test.ts +229 -0
  518. package/src/opt/OptionHelpers.ts +57 -0
  519. package/src/opt/OptionReader.test.ts +106 -0
  520. package/src/opt/OptionReader.ts +61 -0
  521. package/src/types/IConfig.ts +25 -0
  522. package/src/types/IPreset.ts +16 -0
  523. package/src/util/array/arrLast.test.ts +25 -0
  524. package/src/util/array/arrLast.ts +15 -0
  525. package/src/util/array/arrSome.test.ts +78 -0
  526. package/src/util/array/arrSome.ts +23 -0
  527. package/src/util/array/types/ArrayPredicate.ts +10 -0
  528. package/src/util/db/JsonDB.test.ts +214 -0
  529. package/src/util/db/JsonDB.ts +138 -0
  530. package/src/util/errors/ErrorParser.ts +165 -0
  531. package/src/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.ts +15 -0
  532. package/src/util/fs/promptUserEditInTextEditor/promptUserEditInTextEditorSync.ts +30 -0
  533. package/src/util/fs/promptUserEditInTextEditor/promptUserEditJsonInTextEditorSync.ts +25 -0
  534. package/src/util/fs/readFile/readFileSafeSync.ts +20 -0
  535. package/src/util/fs/readFile/readFileSync.ts +13 -0
  536. package/src/util/fs/readJsonFile/readJsonFileSafeSync.ts +17 -0
  537. package/src/util/fs/removeFile/removeFile.ts +1 -0
  538. package/src/util/fs/tempFile/tempFileSync.ts +21 -0
  539. package/src/util/fs/types/IReadJsonFileOptions.ts +1 -0
  540. package/src/util/fs/writeFile/writeFileSafeSync.ts +1 -0
  541. package/src/util/fs/writeFile/writeFileSync.ts +1 -0
  542. package/src/util/fs/writeJsonFile/writeJsonFileSafe.ts +1 -0
  543. package/src/util/function/MethodDisabler.test.ts +112 -0
  544. package/src/util/function/MethodDisabler.ts +94 -0
  545. package/src/util/function/funSetName.test.ts +12 -0
  546. package/src/util/function/funSetName.ts +16 -0
  547. package/src/util/node/execInherit.ts +14 -0
  548. package/src/util/node/formatTableForTerminal.ts +12 -0
  549. package/src/util/object/arrAssign.ts +3 -0
  550. package/src/util/object/createArrayMerger.test.ts +11 -0
  551. package/src/util/object/createArrayMerger.ts +15 -0
  552. package/src/util/object/createObjectMerger.test.ts +11 -0
  553. package/src/util/object/createObjectMerger.ts +17 -0
  554. package/src/util/object/objAssign.ts +3 -0
  555. package/src/util/object/objUpdatePropertyDescriptors.test.ts +40 -0
  556. package/src/util/object/objUpdatePropertyDescriptors.ts +29 -0
  557. package/src/util/object/realizeLazyProperty.ts +9 -0
  558. package/src/util/object/setNonEnumerable.test.ts +63 -0
  559. package/src/util/object/setNonEnumerable.ts +22 -0
  560. package/src/util/os/defaultOpenInEditorCommand.ts +14 -0
  561. package/src/util/os/isOSX.ts +9 -0
  562. package/src/util/os/isVsCodeInstalled.test.ts +7 -0
  563. package/src/util/os/isVsCodeInstalled.ts +14 -0
  564. package/src/util/os/isWindows.ts +12 -0
  565. package/src/util/path/getTempDataPath.test.ts +9 -0
  566. package/src/util/path/getTempDataPath.ts +14 -0
  567. package/src/util/regex/regexEscapeString.test.ts +35 -0
  568. package/src/util/regex/regexEscapeString.ts +13 -0
  569. package/src/util/string/strEnsureStartsWith.test.ts +13 -0
  570. package/src/util/string/strEnsureStartsWith.ts +14 -0
  571. package/src/util/string/strFirstCharToUpperCase.test.ts +33 -0
  572. package/src/util/string/strFirstCharToUpperCase.ts +11 -0
  573. package/src/util/string/strIsLowerCase.test.ts +42 -0
  574. package/src/util/string/strIsLowerCase.ts +13 -0
  575. package/src/util/string/strIsUpperCase.test.ts +48 -0
  576. package/src/util/string/strIsUpperCase.ts +13 -0
  577. package/src/util/string/strSplitCamelCase.test.ts +54 -0
  578. package/src/util/string/strSplitCamelCase.ts +51 -0
  579. package/src/util/string-parsers/createBooleanParser.test.ts +58 -0
  580. package/src/util/string-parsers/createBooleanParser.ts +21 -0
  581. package/src/util/string-parsers/createTypedListParser.test.ts +19 -0
  582. package/src/util/string-parsers/createTypedListParser.ts +19 -0
  583. package/src/util/string-parsers/parseBoolean.test.ts +30 -0
  584. package/src/util/string-parsers/parseBoolean.ts +12 -0
  585. package/src/util/string-parsers/parseInteger.test.ts +52 -0
  586. package/src/util/string-parsers/parseInteger.ts +9 -0
  587. package/src/util/string-parsers/parseNumber.test.ts +53 -0
  588. package/src/util/string-parsers/parseNumber.ts +6 -0
  589. package/src/util/string-parsers/parseString.test.ts +7 -0
  590. package/src/util/string-parsers/parseString.ts +3 -0
  591. package/src/util/types/Any.ts +2 -0
  592. package/src/util/types/DeepArray.ts +12 -0
  593. package/src/util/types/DeepObject.ts +16 -0
  594. package/src/util/types/JsonArray.ts +8 -0
  595. package/src/util/types/JsonDefinedPrimitive.ts +5 -0
  596. package/src/util/types/JsonObject.ts +8 -0
  597. package/src/util/types/JsonRawPrimitive.ts +7 -0
  598. package/src/util/types/JsonValue.ts +14 -0
  599. package/src/util/types/ObjectKey.ts +1 -0
  600. package/src/util/types/TConstructor.ts +6 -0
  601. package/src/util/types/TFunction.ts +5 -0
  602. package/src/util/types/TFunctionNoNew.ts +3 -0
  603. package/src/util/types/TPlainObject.ts +4 -0
  604. package/src/util/types/TPrimitive.ts +1 -0
  605. package/src/util/types/TStringParser.ts +1 -0
  606. package/src/util/types/TValidator.ts +3 -0
  607. package/src/util/validation/createTypedArrayValidator.test.ts +34 -0
  608. package/src/util/validation/createTypedArrayValidator.ts +25 -0
  609. package/src/util/validation/ensureThat.test.ts +37 -0
  610. package/src/util/validation/ensureThat.ts +14 -0
  611. package/src/util/validation/isArray.test.ts +7 -0
  612. package/src/util/validation/isArray.ts +1 -0
  613. package/src/util/validation/isBoolean.test.ts +31 -0
  614. package/src/util/validation/isBoolean.ts +3 -0
  615. package/src/util/validation/isFunction.test.ts +54 -0
  616. package/src/util/validation/isFunction.ts +14 -0
  617. package/src/util/validation/isNamedFunction.test.ts +28 -0
  618. package/src/util/validation/isNamedFunction.ts +8 -0
  619. package/src/util/validation/isNamedFunctionArray.test.ts +14 -0
  620. package/src/util/validation/isNamedFunctionArray.ts +5 -0
  621. package/src/util/validation/isObject.test.ts +57 -0
  622. package/src/util/validation/isObject.ts +17 -0
  623. package/src/util/validation/isPlainObject.test.ts +21 -0
  624. package/src/util/validation/isPlainObject.ts +14 -0
  625. package/src/util/validation/isPrimitive.ts +15 -0
  626. package/src/util/validation/isString.test.ts +23 -0
  627. package/src/util/validation/isString.ts +3 -0
  628. package/src/util/validation/isStringArray.test.ts +24 -0
  629. package/src/util/validation/isStringArray.ts +8 -0
  630. package/src/util/validation/isStringWithNoSpacesOrDashes.test.ts +28 -0
  631. package/src/util/validation/isStringWithNoSpacesOrDashes.ts +5 -0
  632. package/src/util/validation/numbers/isInteger.test.ts +25 -0
  633. package/src/util/validation/numbers/isInteger.ts +13 -0
  634. package/src/util/validation/numbers/isValidNumber.test.ts +20 -0
  635. package/src/util/validation/numbers/isValidNumber.ts +17 -0
  636. package/tsconfig.json +32 -0
  637. package/tsconfig.lib.json +18 -0
  638. package/tsconfig.spec.json +10 -0
  639. package/index.cjs.d.ts +0 -1
  640. package/index.cjs.js +0 -3231
  641. package/index.esm.js +0 -3119
  642. package/src/cmd/CLI.d.ts +0 -2
  643. package/src/cmd/DefaultHelpConfig.d.ts +0 -2
  644. package/src/proto/overrideCommanderPrototype.d.ts +0 -8
  645. package/src/util/types/TFunction.d.ts +0 -4
  646. package/src/util/types/TValidator.d.ts +0 -1
  647. /package/{src → dist/types}/core/splitCombinedArgvShorts.d.ts +0 -0
  648. /package/{src → dist/types}/db/JsonFile.d.ts +0 -0
  649. /package/{src → dist/types}/util/array/arrLast.d.ts +0 -0
  650. /package/{src → dist/types}/util/array/arrSome.d.ts +0 -0
  651. /package/{src → dist/types}/util/array/types/ArrayPredicate.d.ts +0 -0
  652. /package/{src → dist/types}/util/errors/ErrorParser.d.ts +0 -0
  653. /package/{src → dist/types}/util/fs/promptUserEditInTextEditor/IGetUserInputFromEditorOptions.d.ts +0 -0
  654. /package/{src → dist/types}/util/fs/readFile/readFileSafeSync.d.ts +0 -0
  655. /package/{src → dist/types}/util/fs/readFile/readFileSync.d.ts +0 -0
  656. /package/{src → dist/types}/util/fs/removeFile/removeFile.d.ts +0 -0
  657. /package/{src → dist/types}/util/fs/types/IReadJsonFileOptions.d.ts +0 -0
  658. /package/{src → dist/types}/util/fs/writeFile/writeFileSafeSync.d.ts +0 -0
  659. /package/{src → dist/types}/util/fs/writeFile/writeFileSync.d.ts +0 -0
  660. /package/{src → dist/types}/util/fs/writeJsonFile/writeJsonFileSafe.d.ts +0 -0
  661. /package/{src → dist/types}/util/function/funSetName.d.ts +0 -0
  662. /package/{src → dist/types}/util/node/execInherit.d.ts +0 -0
  663. /package/{src → dist/types}/util/node/formatTableForTerminal.d.ts +0 -0
  664. /package/{src → dist/types}/util/object/arrAssign.d.ts +0 -0
  665. /package/{src → dist/types}/util/object/createArrayMerger.d.ts +0 -0
  666. /package/{src → dist/types}/util/object/objAssign.d.ts +0 -0
  667. /package/{src → dist/types}/util/object/realizeLazyProperty.d.ts +0 -0
  668. /package/{src → dist/types}/util/os/defaultOpenInEditorCommand.d.ts +0 -0
  669. /package/{src → dist/types}/util/os/isOSX.d.ts +0 -0
  670. /package/{src → dist/types}/util/os/isVsCodeInstalled.d.ts +0 -0
  671. /package/{src → dist/types}/util/os/isWindows.d.ts +0 -0
  672. /package/{src → dist/types}/util/path/getTempDataPath.d.ts +0 -0
  673. /package/{src → dist/types}/util/regex/regexEscapeString.d.ts +0 -0
  674. /package/{src → dist/types}/util/string/strEnsureStartsWith.d.ts +0 -0
  675. /package/{src → dist/types}/util/string/strFirstCharToUpperCase.d.ts +0 -0
  676. /package/{src → dist/types}/util/string/strIsLowerCase.d.ts +0 -0
  677. /package/{src → dist/types}/util/string/strIsUpperCase.d.ts +0 -0
  678. /package/{src → dist/types}/util/string/strSplitCamelCase.d.ts +0 -0
  679. /package/{src → dist/types}/util/string-parsers/createBooleanParser.d.ts +0 -0
  680. /package/{src → dist/types}/util/string-parsers/parseBoolean.d.ts +0 -0
  681. /package/{src → dist/types}/util/string-parsers/parseInteger.d.ts +0 -0
  682. /package/{src → dist/types}/util/string-parsers/parseNumber.d.ts +0 -0
  683. /package/{src → dist/types}/util/string-parsers/parseString.d.ts +0 -0
  684. /package/{src → dist/types}/util/types/Any.d.ts +0 -0
  685. /package/{src → dist/types}/util/types/JsonDefinedPrimitive.d.ts +0 -0
  686. /package/{src → dist/types}/util/types/ObjectKey.d.ts +0 -0
  687. /package/{src → dist/types}/util/types/TPrimitive.d.ts +0 -0
  688. /package/{src → dist/types}/util/types/TStringParser.d.ts +0 -0
  689. /package/{src → dist/types}/util/validation/createTypedArrayValidator.d.ts +0 -0
  690. /package/{src → dist/types}/util/validation/isArray.d.ts +0 -0
  691. /package/{src → dist/types}/util/validation/isBoolean.d.ts +0 -0
  692. /package/{src → dist/types}/util/validation/isNamedFunctionArray.d.ts +0 -0
  693. /package/{src → dist/types}/util/validation/isObject.d.ts +0 -0
  694. /package/{src → dist/types}/util/validation/isString.d.ts +0 -0
  695. /package/{src → dist/types}/util/validation/isStringArray.d.ts +0 -0
  696. /package/{src → dist/types}/util/validation/isStringWithNoSpacesOrDashes.d.ts +0 -0
  697. /package/{src → dist/types}/util/validation/numbers/isInteger.d.ts +0 -0
  698. /package/{src → dist/types}/util/validation/numbers/isValidNumber.d.ts +0 -0
@@ -0,0 +1,1073 @@
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 { CommandFeatureSelector } from './CommandFeatureSelector';
13
+ import { DefaultHelpConfig } from './DefaultHelpConfig';
14
+ import { ensureThat } from '../util/validation/ensureThat';
15
+ import { formatTableForTerminal } from '../util/node/formatTableForTerminal';
16
+ import { isArray } from '../util/validation/isArray';
17
+ import { isObject } from '../util/validation/isObject';
18
+ import { isString } from '../util/validation/isString';
19
+ import { isStringArray } from '../util/validation/isStringArray';
20
+ import { isStringWithNoSpacesOrDashes } from '../util/validation/isStringWithNoSpacesOrDashes';
21
+ import { JsonFile } from '../db/JsonFile';
22
+ import { objAssign } from '../util/object/objAssign';
23
+ import { OptionBuilder } from '../opt/OptionBuilder';
24
+ import { OptionHelpers } from '../opt/OptionHelpers';
25
+ import { OutputManager } from '../core/OutputManager';
26
+ import { realizeLazyProperty } from '../util/object/realizeLazyProperty';
27
+ import { removeFile } from '../util/fs/removeFile/removeFile';
28
+ import { setNonEnumerable } from '../util/object/setNonEnumerable';
29
+ import { splitCombinedArgvShorts } from '../core/splitCombinedArgvShorts';
30
+ import { Command, CommanderError, InvalidArgumentError, } from '@commander-js/extra-typings';
31
+ /**
32
+ * Wrapper around the @see Command class, for more intuitive construction.
33
+ */
34
+ export class CommandBuilder {
35
+ static dataDirectory = path.join(os.homedir(), 'config', 'cli');
36
+ features = new CommandFeatureSelector(this);
37
+ parent = null;
38
+ $;
39
+ meta = new CommandBuilderMetaData();
40
+ get db() {
41
+ return realizeLazyProperty(this, 'db', new JsonFile(this));
42
+ }
43
+ constructor(name, callback, parent, isNative = false) {
44
+ this.meta.isNative = isNative;
45
+ this.$ = new Command(name);
46
+ commanderBackRefs.set(this.$, this);
47
+ if (parent) {
48
+ this.parent = parent;
49
+ this.parent.meta.subcommands.push(this);
50
+ this.parent.$.addCommand(this.$);
51
+ }
52
+ this.initializeHelp();
53
+ if (callback)
54
+ callback.call(this, this);
55
+ if (this.parent) {
56
+ this.$.copyInheritedSettings(this.parent.$);
57
+ this.features.inheritFrom(this.parent.features);
58
+ this.inheritParentHiddenGlobals();
59
+ }
60
+ if (!this.meta.isNative) {
61
+ this.assertCommandNameNotReserved(this.name);
62
+ this.addUtilCommands();
63
+ }
64
+ if (this.isRoot) {
65
+ for (const child of this.getChildrenIterator({ includeSelf: true })) {
66
+ if (child.features.isAutoAssignSubCommandAliasesEnabled) {
67
+ child.assignSubCommandAliases();
68
+ if (!child.meta.isNative) {
69
+ child.assertNoDuplicateCommandNames();
70
+ }
71
+ }
72
+ if (child.features.isAutoAssignMissingOptionFlagsEnabled) {
73
+ child.assignMissingOptionFlags();
74
+ if (!child.meta.isNative) {
75
+ child.assertNoDuplicateOptionNames();
76
+ }
77
+ }
78
+ }
79
+ }
80
+ }
81
+ setRecommended() {
82
+ this.enableBuiltinOptions({ debug: true, disableStderr: true, disableStdout: true });
83
+ this.autoAssignMissingOptionFlags();
84
+ this.autoAssignSubCommandAliases();
85
+ this.presetsEnabled();
86
+ }
87
+ deleteDataFile() {
88
+ const filepath = this.dataFilepath;
89
+ if (fs.existsSync(filepath))
90
+ removeFile(filepath);
91
+ }
92
+ version(string) {
93
+ this.$.version(string);
94
+ const opt = this.options.find((o) => o.attributeName() === 'version');
95
+ if (opt)
96
+ this.meta.globalOptions.push(opt);
97
+ return this;
98
+ }
99
+ description(...lines) {
100
+ const description = lines.join('\n');
101
+ const summary = description.split(/(\. ?|\n|$)/)[0];
102
+ this.$.summary(summary + '.');
103
+ this.$.description(description);
104
+ return this;
105
+ }
106
+ alias(alias) {
107
+ this.assertCommandNameNotReserved(alias);
108
+ this.$.alias(alias);
109
+ return this;
110
+ }
111
+ aliases(...aliases) {
112
+ aliases.forEach((alias) => this.assertCommandNameNotReserved(alias));
113
+ this.$.aliases(aliases);
114
+ return this;
115
+ }
116
+ enableBuiltinOptions(options) {
117
+ if (!options || options.debug)
118
+ this.globalOption('-D, --debug', 'Output debugging information.');
119
+ if (!options || options.disableColor)
120
+ this.globalOption('-C, --disable-color', 'Disable color in terminal output.');
121
+ if (!options || options.disableStderr)
122
+ this.globalOption('-E, --disable-stderr', 'Mute all output to stderr.');
123
+ if (!options || options.disableStdout)
124
+ this.globalOption('-O, --disable-stdout', 'Mute all output to stdout.');
125
+ return this;
126
+ }
127
+ argument(name, cb) {
128
+ const ins = new ArgumentBuilder(this, name);
129
+ this.$.addArgument(ins.$);
130
+ if (typeof cb === 'function') {
131
+ cb(ins, this);
132
+ }
133
+ else if (typeof cb === 'string') {
134
+ ins.description(cb);
135
+ }
136
+ return this;
137
+ }
138
+ option(flags, cb) {
139
+ const ins = new OptionBuilder(this, flags);
140
+ if (this.hasIdenticalParentOption(ins.$))
141
+ return this;
142
+ this.$.addOption(ins.$);
143
+ if (typeof cb === 'function') {
144
+ cb(ins, this);
145
+ }
146
+ else if (typeof cb === 'string') {
147
+ ins.description(cb);
148
+ }
149
+ return this;
150
+ }
151
+ globalOption(flags, cb) {
152
+ return this.option(flags, (ins) => {
153
+ const opt = ins.$;
154
+ this.meta.globalOptions.push(opt);
155
+ if (typeof cb === 'function') {
156
+ cb(ins, this);
157
+ }
158
+ else if (typeof cb === 'string') {
159
+ ins.description(cb);
160
+ }
161
+ if (opt.hidden)
162
+ this.meta.hiddenGlobalOptions.add(opt);
163
+ });
164
+ }
165
+ command(name, cb) {
166
+ new CommandBuilder(name, cb, this);
167
+ return this;
168
+ }
169
+ nativeCommand(name, cb) {
170
+ new CommandBuilder(name, cb, this, true);
171
+ return this;
172
+ }
173
+ action(fn) {
174
+ const isAsync = isAsyncFunction(fn) || /^\(.+\) ?=> ?tslib_1\.__awaiter\(/.test(fn.toString().trim());
175
+ this.meta.isActionAsync = isAsync;
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
+ });
837
+ }
838
+ /**
839
+ * Makes aliases for the command.
840
+ * The idea is to be able to navigate the command tree by only typing the first letter(s) of the command names.
841
+ *
842
+ * Example: A command 'cola' would get these aliases: ['c', 'co', 'col'].
843
+ * However, if there are namespace clashes with sibling subcommands that start with the same letter,
844
+ * eg. like 'cola' and 'coal' where the first two letters clash, cola's aliases are reduced to only ['col'] and similarly for 'coal'.
845
+ *
846
+ * This method creates the aliases, ensuring there are no clashes with sublings, why it is important that the
847
+ * entire command tree is built before invoking this method.
848
+ */
849
+ assignSubCommandAliases() {
850
+ if (this.getAlias() || this.name.length <= 1)
851
+ return this;
852
+ const sibAliases = this.getSiblings()
853
+ .map((sib) => sib.getAliases())
854
+ .flat();
855
+ for (let i = 0; i < this.name.length - 1; i++) {
856
+ let cmdAlias = this.name.substring(0, i + 1);
857
+ let isClash = arrSome(sibAliases, (sibAlias) => {
858
+ return cmdAlias === sibAlias;
859
+ });
860
+ if (isClash && i === 0) {
861
+ cmdAlias = cmdAlias.charAt(0).toUpperCase();
862
+ isClash = arrSome(sibAliases, (sibAlias) => {
863
+ return cmdAlias === sibAlias;
864
+ });
865
+ }
866
+ if (isClash)
867
+ continue;
868
+ this.alias(cmdAlias);
869
+ return this;
870
+ }
871
+ return this;
872
+ }
873
+ /**
874
+ * Automatically set 'short' and 'long' names to options that don't have one assigned yet.
875
+ *
876
+ * First, it tries to assign a short name based on the first letter of the option's attribute name
877
+ * Both lower and upper case are tried. If these is not available, the next letter of the option name is tried.
878
+ *
879
+ * If none of the letters of the option name are available, the option is skipped until all other
880
+ * options have had letters from their names attempted assigned.
881
+ * Those that remain are assigned the first available letter of the alphabet + 0-9.
882
+ * If there are 64 options for the command and no more alphanumeric characters are available,
883
+ * the option is not assigned a short name.
884
+ */
885
+ assignMissingOptionFlags() {
886
+ const taken = new Set();
887
+ for (const anc of this.getAncestorsIterator({ includeSelf: true })) {
888
+ anc.options.forEach((opt) => {
889
+ if (!opt.short)
890
+ return;
891
+ taken.add(opt.short.replace(/^-/g, ''));
892
+ });
893
+ }
894
+ const failed = new Set();
895
+ // assign letter from option name
896
+ this.options.forEach((opt) => {
897
+ if (opt.short)
898
+ return;
899
+ const name = opt.attributeName();
900
+ for (let c = 0; c < name.length; c++) {
901
+ let char = name.charAt(c).toLowerCase();
902
+ if (taken.has(char)) {
903
+ char = char.toUpperCase();
904
+ if (taken.has(char))
905
+ continue;
906
+ }
907
+ OptionHelpers.setShort(opt, char);
908
+ taken.add(char);
909
+ return;
910
+ }
911
+ failed.add(opt);
912
+ });
913
+ // assign random alphanumeric character.
914
+ const name = 'abcdefghijklmnopqrstuvwxyz1234567890';
915
+ failed.forEach((opt) => {
916
+ for (let c = 0; c < name.length; c++) {
917
+ let char = name.charAt(c);
918
+ if (taken.has(char)) {
919
+ char = char.toUpperCase();
920
+ if (taken.has(char))
921
+ continue;
922
+ }
923
+ OptionHelpers.setShort(opt, char);
924
+ taken.add(char);
925
+ return;
926
+ }
927
+ });
928
+ }
929
+ assertNoDuplicateCommandNames() {
930
+ const names = this.$.commands.map((sub) => sub.aliases().concat(sub.name())).flat();
931
+ if (names.length !== new Set(names).size) {
932
+ this.throwCommanderError(`Duplicate subcommand names/aliases found for command, ${this.name}: ${names.join(', ')}`);
933
+ }
934
+ }
935
+ hasIdenticalParentOption(option) {
936
+ const flags = option.flags;
937
+ for (const anc of this.getAncestorsIterator({ includeSelf: true })) {
938
+ for (const opt of anc.$.options) {
939
+ if (flags === opt.flags) {
940
+ return true;
941
+ }
942
+ }
943
+ }
944
+ return false;
945
+ }
946
+ assertNoDuplicateOptionNames() {
947
+ const throwErr = (cmd, opt, anc) => {
948
+ this.throwCommanderError(`Duplicate option names > cmd: ${cmd.name}, ${anc ? `anc: ${anc.name}, ` : ''}opt: ${opt}`);
949
+ };
950
+ const set = new Set();
951
+ for (const opt of this.options) {
952
+ if (opt.name() === 'help')
953
+ continue;
954
+ if (opt.short) {
955
+ if (set.has(opt.short))
956
+ throwErr(this, opt.short);
957
+ set.add(opt.short);
958
+ }
959
+ if (opt.long) {
960
+ if (set.has(opt.long))
961
+ throwErr(this, opt.long);
962
+ set.add(opt.long);
963
+ }
964
+ if (opt.attributeName()) {
965
+ if (set.has(opt.attributeName()))
966
+ throwErr(this, opt.attributeName());
967
+ set.add(opt.attributeName());
968
+ }
969
+ }
970
+ for (const anc of this.getAncestorsIterator()) {
971
+ for (const opt of anc.$.options) {
972
+ if (opt.short && set.has(opt.short)) {
973
+ if (opt.short !== 'V')
974
+ continue;
975
+ throwErr(this, opt.short, anc);
976
+ }
977
+ if (opt.long && set.has(opt.long)) {
978
+ throwErr(this, opt.long, anc);
979
+ }
980
+ if (opt.attributeName() && set.has(opt.attributeName())) {
981
+ throwErr(this, opt.attributeName(), anc);
982
+ }
983
+ }
984
+ }
985
+ }
986
+ initializeActionWrapper(isAsync = false) {
987
+ if (isAsync) {
988
+ this.$.action(async () => {
989
+ try {
990
+ this.handleOutputOptions();
991
+ const [args, opts] = this.getParsedValidArgsOptsWithPresets();
992
+ if (opts['help'])
993
+ return this.outputHelp();
994
+ const owg = this.$.optsWithGlobals();
995
+ await this.meta.actionHandler.call(this, ...args, opts, this);
996
+ }
997
+ catch (error) {
998
+ this.meta.errorHandler.call(this, error, this);
999
+ }
1000
+ });
1001
+ }
1002
+ else {
1003
+ this.$.action(() => {
1004
+ try {
1005
+ this.handleOutputOptions();
1006
+ const [args, opts] = this.getParsedValidArgsOptsWithPresets();
1007
+ if (opts['help'])
1008
+ return this.outputHelp();
1009
+ const owg = this.$.optsWithGlobals();
1010
+ this.meta.actionHandler.call(this, ...args, opts, this);
1011
+ }
1012
+ catch (error) {
1013
+ this.meta.errorHandler.call(this, error, this);
1014
+ }
1015
+ });
1016
+ }
1017
+ }
1018
+ initializeHelp() {
1019
+ if (this.isRoot)
1020
+ this.globalOption('-h, --help', 'show help');
1021
+ this.$.addHelpCommand('?', 'show help');
1022
+ this.$.configureHelp(DefaultHelpConfig);
1023
+ }
1024
+ inheritParentHiddenGlobals() {
1025
+ if (!this.parent)
1026
+ return;
1027
+ for (const opt of this.parent.meta.hiddenGlobalOptions) {
1028
+ this.meta.hiddenGlobalOptions.add(opt);
1029
+ }
1030
+ }
1031
+ assertCommandNameNotReserved(name) {
1032
+ if (this.isRoot)
1033
+ return;
1034
+ if (this.meta.isNative)
1035
+ return;
1036
+ if (name === 'u' || name === 'util') {
1037
+ this.throwCommanderError(`Name '${name}' is reserved and is not available as name or alias.`);
1038
+ }
1039
+ }
1040
+ }
1041
+ process.argv = splitCombinedArgvShorts(process.argv.slice());
1042
+ export const commanderBackRefs = new WeakMap();
1043
+ const oldParse = Command.prototype.parse;
1044
+ Command.prototype.parse = function parse(argv, options) {
1045
+ if (argv) {
1046
+ argv = splitCombinedArgvShorts(argv.slice());
1047
+ this.builder.meta.rawArgs = argv.slice(options?.from === 'user' ? 0 : 2);
1048
+ }
1049
+ else {
1050
+ this.builder.meta.rawArgs = process.argv.slice(2);
1051
+ }
1052
+ return oldParse.call(this, argv, options);
1053
+ };
1054
+ const oldParseAsync = Command.prototype.parseAsync;
1055
+ Command.prototype.parseAsync = async function (argv, options) {
1056
+ if (argv) {
1057
+ argv = splitCombinedArgvShorts(argv.slice());
1058
+ this.builder.meta.rawArgs = argv.slice(options?.from === 'user' ? 0 : 2);
1059
+ }
1060
+ else {
1061
+ this.builder.meta.rawArgs = process.argv.slice(2);
1062
+ }
1063
+ return await oldParseAsync.call(this, argv, options);
1064
+ };
1065
+ Object.defineProperty(Command.prototype, 'builder', {
1066
+ get() {
1067
+ const ins = commanderBackRefs.get(this);
1068
+ if (!ins)
1069
+ throw new Error(`CommandBuilder not found for command ${this.name()}`);
1070
+ return ins;
1071
+ },
1072
+ });
1073
+ //# sourceMappingURL=CommandBuilder.js.map