parse-my-command 0.1.3 → 0.1.4

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.
package/README.md CHANGED
@@ -52,3 +52,15 @@ console.log(missingOptions.get(childCommand)); // Set(1) { 'optionC' }
52
52
  ```
53
53
 
54
54
  More examples can be found in the [examples](/examples/) directory.
55
+
56
+ ## How It Works and Limitations
57
+
58
+ This module works by creating a (best-effort) clone of the command and its
59
+ subcommands, setting the actions to no-op functions, and then parsing the
60
+ `argv` with the cloned instance. This approach might have some limitations:
61
+
62
+ 1. The implementation might break if Commander.js changes its internals
63
+ 2. Custom argument and option processors are assumed to be pure functions
64
+ 3. Hooks attached to the commands will not be called
65
+ 4. Some edge cases might not be handled correctly (Please feel free to open an
66
+ issue/PR if you find one)
package/dist/index.cjs CHANGED
@@ -53,14 +53,46 @@ var findMissingOptions = (command, providedOptionsByCommand) => {
53
53
  }
54
54
  return missingOptionsByCommand;
55
55
  };
56
+ var copyCommandSettings = (source, target) => {
57
+ for (const keysToCopy of [
58
+ "_args",
59
+ "_combineFlagAndOptionalValue",
60
+ "_allowUnknownOption",
61
+ "_allowExcessArguments",
62
+ "_enablePositionalOptions",
63
+ "_passThroughOptions"
64
+ ]) {
65
+ target[keysToCopy] = source[keysToCopy];
66
+ }
67
+ target.name(source.name());
68
+ target.aliases(source.aliases());
69
+ };
70
+ var cloneOption = (option) => {
71
+ const newOption = new import_commander.Option(option.flags, option.description);
72
+ newOption.default(option.defaultValue, option.defaultValueDescription);
73
+ if (option.argChoices) {
74
+ newOption.choices(option.argChoices);
75
+ }
76
+ newOption.makeOptionMandatory(false);
77
+ newOption.preset(option.parseArg);
78
+ newOption.conflicts(
79
+ option.conflictsWith
80
+ );
81
+ newOption.env(option.envVar);
82
+ if (option.parseArg) {
83
+ newOption.argParser(option.parseArg);
84
+ }
85
+ return newOption;
86
+ };
56
87
  var partialParse = (command, argv, options) => {
57
88
  const providedOptions = /* @__PURE__ */ new Map();
58
89
  const commandsMap = /* @__PURE__ */ new Map();
59
90
  let matchedCommand;
60
91
  const createParserCommand = (parserCommand2, command2) => {
61
92
  commandsMap.set(parserCommand2, command2);
93
+ copyCommandSettings(command2, parserCommand2);
62
94
  for (const option of command2.options) {
63
- parserCommand2.option(option.flags, option.description);
95
+ parserCommand2.addOption(cloneOption(option));
64
96
  }
65
97
  parserCommand2.hook("preSubcommand", (thisCommand, actionCommand) => {
66
98
  providedOptions.set(commandsMap.get(parserCommand2), thisCommand.opts());
@@ -92,4 +124,4 @@ var partialParse = (command, argv, options) => {
92
124
  findMissingOptions,
93
125
  partialParse
94
126
  });
95
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgY2FtZWxDYXNlIGZyb20gXCJjYW1lbGNhc2VcIjtcbmltcG9ydCB7IHR5cGUgT3B0aW9uVmFsdWVzLCBDb21tYW5kLCB0eXBlIFBhcnNlT3B0aW9ucyB9IGZyb20gXCJjb21tYW5kZXJcIjtcblxuZXhwb3J0IGNvbnN0IGZpbmRNaXNzaW5nT3B0aW9ucyA9IChcbiAgY29tbWFuZDogQ29tbWFuZCxcbiAgcHJvdmlkZWRPcHRpb25zQnlDb21tYW5kOiBNYXA8Q29tbWFuZCwgT3B0aW9uVmFsdWVzPixcbikgPT4ge1xuICBjb25zdCBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZCA9IG5ldyBNYXA8Q29tbWFuZCwgU2V0PHN0cmluZz4+KCk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgbGV0IGN1cnJlbnRDb21tYW5kOiBDb21tYW5kIHwgdW5kZWZpbmVkIHwgbnVsbCA9IGNvbW1hbmQ7XG5cbiAgd2hpbGUgKGN1cnJlbnRDb21tYW5kKSB7XG4gICAgY29uc3QgbWlzc2luZ09wdGlvbnMgPSBuZXcgU2V0PHN0cmluZz4oKTtcbiAgICBjb25zdCBwcm92aWRlZE9wdGlvbnMgPSBwcm92aWRlZE9wdGlvbnNCeUNvbW1hbmQuZ2V0KGN1cnJlbnRDb21tYW5kKTtcbiAgICBmb3IgKGNvbnN0IG9wdGlvbiBvZiBjdXJyZW50Q29tbWFuZC5vcHRpb25zKSB7XG4gICAgICBjb25zdCBrZXkgPSBjYW1lbENhc2UoKG9wdGlvbi5sb25nID8/IG9wdGlvbi5zaG9ydCkhKTtcbiAgICAgIGlmIChwcm92aWRlZE9wdGlvbnM/LltrZXldKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBtaXNzaW5nT3B0aW9ucy5hZGQoa2V5KTtcbiAgICB9XG5cbiAgICBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZC5zZXQoY3VycmVudENvbW1hbmQsIG1pc3NpbmdPcHRpb25zKTtcbiAgICBjdXJyZW50Q29tbWFuZCA9IGN1cnJlbnRDb21tYW5kLnBhcmVudDtcbiAgfVxuXG4gIHJldHVybiBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZDtcbn07XG5cbmV4cG9ydCB0eXBlIFBhcnRpYWxQYXJzZVJlc3VsdCA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb21tYW5kIHdob3NlIGFjdGlvbiB3aWxsIGJlIGV4ZWN1dGVkXG4gICAqL1xuICBtYXRjaGVkQ29tbWFuZDogQ29tbWFuZCB8IHVuZGVmaW5lZDtcbiAgLyoqXG4gICAqIEEgbWFwIG9mIGNvbW1hbmRzIHRvIGEgc2V0IG9mIG1pc3Npbmcgb3B0aW9ucyBmb3IgdGhhdCBjb21tYW5kXG4gICAqL1xuICBtaXNzaW5nT3B0aW9uczogTWFwPENvbW1hbmQsIFNldDxzdHJpbmc+PjtcbiAgLyoqXG4gICAqIEEgbWFwIG9mIGNvbW1hbmRzIHRvIHRoZSBvcHRpb25zIHByb3ZpZGVkIGZvciB0aGF0IGNvbW1hbmRcbiAgICovXG4gIHByb3ZpZGVkT3B0aW9uczogTWFwPENvbW1hbmQsIE9wdGlvblZhbHVlcz47XG59O1xuXG4vKipcbiAqIFBhcnRpYWxseSBwYXJzZSBhcmd2IGZvciBhIGNvbW1hbmQgd2l0aG91dCBleGVjdXRpbmcgdGhlIGFjdGlvbi4gQHNlZSB7QGxpbmsgQ29tbWFuZC5wYXJzZX1cbiAqXG4gKiBAcmV0dXJucyBBbiBvYmplY3QgY29udGFpbmluZyB0aGUgbWF0Y2hlZCBjb21tYW5kLCB0aGUgcHJvdmlkZWQgb3B0aW9ucywgYW5kIHRoZSBtaXNzaW5nIG9wdGlvbnMuXG4gKi9cbmV4cG9ydCBjb25zdCBwYXJ0aWFsUGFyc2UgPSAoXG4gIGNvbW1hbmQ6IENvbW1hbmQsXG4gIGFyZ3Y6IHJlYWRvbmx5IHN0cmluZ1tdLFxuICBvcHRpb25zPzogUGFyc2VPcHRpb25zLFxuKTogUGFydGlhbFBhcnNlUmVzdWx0ID0+IHtcbiAgY29uc3QgcHJvdmlkZWRPcHRpb25zID0gbmV3IE1hcDxDb21tYW5kLCBPcHRpb25WYWx1ZXM+KCk7XG4gIGNvbnN0IGNvbW1hbmRzTWFwID0gbmV3IE1hcDxDb21tYW5kLCBDb21tYW5kPigpO1xuICBsZXQgbWF0Y2hlZENvbW1hbmQ6IENvbW1hbmQgfCB1bmRlZmluZWQ7XG5cbiAgY29uc3QgY3JlYXRlUGFyc2VyQ29tbWFuZCA9IChwYXJzZXJDb21tYW5kOiBDb21tYW5kLCBjb21tYW5kOiBDb21tYW5kKSA9PiB7XG4gICAgY29tbWFuZHNNYXAuc2V0KHBhcnNlckNvbW1hbmQsIGNvbW1hbmQpO1xuXG4gICAgZm9yIChjb25zdCBvcHRpb24gb2YgY29tbWFuZC5vcHRpb25zKSB7XG4gICAgICBwYXJzZXJDb21tYW5kLm9wdGlvbihvcHRpb24uZmxhZ3MsIG9wdGlvbi5kZXNjcmlwdGlvbik7XG4gICAgfVxuXG4gICAgcGFyc2VyQ29tbWFuZC5ob29rKFwicHJlU3ViY29tbWFuZFwiLCAodGhpc0NvbW1hbmQsIGFjdGlvbkNvbW1hbmQpID0+IHtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoY29tbWFuZHNNYXAuZ2V0KHBhcnNlckNvbW1hbmQpISwgdGhpc0NvbW1hbmQub3B0cygpKTtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoY29tbWFuZHNNYXAuZ2V0KGFjdGlvbkNvbW1hbmQpISwgdGhpc0NvbW1hbmQub3B0cygpKTtcbiAgICB9KTtcblxuICAgIHBhcnNlckNvbW1hbmQuYWN0aW9uKCgpID0+IHtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoXG4gICAgICAgIGNvbW1hbmRzTWFwLmdldChwYXJzZXJDb21tYW5kKSEsXG4gICAgICAgIHBhcnNlckNvbW1hbmQub3B0cygpLFxuICAgICAgKTtcbiAgICAgIG1hdGNoZWRDb21tYW5kID0gY29tbWFuZDtcbiAgICB9KTtcblxuICAgIGZvciAoY29uc3Qgc3ViY29tbWFuZCBvZiBjb21tYW5kLmNvbW1hbmRzIGFzIENvbW1hbmRbXSkge1xuICAgICAgY29uc3QgcGFyc2VyU3ViY29tbWFuZCA9IHBhcnNlckNvbW1hbmRcbiAgICAgICAgLmNvbW1hbmQoc3ViY29tbWFuZC5uYW1lKCkpXG4gICAgICAgIC5leGl0T3ZlcnJpZGUoKTtcbiAgICAgIGNyZWF0ZVBhcnNlckNvbW1hbmQocGFyc2VyU3ViY29tbWFuZCwgc3ViY29tbWFuZCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHBhcnNlckNvbW1hbmQ7XG4gIH07XG5cbiAgY29uc3QgcGFyc2VyQ29tbWFuZCA9IGNyZWF0ZVBhcnNlckNvbW1hbmQoXG4gICAgbmV3IENvbW1hbmQoKS5leGl0T3ZlcnJpZGUoKSxcbiAgICBjb21tYW5kLFxuICApO1xuICBwYXJzZXJDb21tYW5kLnBhcnNlKGFyZ3YsIG9wdGlvbnMpO1xuXG4gIGNvbnN0IG1pc3NpbmdPcHRpb25zID0gbWF0Y2hlZENvbW1hbmRcbiAgICA/IGZpbmRNaXNzaW5nT3B0aW9ucyhtYXRjaGVkQ29tbWFuZCwgcHJvdmlkZWRPcHRpb25zKVxuICAgIDogbmV3IE1hcDxDb21tYW5kLCBTZXQ8c3RyaW5nPj4oKTtcblxuICByZXR1cm4geyBtYXRjaGVkQ29tbWFuZCwgbWlzc2luZ09wdGlvbnMsIHByb3ZpZGVkT3B0aW9ucyB9O1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsdUJBQXNCO0FBQ3RCLHVCQUE4RDtBQUV2RCxJQUFNLHFCQUFxQixDQUNoQyxTQUNBLDZCQUNHO0FBQ0gsUUFBTSwwQkFBMEIsb0JBQUksSUFBMEI7QUFHOUQsTUFBSSxpQkFBNkM7QUFFakQsU0FBTyxnQkFBZ0I7QUFDckIsVUFBTSxpQkFBaUIsb0JBQUksSUFBWTtBQUN2QyxVQUFNLGtCQUFrQix5QkFBeUIsSUFBSSxjQUFjO0FBQ25FLGVBQVcsVUFBVSxlQUFlLFNBQVM7QUFDM0MsWUFBTSxVQUFNLGlCQUFBQSxTQUFXLE9BQU8sUUFBUSxPQUFPLEtBQU87QUFDcEQsVUFBSSxrQkFBa0IsR0FBRyxHQUFHO0FBQzFCO0FBQUEsTUFDRjtBQUVBLHFCQUFlLElBQUksR0FBRztBQUFBLElBQ3hCO0FBRUEsNEJBQXdCLElBQUksZ0JBQWdCLGNBQWM7QUFDMUQscUJBQWlCLGVBQWU7QUFBQSxFQUNsQztBQUVBLFNBQU87QUFDVDtBQXNCTyxJQUFNLGVBQWUsQ0FDMUIsU0FDQSxNQUNBLFlBQ3VCO0FBQ3ZCLFFBQU0sa0JBQWtCLG9CQUFJLElBQTJCO0FBQ3ZELFFBQU0sY0FBYyxvQkFBSSxJQUFzQjtBQUM5QyxNQUFJO0FBRUosUUFBTSxzQkFBc0IsQ0FBQ0MsZ0JBQXdCQyxhQUFxQjtBQUN4RSxnQkFBWSxJQUFJRCxnQkFBZUMsUUFBTztBQUV0QyxlQUFXLFVBQVVBLFNBQVEsU0FBUztBQUNwQyxNQUFBRCxlQUFjLE9BQU8sT0FBTyxPQUFPLE9BQU8sV0FBVztBQUFBLElBQ3ZEO0FBRUEsSUFBQUEsZUFBYyxLQUFLLGlCQUFpQixDQUFDLGFBQWEsa0JBQWtCO0FBQ2xFLHNCQUFnQixJQUFJLFlBQVksSUFBSUEsY0FBYSxHQUFJLFlBQVksS0FBSyxDQUFDO0FBQ3ZFLHNCQUFnQixJQUFJLFlBQVksSUFBSSxhQUFhLEdBQUksWUFBWSxLQUFLLENBQUM7QUFBQSxJQUN6RSxDQUFDO0FBRUQsSUFBQUEsZUFBYyxPQUFPLE1BQU07QUFDekIsc0JBQWdCO0FBQUEsUUFDZCxZQUFZLElBQUlBLGNBQWE7QUFBQSxRQUM3QkEsZUFBYyxLQUFLO0FBQUEsTUFDckI7QUFDQSx1QkFBaUJDO0FBQUEsSUFDbkIsQ0FBQztBQUVELGVBQVcsY0FBY0EsU0FBUSxVQUF1QjtBQUN0RCxZQUFNLG1CQUFtQkQsZUFDdEIsUUFBUSxXQUFXLEtBQUssQ0FBQyxFQUN6QixhQUFhO0FBQ2hCLDBCQUFvQixrQkFBa0IsVUFBVTtBQUFBLElBQ2xEO0FBRUEsV0FBT0E7QUFBQSxFQUNUO0FBRUEsUUFBTSxnQkFBZ0I7QUFBQSxJQUNwQixJQUFJLHlCQUFRLEVBQUUsYUFBYTtBQUFBLElBQzNCO0FBQUEsRUFDRjtBQUNBLGdCQUFjLE1BQU0sTUFBTSxPQUFPO0FBRWpDLFFBQU0saUJBQWlCLGlCQUNuQixtQkFBbUIsZ0JBQWdCLGVBQWUsSUFDbEQsb0JBQUksSUFBMEI7QUFFbEMsU0FBTyxFQUFFLGdCQUFnQixnQkFBZ0IsZ0JBQWdCO0FBQzNEOyIsCiAgIm5hbWVzIjogWyJjYW1lbENhc2UiLCAicGFyc2VyQ29tbWFuZCIsICJjb21tYW5kIl0KfQo=
127
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": ["import camelCase from \"camelcase\";\nimport {\n  type OptionValues,\n  Command,\n  type ParseOptions,\n  Option,\n} from \"commander\";\n\nexport const findMissingOptions = (\n  command: Command,\n  providedOptionsByCommand: Map<Command, OptionValues>,\n) => {\n  const missingOptionsByCommand = new Map<Command, Set<string>>();\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  let currentCommand: Command | undefined | null = command;\n\n  while (currentCommand) {\n    const missingOptions = new Set<string>();\n    const providedOptions = providedOptionsByCommand.get(currentCommand);\n    for (const option of currentCommand.options) {\n      const key = camelCase((option.long ?? option.short)!);\n      if (providedOptions?.[key]) {\n        continue;\n      }\n\n      missingOptions.add(key);\n    }\n\n    missingOptionsByCommand.set(currentCommand, missingOptions);\n    currentCommand = currentCommand.parent;\n  }\n\n  return missingOptionsByCommand;\n};\n\nexport type PartialParseResult = {\n  /**\n   * The command whose action will be executed\n   */\n  matchedCommand: Command | undefined;\n  /**\n   * A map of commands to a set of missing options for that command\n   */\n  missingOptions: Map<Command, Set<string>>;\n  /**\n   * A map of commands to the options provided for that command\n   */\n  providedOptions: Map<Command, OptionValues>;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  for (const keysToCopy of [\n    \"_args\",\n    \"_combineFlagAndOptionalValue\",\n    \"_allowUnknownOption\",\n    \"_allowExcessArguments\",\n    \"_enablePositionalOptions\",\n    \"_passThroughOptions\",\n  ] as const) {\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n    (target as any)[keysToCopy] = (source as any)[keysToCopy];\n  }\n\n  target.name(source.name());\n  target.aliases(source.aliases());\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.makeOptionMandatory(false);\n  newOption.preset(option.parseArg);\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  return newOption;\n};\n\n/**\n * Partially parse argv for a command without executing the action. @see {@link Command.parse}\n *\n * @returns An object containing the matched command, the provided options, and the missing options.\n */\nexport const partialParse = (\n  command: Command,\n  argv: readonly string[],\n  options?: ParseOptions,\n): PartialParseResult => {\n  const providedOptions = new Map<Command, OptionValues>();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n\n    for (const option of command.options) {\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      providedOptions.set(commandsMap.get(parserCommand)!, thisCommand.opts());\n      providedOptions.set(commandsMap.get(actionCommand)!, thisCommand.opts());\n    });\n\n    parserCommand.action(() => {\n      providedOptions.set(\n        commandsMap.get(parserCommand)!,\n        parserCommand.opts(),\n      );\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand\n        .command(subcommand.name())\n        .exitOverride();\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(\n    new Command().exitOverride(),\n    command,\n  );\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return { matchedCommand, missingOptions, providedOptions };\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uBAAsB;AACtB,uBAKO;AAEA,IAAM,qBAAqB,CAChC,SACA,6BACG;AACH,QAAM,0BAA0B,oBAAI,IAA0B;AAG9D,MAAI,iBAA6C;AAEjD,SAAO,gBAAgB;AACrB,UAAM,iBAAiB,oBAAI,IAAY;AACvC,UAAM,kBAAkB,yBAAyB,IAAI,cAAc;AACnE,eAAW,UAAU,eAAe,SAAS;AAC3C,YAAM,UAAM,iBAAAA,SAAW,OAAO,QAAQ,OAAO,KAAO;AACpD,UAAI,kBAAkB,GAAG,GAAG;AAC1B;AAAA,MACF;AAEA,qBAAe,IAAI,GAAG;AAAA,IACxB;AAEA,4BAAwB,IAAI,gBAAgB,cAAc;AAC1D,qBAAiB,eAAe;AAAA,EAClC;AAEA,SAAO;AACT;AAiBA,IAAM,sBAAsB,CAAC,QAAiB,WAAoB;AAChE,aAAW,cAAc;AAAA,IACvB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,GAAY;AAEV,IAAC,OAAe,UAAU,IAAK,OAAe,UAAU;AAAA,EAC1D;AAEA,SAAO,KAAK,OAAO,KAAK,CAAC;AACzB,SAAO,QAAQ,OAAO,QAAQ,CAAC;AACjC;AAEA,IAAM,cAAc,CAAC,WAAmB;AACtC,QAAM,YAAY,IAAI,wBAAO,OAAO,OAAO,OAAO,WAAW;AAC7D,YAAU,QAAQ,OAAO,cAAc,OAAO,uBAAuB;AACrE,MAAI,OAAO,YAAY;AACrB,cAAU,QAAQ,OAAO,UAAU;AAAA,EACrC;AAEA,YAAU,oBAAoB,KAAK;AACnC,YAAU,OAAO,OAAO,QAAQ;AAChC,YAAU;AAAA,IACP,OAAgD;AAAA,EACnD;AACA,YAAU,IAAK,OAAuC,MAAM;AAC5D,MAAI,OAAO,UAAU;AACnB,cAAU,UAAU,OAAO,QAAQ;AAAA,EACrC;AAEA,SAAO;AACT;AAOO,IAAM,eAAe,CAC1B,SACA,MACA,YACuB;AACvB,QAAM,kBAAkB,oBAAI,IAA2B;AACvD,QAAM,cAAc,oBAAI,IAAsB;AAC9C,MAAI;AAEJ,QAAM,sBAAsB,CAACC,gBAAwBC,aAAqB;AACxE,gBAAY,IAAID,gBAAeC,QAAO;AAEtC,wBAAoBA,UAASD,cAAa;AAE1C,eAAW,UAAUC,SAAQ,SAAS;AACpC,MAAAD,eAAc,UAAU,YAAY,MAAM,CAAC;AAAA,IAC7C;AAEA,IAAAA,eAAc,KAAK,iBAAiB,CAAC,aAAa,kBAAkB;AAClE,sBAAgB,IAAI,YAAY,IAAIA,cAAa,GAAI,YAAY,KAAK,CAAC;AACvE,sBAAgB,IAAI,YAAY,IAAI,aAAa,GAAI,YAAY,KAAK,CAAC;AAAA,IACzE,CAAC;AAED,IAAAA,eAAc,OAAO,MAAM;AACzB,sBAAgB;AAAA,QACd,YAAY,IAAIA,cAAa;AAAA,QAC7BA,eAAc,KAAK;AAAA,MACrB;AACA,uBAAiBC;AAAA,IACnB,CAAC;AAED,eAAW,cAAcA,SAAQ,UAAuB;AACtD,YAAM,mBAAmBD,eACtB,QAAQ,WAAW,KAAK,CAAC,EACzB,aAAa;AAChB,0BAAoB,kBAAkB,UAAU;AAAA,IAClD;AAEA,WAAOA;AAAA,EACT;AAEA,QAAM,gBAAgB;AAAA,IACpB,IAAI,yBAAQ,EAAE,aAAa;AAAA,IAC3B;AAAA,EACF;AACA,gBAAc,MAAM,MAAM,OAAO;AAEjC,QAAM,iBAAiB,iBACnB,mBAAmB,gBAAgB,eAAe,IAClD,oBAAI,IAA0B;AAElC,SAAO,EAAE,gBAAgB,gBAAgB,gBAAgB;AAC3D;",
  "names": ["camelCase", "parserCommand", "command"]
}

package/dist/index.js CHANGED
@@ -1,6 +1,9 @@
1
1
  // src/index.ts
2
2
  import camelCase from "camelcase";
3
- import { Command } from "commander";
3
+ import {
4
+ Command,
5
+ Option
6
+ } from "commander";
4
7
  var findMissingOptions = (command, providedOptionsByCommand) => {
5
8
  const missingOptionsByCommand = /* @__PURE__ */ new Map();
6
9
  let currentCommand = command;
@@ -19,14 +22,46 @@ var findMissingOptions = (command, providedOptionsByCommand) => {
19
22
  }
20
23
  return missingOptionsByCommand;
21
24
  };
25
+ var copyCommandSettings = (source, target) => {
26
+ for (const keysToCopy of [
27
+ "_args",
28
+ "_combineFlagAndOptionalValue",
29
+ "_allowUnknownOption",
30
+ "_allowExcessArguments",
31
+ "_enablePositionalOptions",
32
+ "_passThroughOptions"
33
+ ]) {
34
+ target[keysToCopy] = source[keysToCopy];
35
+ }
36
+ target.name(source.name());
37
+ target.aliases(source.aliases());
38
+ };
39
+ var cloneOption = (option) => {
40
+ const newOption = new Option(option.flags, option.description);
41
+ newOption.default(option.defaultValue, option.defaultValueDescription);
42
+ if (option.argChoices) {
43
+ newOption.choices(option.argChoices);
44
+ }
45
+ newOption.makeOptionMandatory(false);
46
+ newOption.preset(option.parseArg);
47
+ newOption.conflicts(
48
+ option.conflictsWith
49
+ );
50
+ newOption.env(option.envVar);
51
+ if (option.parseArg) {
52
+ newOption.argParser(option.parseArg);
53
+ }
54
+ return newOption;
55
+ };
22
56
  var partialParse = (command, argv, options) => {
23
57
  const providedOptions = /* @__PURE__ */ new Map();
24
58
  const commandsMap = /* @__PURE__ */ new Map();
25
59
  let matchedCommand;
26
60
  const createParserCommand = (parserCommand2, command2) => {
27
61
  commandsMap.set(parserCommand2, command2);
62
+ copyCommandSettings(command2, parserCommand2);
28
63
  for (const option of command2.options) {
29
- parserCommand2.option(option.flags, option.description);
64
+ parserCommand2.addOption(cloneOption(option));
30
65
  }
31
66
  parserCommand2.hook("preSubcommand", (thisCommand, actionCommand) => {
32
67
  providedOptions.set(commandsMap.get(parserCommand2), thisCommand.opts());
@@ -57,4 +92,4 @@ export {
57
92
  findMissingOptions,
58
93
  partialParse
59
94
  };
60
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgY2FtZWxDYXNlIGZyb20gXCJjYW1lbGNhc2VcIjtcbmltcG9ydCB7IHR5cGUgT3B0aW9uVmFsdWVzLCBDb21tYW5kLCB0eXBlIFBhcnNlT3B0aW9ucyB9IGZyb20gXCJjb21tYW5kZXJcIjtcblxuZXhwb3J0IGNvbnN0IGZpbmRNaXNzaW5nT3B0aW9ucyA9IChcbiAgY29tbWFuZDogQ29tbWFuZCxcbiAgcHJvdmlkZWRPcHRpb25zQnlDb21tYW5kOiBNYXA8Q29tbWFuZCwgT3B0aW9uVmFsdWVzPixcbikgPT4ge1xuICBjb25zdCBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZCA9IG5ldyBNYXA8Q29tbWFuZCwgU2V0PHN0cmluZz4+KCk7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgbGV0IGN1cnJlbnRDb21tYW5kOiBDb21tYW5kIHwgdW5kZWZpbmVkIHwgbnVsbCA9IGNvbW1hbmQ7XG5cbiAgd2hpbGUgKGN1cnJlbnRDb21tYW5kKSB7XG4gICAgY29uc3QgbWlzc2luZ09wdGlvbnMgPSBuZXcgU2V0PHN0cmluZz4oKTtcbiAgICBjb25zdCBwcm92aWRlZE9wdGlvbnMgPSBwcm92aWRlZE9wdGlvbnNCeUNvbW1hbmQuZ2V0KGN1cnJlbnRDb21tYW5kKTtcbiAgICBmb3IgKGNvbnN0IG9wdGlvbiBvZiBjdXJyZW50Q29tbWFuZC5vcHRpb25zKSB7XG4gICAgICBjb25zdCBrZXkgPSBjYW1lbENhc2UoKG9wdGlvbi5sb25nID8/IG9wdGlvbi5zaG9ydCkhKTtcbiAgICAgIGlmIChwcm92aWRlZE9wdGlvbnM/LltrZXldKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBtaXNzaW5nT3B0aW9ucy5hZGQoa2V5KTtcbiAgICB9XG5cbiAgICBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZC5zZXQoY3VycmVudENvbW1hbmQsIG1pc3NpbmdPcHRpb25zKTtcbiAgICBjdXJyZW50Q29tbWFuZCA9IGN1cnJlbnRDb21tYW5kLnBhcmVudDtcbiAgfVxuXG4gIHJldHVybiBtaXNzaW5nT3B0aW9uc0J5Q29tbWFuZDtcbn07XG5cbmV4cG9ydCB0eXBlIFBhcnRpYWxQYXJzZVJlc3VsdCA9IHtcbiAgLyoqXG4gICAqIFRoZSBjb21tYW5kIHdob3NlIGFjdGlvbiB3aWxsIGJlIGV4ZWN1dGVkXG4gICAqL1xuICBtYXRjaGVkQ29tbWFuZDogQ29tbWFuZCB8IHVuZGVmaW5lZDtcbiAgLyoqXG4gICAqIEEgbWFwIG9mIGNvbW1hbmRzIHRvIGEgc2V0IG9mIG1pc3Npbmcgb3B0aW9ucyBmb3IgdGhhdCBjb21tYW5kXG4gICAqL1xuICBtaXNzaW5nT3B0aW9uczogTWFwPENvbW1hbmQsIFNldDxzdHJpbmc+PjtcbiAgLyoqXG4gICAqIEEgbWFwIG9mIGNvbW1hbmRzIHRvIHRoZSBvcHRpb25zIHByb3ZpZGVkIGZvciB0aGF0IGNvbW1hbmRcbiAgICovXG4gIHByb3ZpZGVkT3B0aW9uczogTWFwPENvbW1hbmQsIE9wdGlvblZhbHVlcz47XG59O1xuXG4vKipcbiAqIFBhcnRpYWxseSBwYXJzZSBhcmd2IGZvciBhIGNvbW1hbmQgd2l0aG91dCBleGVjdXRpbmcgdGhlIGFjdGlvbi4gQHNlZSB7QGxpbmsgQ29tbWFuZC5wYXJzZX1cbiAqXG4gKiBAcmV0dXJucyBBbiBvYmplY3QgY29udGFpbmluZyB0aGUgbWF0Y2hlZCBjb21tYW5kLCB0aGUgcHJvdmlkZWQgb3B0aW9ucywgYW5kIHRoZSBtaXNzaW5nIG9wdGlvbnMuXG4gKi9cbmV4cG9ydCBjb25zdCBwYXJ0aWFsUGFyc2UgPSAoXG4gIGNvbW1hbmQ6IENvbW1hbmQsXG4gIGFyZ3Y6IHJlYWRvbmx5IHN0cmluZ1tdLFxuICBvcHRpb25zPzogUGFyc2VPcHRpb25zLFxuKTogUGFydGlhbFBhcnNlUmVzdWx0ID0+IHtcbiAgY29uc3QgcHJvdmlkZWRPcHRpb25zID0gbmV3IE1hcDxDb21tYW5kLCBPcHRpb25WYWx1ZXM+KCk7XG4gIGNvbnN0IGNvbW1hbmRzTWFwID0gbmV3IE1hcDxDb21tYW5kLCBDb21tYW5kPigpO1xuICBsZXQgbWF0Y2hlZENvbW1hbmQ6IENvbW1hbmQgfCB1bmRlZmluZWQ7XG5cbiAgY29uc3QgY3JlYXRlUGFyc2VyQ29tbWFuZCA9IChwYXJzZXJDb21tYW5kOiBDb21tYW5kLCBjb21tYW5kOiBDb21tYW5kKSA9PiB7XG4gICAgY29tbWFuZHNNYXAuc2V0KHBhcnNlckNvbW1hbmQsIGNvbW1hbmQpO1xuXG4gICAgZm9yIChjb25zdCBvcHRpb24gb2YgY29tbWFuZC5vcHRpb25zKSB7XG4gICAgICBwYXJzZXJDb21tYW5kLm9wdGlvbihvcHRpb24uZmxhZ3MsIG9wdGlvbi5kZXNjcmlwdGlvbik7XG4gICAgfVxuXG4gICAgcGFyc2VyQ29tbWFuZC5ob29rKFwicHJlU3ViY29tbWFuZFwiLCAodGhpc0NvbW1hbmQsIGFjdGlvbkNvbW1hbmQpID0+IHtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoY29tbWFuZHNNYXAuZ2V0KHBhcnNlckNvbW1hbmQpISwgdGhpc0NvbW1hbmQub3B0cygpKTtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoY29tbWFuZHNNYXAuZ2V0KGFjdGlvbkNvbW1hbmQpISwgdGhpc0NvbW1hbmQub3B0cygpKTtcbiAgICB9KTtcblxuICAgIHBhcnNlckNvbW1hbmQuYWN0aW9uKCgpID0+IHtcbiAgICAgIHByb3ZpZGVkT3B0aW9ucy5zZXQoXG4gICAgICAgIGNvbW1hbmRzTWFwLmdldChwYXJzZXJDb21tYW5kKSEsXG4gICAgICAgIHBhcnNlckNvbW1hbmQub3B0cygpLFxuICAgICAgKTtcbiAgICAgIG1hdGNoZWRDb21tYW5kID0gY29tbWFuZDtcbiAgICB9KTtcblxuICAgIGZvciAoY29uc3Qgc3ViY29tbWFuZCBvZiBjb21tYW5kLmNvbW1hbmRzIGFzIENvbW1hbmRbXSkge1xuICAgICAgY29uc3QgcGFyc2VyU3ViY29tbWFuZCA9IHBhcnNlckNvbW1hbmRcbiAgICAgICAgLmNvbW1hbmQoc3ViY29tbWFuZC5uYW1lKCkpXG4gICAgICAgIC5leGl0T3ZlcnJpZGUoKTtcbiAgICAgIGNyZWF0ZVBhcnNlckNvbW1hbmQocGFyc2VyU3ViY29tbWFuZCwgc3ViY29tbWFuZCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHBhcnNlckNvbW1hbmQ7XG4gIH07XG5cbiAgY29uc3QgcGFyc2VyQ29tbWFuZCA9IGNyZWF0ZVBhcnNlckNvbW1hbmQoXG4gICAgbmV3IENvbW1hbmQoKS5leGl0T3ZlcnJpZGUoKSxcbiAgICBjb21tYW5kLFxuICApO1xuICBwYXJzZXJDb21tYW5kLnBhcnNlKGFyZ3YsIG9wdGlvbnMpO1xuXG4gIGNvbnN0IG1pc3NpbmdPcHRpb25zID0gbWF0Y2hlZENvbW1hbmRcbiAgICA/IGZpbmRNaXNzaW5nT3B0aW9ucyhtYXRjaGVkQ29tbWFuZCwgcHJvdmlkZWRPcHRpb25zKVxuICAgIDogbmV3IE1hcDxDb21tYW5kLCBTZXQ8c3RyaW5nPj4oKTtcblxuICByZXR1cm4geyBtYXRjaGVkQ29tbWFuZCwgbWlzc2luZ09wdGlvbnMsIHByb3ZpZGVkT3B0aW9ucyB9O1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7QUFBQSxPQUFPLGVBQWU7QUFDdEIsU0FBNEIsZUFBa0M7QUFFdkQsSUFBTSxxQkFBcUIsQ0FDaEMsU0FDQSw2QkFDRztBQUNILFFBQU0sMEJBQTBCLG9CQUFJLElBQTBCO0FBRzlELE1BQUksaUJBQTZDO0FBRWpELFNBQU8sZ0JBQWdCO0FBQ3JCLFVBQU0saUJBQWlCLG9CQUFJLElBQVk7QUFDdkMsVUFBTSxrQkFBa0IseUJBQXlCLElBQUksY0FBYztBQUNuRSxlQUFXLFVBQVUsZUFBZSxTQUFTO0FBQzNDLFlBQU0sTUFBTSxVQUFXLE9BQU8sUUFBUSxPQUFPLEtBQU87QUFDcEQsVUFBSSxrQkFBa0IsR0FBRyxHQUFHO0FBQzFCO0FBQUEsTUFDRjtBQUVBLHFCQUFlLElBQUksR0FBRztBQUFBLElBQ3hCO0FBRUEsNEJBQXdCLElBQUksZ0JBQWdCLGNBQWM7QUFDMUQscUJBQWlCLGVBQWU7QUFBQSxFQUNsQztBQUVBLFNBQU87QUFDVDtBQXNCTyxJQUFNLGVBQWUsQ0FDMUIsU0FDQSxNQUNBLFlBQ3VCO0FBQ3ZCLFFBQU0sa0JBQWtCLG9CQUFJLElBQTJCO0FBQ3ZELFFBQU0sY0FBYyxvQkFBSSxJQUFzQjtBQUM5QyxNQUFJO0FBRUosUUFBTSxzQkFBc0IsQ0FBQ0EsZ0JBQXdCQyxhQUFxQjtBQUN4RSxnQkFBWSxJQUFJRCxnQkFBZUMsUUFBTztBQUV0QyxlQUFXLFVBQVVBLFNBQVEsU0FBUztBQUNwQyxNQUFBRCxlQUFjLE9BQU8sT0FBTyxPQUFPLE9BQU8sV0FBVztBQUFBLElBQ3ZEO0FBRUEsSUFBQUEsZUFBYyxLQUFLLGlCQUFpQixDQUFDLGFBQWEsa0JBQWtCO0FBQ2xFLHNCQUFnQixJQUFJLFlBQVksSUFBSUEsY0FBYSxHQUFJLFlBQVksS0FBSyxDQUFDO0FBQ3ZFLHNCQUFnQixJQUFJLFlBQVksSUFBSSxhQUFhLEdBQUksWUFBWSxLQUFLLENBQUM7QUFBQSxJQUN6RSxDQUFDO0FBRUQsSUFBQUEsZUFBYyxPQUFPLE1BQU07QUFDekIsc0JBQWdCO0FBQUEsUUFDZCxZQUFZLElBQUlBLGNBQWE7QUFBQSxRQUM3QkEsZUFBYyxLQUFLO0FBQUEsTUFDckI7QUFDQSx1QkFBaUJDO0FBQUEsSUFDbkIsQ0FBQztBQUVELGVBQVcsY0FBY0EsU0FBUSxVQUF1QjtBQUN0RCxZQUFNLG1CQUFtQkQsZUFDdEIsUUFBUSxXQUFXLEtBQUssQ0FBQyxFQUN6QixhQUFhO0FBQ2hCLDBCQUFvQixrQkFBa0IsVUFBVTtBQUFBLElBQ2xEO0FBRUEsV0FBT0E7QUFBQSxFQUNUO0FBRUEsUUFBTSxnQkFBZ0I7QUFBQSxJQUNwQixJQUFJLFFBQVEsRUFBRSxhQUFhO0FBQUEsSUFDM0I7QUFBQSxFQUNGO0FBQ0EsZ0JBQWMsTUFBTSxNQUFNLE9BQU87QUFFakMsUUFBTSxpQkFBaUIsaUJBQ25CLG1CQUFtQixnQkFBZ0IsZUFBZSxJQUNsRCxvQkFBSSxJQUEwQjtBQUVsQyxTQUFPLEVBQUUsZ0JBQWdCLGdCQUFnQixnQkFBZ0I7QUFDM0Q7IiwKICAibmFtZXMiOiBbInBhcnNlckNvbW1hbmQiLCAiY29tbWFuZCJdCn0K
95
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": ["import camelCase from \"camelcase\";\nimport {\n  type OptionValues,\n  Command,\n  type ParseOptions,\n  Option,\n} from \"commander\";\n\nexport const findMissingOptions = (\n  command: Command,\n  providedOptionsByCommand: Map<Command, OptionValues>,\n) => {\n  const missingOptionsByCommand = new Map<Command, Set<string>>();\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  let currentCommand: Command | undefined | null = command;\n\n  while (currentCommand) {\n    const missingOptions = new Set<string>();\n    const providedOptions = providedOptionsByCommand.get(currentCommand);\n    for (const option of currentCommand.options) {\n      const key = camelCase((option.long ?? option.short)!);\n      if (providedOptions?.[key]) {\n        continue;\n      }\n\n      missingOptions.add(key);\n    }\n\n    missingOptionsByCommand.set(currentCommand, missingOptions);\n    currentCommand = currentCommand.parent;\n  }\n\n  return missingOptionsByCommand;\n};\n\nexport type PartialParseResult = {\n  /**\n   * The command whose action will be executed\n   */\n  matchedCommand: Command | undefined;\n  /**\n   * A map of commands to a set of missing options for that command\n   */\n  missingOptions: Map<Command, Set<string>>;\n  /**\n   * A map of commands to the options provided for that command\n   */\n  providedOptions: Map<Command, OptionValues>;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  for (const keysToCopy of [\n    \"_args\",\n    \"_combineFlagAndOptionalValue\",\n    \"_allowUnknownOption\",\n    \"_allowExcessArguments\",\n    \"_enablePositionalOptions\",\n    \"_passThroughOptions\",\n  ] as const) {\n    // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n    (target as any)[keysToCopy] = (source as any)[keysToCopy];\n  }\n\n  target.name(source.name());\n  target.aliases(source.aliases());\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.makeOptionMandatory(false);\n  newOption.preset(option.parseArg);\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  return newOption;\n};\n\n/**\n * Partially parse argv for a command without executing the action. @see {@link Command.parse}\n *\n * @returns An object containing the matched command, the provided options, and the missing options.\n */\nexport const partialParse = (\n  command: Command,\n  argv: readonly string[],\n  options?: ParseOptions,\n): PartialParseResult => {\n  const providedOptions = new Map<Command, OptionValues>();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n\n    for (const option of command.options) {\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      providedOptions.set(commandsMap.get(parserCommand)!, thisCommand.opts());\n      providedOptions.set(commandsMap.get(actionCommand)!, thisCommand.opts());\n    });\n\n    parserCommand.action(() => {\n      providedOptions.set(\n        commandsMap.get(parserCommand)!,\n        parserCommand.opts(),\n      );\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand\n        .command(subcommand.name())\n        .exitOverride();\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(\n    new Command().exitOverride(),\n    command,\n  );\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return { matchedCommand, missingOptions, providedOptions };\n};\n"],
  "mappings": ";AAAA,OAAO,eAAe;AACtB;AAAA,EAEE;AAAA,EAEA;AAAA,OACK;AAEA,IAAM,qBAAqB,CAChC,SACA,6BACG;AACH,QAAM,0BAA0B,oBAAI,IAA0B;AAG9D,MAAI,iBAA6C;AAEjD,SAAO,gBAAgB;AACrB,UAAM,iBAAiB,oBAAI,IAAY;AACvC,UAAM,kBAAkB,yBAAyB,IAAI,cAAc;AACnE,eAAW,UAAU,eAAe,SAAS;AAC3C,YAAM,MAAM,UAAW,OAAO,QAAQ,OAAO,KAAO;AACpD,UAAI,kBAAkB,GAAG,GAAG;AAC1B;AAAA,MACF;AAEA,qBAAe,IAAI,GAAG;AAAA,IACxB;AAEA,4BAAwB,IAAI,gBAAgB,cAAc;AAC1D,qBAAiB,eAAe;AAAA,EAClC;AAEA,SAAO;AACT;AAiBA,IAAM,sBAAsB,CAAC,QAAiB,WAAoB;AAChE,aAAW,cAAc;AAAA,IACvB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,GAAY;AAEV,IAAC,OAAe,UAAU,IAAK,OAAe,UAAU;AAAA,EAC1D;AAEA,SAAO,KAAK,OAAO,KAAK,CAAC;AACzB,SAAO,QAAQ,OAAO,QAAQ,CAAC;AACjC;AAEA,IAAM,cAAc,CAAC,WAAmB;AACtC,QAAM,YAAY,IAAI,OAAO,OAAO,OAAO,OAAO,WAAW;AAC7D,YAAU,QAAQ,OAAO,cAAc,OAAO,uBAAuB;AACrE,MAAI,OAAO,YAAY;AACrB,cAAU,QAAQ,OAAO,UAAU;AAAA,EACrC;AAEA,YAAU,oBAAoB,KAAK;AACnC,YAAU,OAAO,OAAO,QAAQ;AAChC,YAAU;AAAA,IACP,OAAgD;AAAA,EACnD;AACA,YAAU,IAAK,OAAuC,MAAM;AAC5D,MAAI,OAAO,UAAU;AACnB,cAAU,UAAU,OAAO,QAAQ;AAAA,EACrC;AAEA,SAAO;AACT;AAOO,IAAM,eAAe,CAC1B,SACA,MACA,YACuB;AACvB,QAAM,kBAAkB,oBAAI,IAA2B;AACvD,QAAM,cAAc,oBAAI,IAAsB;AAC9C,MAAI;AAEJ,QAAM,sBAAsB,CAACA,gBAAwBC,aAAqB;AACxE,gBAAY,IAAID,gBAAeC,QAAO;AAEtC,wBAAoBA,UAASD,cAAa;AAE1C,eAAW,UAAUC,SAAQ,SAAS;AACpC,MAAAD,eAAc,UAAU,YAAY,MAAM,CAAC;AAAA,IAC7C;AAEA,IAAAA,eAAc,KAAK,iBAAiB,CAAC,aAAa,kBAAkB;AAClE,sBAAgB,IAAI,YAAY,IAAIA,cAAa,GAAI,YAAY,KAAK,CAAC;AACvE,sBAAgB,IAAI,YAAY,IAAI,aAAa,GAAI,YAAY,KAAK,CAAC;AAAA,IACzE,CAAC;AAED,IAAAA,eAAc,OAAO,MAAM;AACzB,sBAAgB;AAAA,QACd,YAAY,IAAIA,cAAa;AAAA,QAC7BA,eAAc,KAAK;AAAA,MACrB;AACA,uBAAiBC;AAAA,IACnB,CAAC;AAED,eAAW,cAAcA,SAAQ,UAAuB;AACtD,YAAM,mBAAmBD,eACtB,QAAQ,WAAW,KAAK,CAAC,EACzB,aAAa;AAChB,0BAAoB,kBAAkB,UAAU;AAAA,IAClD;AAEA,WAAOA;AAAA,EACT;AAEA,QAAM,gBAAgB;AAAA,IACpB,IAAI,QAAQ,EAAE,aAAa;AAAA,IAC3B;AAAA,EACF;AACA,gBAAc,MAAM,MAAM,OAAO;AAEjC,QAAM,iBAAiB,iBACnB,mBAAmB,gBAAgB,eAAe,IAClD,oBAAI,IAA0B;AAElC,SAAO,EAAE,gBAAgB,gBAAgB,gBAAgB;AAC3D;",
  "names": ["parserCommand", "command"]
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-my-command",
3
- "version": "0.1.3",
3
+ "version": "0.1.4",
4
4
  "description": "Parse argv with Commander.js without executing the command",
5
5
  "keywords": [
6
6
  "parser",