parse-my-command 0.4.0 → 0.5.1

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/dist/index.cjs CHANGED
@@ -1,55 +1,107 @@
1
1
  var __create = Object.create;
2
+ var __getProtoOf = Object.getPrototypeOf;
2
3
  var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
7
+ function __accessProp(key) {
8
+ return this[key];
9
+ }
10
+ var __toESMCache_node;
11
+ var __toESMCache_esm;
12
+ var __toESM = (mod, isNodeMode, target) => {
13
+ var canCache = mod != null && typeof mod === "object";
14
+ if (canCache) {
15
+ var cache = isNodeMode ? __toESMCache_node ??= new WeakMap : __toESMCache_esm ??= new WeakMap;
16
+ var cached = cache.get(mod);
17
+ if (cached)
18
+ return cached;
19
+ }
20
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
21
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
22
+ for (let key of __getOwnPropNames(mod))
23
+ if (!__hasOwnProp.call(to, key))
24
+ __defProp(to, key, {
25
+ get: __accessProp.bind(mod, key),
26
+ enumerable: true
27
+ });
28
+ if (canCache)
29
+ cache.set(mod, to);
30
+ return to;
10
31
  };
11
- var __copyProps = (to, from, except, desc) => {
32
+ var __toCommonJS = (from) => {
33
+ var entry = (__moduleCache ??= new WeakMap).get(from), desc;
34
+ if (entry)
35
+ return entry;
36
+ entry = __defProp({}, "__esModule", { value: true });
12
37
  if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
38
+ for (var key of __getOwnPropNames(from))
39
+ if (!__hasOwnProp.call(entry, key))
40
+ __defProp(entry, key, {
41
+ get: __accessProp.bind(from, key),
42
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
43
+ });
16
44
  }
17
- return to;
45
+ __moduleCache.set(from, entry);
46
+ return entry;
47
+ };
48
+ var __moduleCache;
49
+ var __returnValue = (v) => v;
50
+ function __exportSetter(name, newValue) {
51
+ this[name] = __returnValue.bind(null, newValue);
52
+ }
53
+ var __export = (target, all) => {
54
+ for (var name in all)
55
+ __defProp(target, name, {
56
+ get: all[name],
57
+ enumerable: true,
58
+ configurable: true,
59
+ set: __exportSetter.bind(all, name)
60
+ });
18
61
  };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
62
 
29
63
  // src/index.ts
30
- var index_exports = {};
31
- __export(index_exports, {
32
- findMissingOptions: () => findMissingOptions,
33
- partialParse: () => partialParse
64
+ var exports_src = {};
65
+ __export(exports_src, {
66
+ partialParse: () => partialParse,
67
+ findMissingOptions: () => findMissingOptions
34
68
  });
35
- module.exports = __toCommonJS(index_exports);
69
+ module.exports = __toCommonJS(exports_src);
70
+ var import_camelcase = __toESM(require("camelcase"));
71
+ var import_commander = require("commander");
36
72
 
37
73
  // src/noop.ts
38
- var noop = () => {
39
- };
74
+ var noop = () => {};
40
75
 
41
76
  // src/index.ts
42
- var import_camelcase = __toESM(require("camelcase"), 1);
43
- var import_commander = require("commander");
77
+ var commandSettingKeys = [
78
+ "_allowExcessArguments",
79
+ "_allowUnknownOption",
80
+ "_combineFlagAndOptionalValue",
81
+ "_defaultCommandName",
82
+ "_enablePositionalOptions",
83
+ "_passThroughOptions"
84
+ ];
85
+ var getOrThrow = (map, key) => {
86
+ const value = map.get(key);
87
+ if (value === undefined) {
88
+ throw new Error("Expected map value to be present");
89
+ }
90
+ return value;
91
+ };
44
92
  var findMissingOptions = (command, providedOptionsByCommand) => {
45
- const missingOptionsByCommand = /* @__PURE__ */ new Map();
93
+ const missingOptionsByCommand = new Map;
46
94
  let currentCommand = command;
47
95
  while (currentCommand) {
48
- const missingOptions = /* @__PURE__ */ new Set();
96
+ const missingOptions = new Set;
49
97
  const providedOptions = providedOptionsByCommand.get(currentCommand);
50
98
  for (const option of currentCommand.options) {
51
- const key = option.negate ? (0, import_camelcase.default)(option.long.replace(/^--no-/, "")) : (0, import_camelcase.default)(option.long ?? option.short);
52
- if (providedOptions?.[key] !== void 0) {
99
+ const optionName = option.negate ? option.long?.replace(/^--no-/, "") : option.long ?? option.short;
100
+ if (!optionName) {
101
+ continue;
102
+ }
103
+ const key = import_camelcase.default(optionName);
104
+ if (providedOptions?.[key] !== undefined) {
53
105
  continue;
54
106
  }
55
107
  missingOptions.add(key);
@@ -60,28 +112,19 @@ var findMissingOptions = (command, providedOptionsByCommand) => {
60
112
  return missingOptionsByCommand;
61
113
  };
62
114
  var copyCommandSettings = (source, target) => {
63
- for (const keysToCopy of [
64
- "_allowExcessArguments",
65
- "_allowUnknownOption",
66
- "_combineFlagAndOptionalValue",
67
- "_defaultCommandName",
68
- "_enablePositionalOptions",
69
- "_passThroughOptions"
70
- ]) {
71
- target[keysToCopy] = source[keysToCopy];
115
+ const sourcePrivateState = source;
116
+ const targetPrivateState = target;
117
+ for (const key of commandSettingKeys) {
118
+ targetPrivateState[key] = sourcePrivateState[key];
72
119
  }
73
120
  target.name(source.name());
74
121
  target.aliases(source.aliases());
75
122
  for (const argument of source.registeredArguments) {
76
123
  target.addArgument(argument);
77
124
  }
78
- if (source.version()) {
79
- target.version(
80
- source.version(),
81
- source.options.find(
82
- (option) => option.attributeName() === source._versionOptionName
83
- )?.flags
84
- );
125
+ const version = source.version();
126
+ if (version) {
127
+ target.version(version, source.options.find((option) => option.attributeName() === sourcePrivateState._versionOptionName)?.flags);
85
128
  }
86
129
  };
87
130
  var disableCommandOutput = (command) => {
@@ -103,22 +146,20 @@ var cloneOption = (option) => {
103
146
  if (option.argChoices) {
104
147
  newOption.choices(option.argChoices);
105
148
  }
106
- newOption.conflicts(
107
- option.conflictsWith
108
- );
149
+ newOption.conflicts(option.conflictsWith);
109
150
  newOption.implied = option.implied;
110
151
  return newOption;
111
152
  };
112
153
  var partialParse = (command, argv, options) => {
113
- const providedOptions = /* @__PURE__ */ new Map();
114
- const providedOptionsSources = /* @__PURE__ */ new Map();
115
- const commandsMap = /* @__PURE__ */ new Map();
154
+ const providedOptions = new Map;
155
+ const providedOptionsSources = new Map;
156
+ const commandsMap = new Map;
116
157
  let matchedCommand;
117
158
  const setProvidedOptionSource = (command2, optionKey, source) => {
118
159
  if (!source) {
119
160
  return;
120
161
  }
121
- const sourcesMap = providedOptionsSources.get(command2) ?? /* @__PURE__ */ new Map();
162
+ const sourcesMap = providedOptionsSources.get(command2) ?? new Map;
122
163
  sourcesMap.set(optionKey, source);
123
164
  providedOptionsSources.set(command2, sourcesMap);
124
165
  };
@@ -128,36 +169,25 @@ var partialParse = (command, argv, options) => {
128
169
  disableCommandOutput(parserCommand2);
129
170
  parserCommand2.exitOverride();
130
171
  for (const option of command2.options) {
131
- if (parserCommand2.options.some(
132
- (parserCommandOption) => parserCommandOption.flags === option.flags
133
- )) {
172
+ if (parserCommand2.options.some((parserCommandOption) => parserCommandOption.flags === option.flags)) {
134
173
  continue;
135
174
  }
136
175
  parserCommand2.addOption(cloneOption(option));
137
176
  }
138
177
  parserCommand2.hook("preSubcommand", (thisCommand, actionCommand) => {
139
178
  for (const cmd of [thisCommand, actionCommand]) {
140
- providedOptions.set(commandsMap.get(cmd), cmd.opts());
179
+ const originalCommand = getOrThrow(commandsMap, cmd);
180
+ providedOptions.set(originalCommand, cmd.opts());
141
181
  for (const optionKey of Object.keys(cmd.opts())) {
142
- setProvidedOptionSource(
143
- cmd,
144
- optionKey,
145
- cmd.getOptionValueSource(optionKey)
146
- );
182
+ setProvidedOptionSource(originalCommand, optionKey, cmd.getOptionValueSource(optionKey));
147
183
  }
148
184
  }
149
185
  });
150
186
  parserCommand2.action(() => {
151
- providedOptions.set(
152
- commandsMap.get(parserCommand2),
153
- parserCommand2.opts()
154
- );
187
+ const originalCommand = getOrThrow(commandsMap, parserCommand2);
188
+ providedOptions.set(originalCommand, parserCommand2.opts());
155
189
  for (const optionKey of Object.keys(parserCommand2.opts())) {
156
- setProvidedOptionSource(
157
- commandsMap.get(parserCommand2),
158
- optionKey,
159
- parserCommand2.getOptionValueSource(optionKey)
160
- );
190
+ setProvidedOptionSource(originalCommand, optionKey, parserCommand2.getOptionValueSource(optionKey));
161
191
  }
162
192
  matchedCommand = command2;
163
193
  });
@@ -167,9 +197,9 @@ var partialParse = (command, argv, options) => {
167
197
  }
168
198
  return parserCommand2;
169
199
  };
170
- const parserCommand = createParserCommand(new import_commander.Command(), command);
200
+ const parserCommand = createParserCommand(new import_commander.Command, command);
171
201
  parserCommand.parse(argv, options);
172
- const missingOptions = matchedCommand ? findMissingOptions(matchedCommand, providedOptions) : /* @__PURE__ */ new Map();
202
+ const missingOptions = matchedCommand ? findMissingOptions(matchedCommand, providedOptions) : new Map;
173
203
  return {
174
204
  matchedCommand,
175
205
  missingOptions,
@@ -177,9 +207,6 @@ var partialParse = (command, argv, options) => {
177
207
  providedOptionsSources
178
208
  };
179
209
  };
180
- // Annotate the CommonJS export names for ESM import in node:
181
- 0 && (module.exports = {
182
- findMissingOptions,
183
- partialParse
184
- });
185
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/noop.ts"],
  "sourcesContent": ["import { noop } from \"./noop.ts\";\nimport camelCase from \"camelcase\";\nimport {\n  type OptionValues,\n  Command,\n  type ParseOptions,\n  Option,\n  type OptionValueSource,\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 = option.negate\n        ? camelCase(option.long!.replace(/^--no-/, \"\"))\n        : camelCase((option.long ?? option.short)!);\n\n      if (providedOptions?.[key] !== undefined) {\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   * A map of commands to a map of option keys to the source of the option value\n   */\n  providedOptionsSources: Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  for (const keysToCopy of [\n    \"_allowExcessArguments\",\n    \"_allowUnknownOption\",\n    \"_combineFlagAndOptionalValue\",\n    \"_defaultCommandName\",\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  for (const argument of source.registeredArguments) {\n    target.addArgument(argument);\n  }\n\n  if (source.version()) {\n    target.version(\n      source.version()!,\n      source.options.find(\n        (option) =>\n          option.attributeName() ===\n          (source as Command & { _versionOptionName: string })\n            ._versionOptionName,\n      )?.flags,\n    );\n  }\n};\n\nconst disableCommandOutput = (command: Command) => {\n  command.configureOutput({\n    writeOut: noop,\n    writeErr: noop,\n    outputError: noop,\n  });\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.makeOptionMandatory(false);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n\n  newOption.preset((option as Option & { presetArg: unknown }).presetArg);\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n\n  (newOption as Option & { implied: unknown }).implied = (\n    option as Option & { implied: unknown }\n  ).implied;\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 providedOptionsSources = new Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const setProvidedOptionSource = (\n    command: Command,\n    optionKey: string,\n    source: OptionValueSource | undefined,\n  ) => {\n    if (!source) {\n      return;\n    }\n\n    const sourcesMap =\n      providedOptionsSources.get(command) ??\n      new Map<string, OptionValueSource>();\n    sourcesMap.set(optionKey, source);\n    providedOptionsSources.set(command, sourcesMap);\n  };\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n    disableCommandOutput(parserCommand);\n    parserCommand.exitOverride();\n\n    for (const option of command.options) {\n      // Skip adding the option if it's already registered\n      if (\n        parserCommand.options.some(\n          (parserCommandOption) => parserCommandOption.flags === option.flags,\n        )\n      ) {\n        continue;\n      }\n\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      for (const cmd of [thisCommand, actionCommand]) {\n        providedOptions.set(commandsMap.get(cmd)!, cmd.opts());\n\n        for (const optionKey of Object.keys(cmd.opts())) {\n          setProvidedOptionSource(\n            cmd,\n            optionKey,\n            cmd.getOptionValueSource(optionKey),\n          );\n        }\n      }\n    });\n\n    parserCommand.action(() => {\n      providedOptions.set(\n        commandsMap.get(parserCommand)!,\n        parserCommand.opts(),\n      );\n\n      for (const optionKey of Object.keys(parserCommand.opts())) {\n        setProvidedOptionSource(\n          commandsMap.get(parserCommand)!,\n          optionKey,\n          parserCommand.getOptionValueSource(optionKey),\n        );\n      }\n\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand.command(subcommand.name());\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(new Command(), command);\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return {\n    matchedCommand,\n    missingOptions,\n    providedOptions,\n    providedOptionsSources,\n  };\n};\n", "// eslint-disable-next-line @typescript-eslint/no-empty-function\nexport const noop = () => {};\n"],
  "mappings": "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",
  "names": ["camelCase", "command", "parserCommand"]
}

210
+
211
+ //# debugId=F0B7EB039167465764756E2164756E21
212
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/noop.ts"],
  "sourcesContent": [
    "import camelCase from \"camelcase\";\nimport {\n  Command,\n  Option,\n  type OptionValueSource,\n  type OptionValues,\n  type ParseOptions,\n} from \"commander\";\nimport { noop } from \"./noop.js\";\n\nconst commandSettingKeys = [\n  \"_allowExcessArguments\",\n  \"_allowUnknownOption\",\n  \"_combineFlagAndOptionalValue\",\n  \"_defaultCommandName\",\n  \"_enablePositionalOptions\",\n  \"_passThroughOptions\",\n] as const;\n\ntype CommandSettingKey = (typeof commandSettingKeys)[number];\ntype CommandPrivateState = Command &\n  Record<CommandSettingKey, unknown> & {\n    _versionOptionName?: string;\n  };\n\nconst getOrThrow = <Key, Value>(map: Map<Key, Value>, key: Key): Value => {\n  const value = map.get(key);\n  if (value === undefined) {\n    throw new Error(\"Expected map value to be present\");\n  }\n\n  return value;\n};\n\nexport const findMissingOptions = (\n  command: Command,\n  providedOptionsByCommand: Map<Command, OptionValues>,\n) => {\n  const missingOptionsByCommand = new Map<Command, Set<string>>();\n\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 optionName = option.negate\n        ? option.long?.replace(/^--no-/, \"\")\n        : (option.long ?? option.short);\n      if (!optionName) {\n        continue;\n      }\n\n      const key = camelCase(optionName);\n\n      if (providedOptions?.[key] !== undefined) {\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   * A map of commands to a map of option keys to the source of the option value\n   */\n  providedOptionsSources: Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  const sourcePrivateState = source as CommandPrivateState;\n  const targetPrivateState = target as CommandPrivateState;\n\n  for (const key of commandSettingKeys) {\n    targetPrivateState[key] = sourcePrivateState[key];\n  }\n\n  target.name(source.name());\n  target.aliases(source.aliases());\n  for (const argument of source.registeredArguments) {\n    target.addArgument(argument);\n  }\n\n  const version = source.version();\n  if (version) {\n    target.version(\n      version,\n      source.options.find(\n        (option) =>\n          option.attributeName() === sourcePrivateState._versionOptionName,\n      )?.flags,\n    );\n  }\n};\n\nconst disableCommandOutput = (command: Command) => {\n  command.configureOutput({\n    writeOut: noop,\n    writeErr: noop,\n    outputError: noop,\n  });\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.makeOptionMandatory(false);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n\n  newOption.preset((option as Option & { presetArg: unknown }).presetArg);\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n\n  (newOption as Option & { implied: unknown }).implied = (\n    option as Option & { implied: unknown }\n  ).implied;\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 providedOptionsSources = new Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const setProvidedOptionSource = (\n    command: Command,\n    optionKey: string,\n    source: OptionValueSource | undefined,\n  ) => {\n    if (!source) {\n      return;\n    }\n\n    const sourcesMap =\n      providedOptionsSources.get(command) ??\n      new Map<string, OptionValueSource>();\n    sourcesMap.set(optionKey, source);\n    providedOptionsSources.set(command, sourcesMap);\n  };\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n    disableCommandOutput(parserCommand);\n    parserCommand.exitOverride();\n\n    for (const option of command.options) {\n      // Skip adding the option if it's already registered\n      if (\n        parserCommand.options.some(\n          (parserCommandOption) => parserCommandOption.flags === option.flags,\n        )\n      ) {\n        continue;\n      }\n\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      for (const cmd of [thisCommand, actionCommand]) {\n        const originalCommand = getOrThrow(commandsMap, cmd);\n        providedOptions.set(originalCommand, cmd.opts());\n\n        for (const optionKey of Object.keys(cmd.opts())) {\n          setProvidedOptionSource(\n            originalCommand,\n            optionKey,\n            cmd.getOptionValueSource(optionKey),\n          );\n        }\n      }\n    });\n\n    parserCommand.action(() => {\n      const originalCommand = getOrThrow(commandsMap, parserCommand);\n      providedOptions.set(originalCommand, parserCommand.opts());\n\n      for (const optionKey of Object.keys(parserCommand.opts())) {\n        setProvidedOptionSource(\n          originalCommand,\n          optionKey,\n          parserCommand.getOptionValueSource(optionKey),\n        );\n      }\n\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand.command(subcommand.name());\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(new Command(), command);\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return {\n    matchedCommand,\n    missingOptions,\n    providedOptions,\n    providedOptionsSources,\n  };\n};\n",
    "export const noop = () => {};\n"
  ],
  "mappings": "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",
  "debugId": "F0B7EB039167465764756E2164756E21",
  "names": []
}
package/dist/index.d.cts CHANGED
@@ -1,7 +1,6 @@
1
- import { Command, OptionValues, OptionValueSource, ParseOptions } from 'commander';
2
-
3
- declare const findMissingOptions: (command: Command, providedOptionsByCommand: Map<Command, OptionValues>) => Map<Command, Set<string>>;
4
- type PartialParseResult = {
1
+ import { Command, type OptionValueSource, type OptionValues, type ParseOptions } from "commander";
2
+ export declare const findMissingOptions: (command: Command, providedOptionsByCommand: Map<Command, OptionValues>) => Map<Command, Set<string>>;
3
+ export type PartialParseResult = {
5
4
  /**
6
5
  * The command whose action will be executed
7
6
  */
@@ -24,6 +23,4 @@ type PartialParseResult = {
24
23
  *
25
24
  * @returns An object containing the matched command, the provided options, and the missing options.
26
25
  */
27
- declare const partialParse: (command: Command, argv: readonly string[], options?: ParseOptions) => PartialParseResult;
28
-
29
- export { type PartialParseResult, findMissingOptions, partialParse };
26
+ export declare const partialParse: (command: Command, argv: readonly string[], options?: ParseOptions) => PartialParseResult;
package/dist/index.d.ts CHANGED
@@ -1,7 +1,6 @@
1
- import { Command, OptionValues, OptionValueSource, ParseOptions } from 'commander';
2
-
3
- declare const findMissingOptions: (command: Command, providedOptionsByCommand: Map<Command, OptionValues>) => Map<Command, Set<string>>;
4
- type PartialParseResult = {
1
+ import { Command, type OptionValueSource, type OptionValues, type ParseOptions } from "commander";
2
+ export declare const findMissingOptions: (command: Command, providedOptionsByCommand: Map<Command, OptionValues>) => Map<Command, Set<string>>;
3
+ export type PartialParseResult = {
5
4
  /**
6
5
  * The command whose action will be executed
7
6
  */
@@ -24,6 +23,4 @@ type PartialParseResult = {
24
23
  *
25
24
  * @returns An object containing the matched command, the provided options, and the missing options.
26
25
  */
27
- declare const partialParse: (command: Command, argv: readonly string[], options?: ParseOptions) => PartialParseResult;
28
-
29
- export { type PartialParseResult, findMissingOptions, partialParse };
26
+ export declare const partialParse: (command: Command, argv: readonly string[], options?: ParseOptions) => PartialParseResult;
package/dist/index.js CHANGED
@@ -1,22 +1,42 @@
1
- // src/noop.ts
2
- var noop = () => {
3
- };
4
-
5
1
  // src/index.ts
6
2
  import camelCase from "camelcase";
7
3
  import {
8
4
  Command,
9
5
  Option
10
6
  } from "commander";
7
+
8
+ // src/noop.ts
9
+ var noop = () => {};
10
+
11
+ // src/index.ts
12
+ var commandSettingKeys = [
13
+ "_allowExcessArguments",
14
+ "_allowUnknownOption",
15
+ "_combineFlagAndOptionalValue",
16
+ "_defaultCommandName",
17
+ "_enablePositionalOptions",
18
+ "_passThroughOptions"
19
+ ];
20
+ var getOrThrow = (map, key) => {
21
+ const value = map.get(key);
22
+ if (value === undefined) {
23
+ throw new Error("Expected map value to be present");
24
+ }
25
+ return value;
26
+ };
11
27
  var findMissingOptions = (command, providedOptionsByCommand) => {
12
- const missingOptionsByCommand = /* @__PURE__ */ new Map();
28
+ const missingOptionsByCommand = new Map;
13
29
  let currentCommand = command;
14
30
  while (currentCommand) {
15
- const missingOptions = /* @__PURE__ */ new Set();
31
+ const missingOptions = new Set;
16
32
  const providedOptions = providedOptionsByCommand.get(currentCommand);
17
33
  for (const option of currentCommand.options) {
18
- const key = option.negate ? camelCase(option.long.replace(/^--no-/, "")) : camelCase(option.long ?? option.short);
19
- if (providedOptions?.[key] !== void 0) {
34
+ const optionName = option.negate ? option.long?.replace(/^--no-/, "") : option.long ?? option.short;
35
+ if (!optionName) {
36
+ continue;
37
+ }
38
+ const key = camelCase(optionName);
39
+ if (providedOptions?.[key] !== undefined) {
20
40
  continue;
21
41
  }
22
42
  missingOptions.add(key);
@@ -27,28 +47,19 @@ var findMissingOptions = (command, providedOptionsByCommand) => {
27
47
  return missingOptionsByCommand;
28
48
  };
29
49
  var copyCommandSettings = (source, target) => {
30
- for (const keysToCopy of [
31
- "_allowExcessArguments",
32
- "_allowUnknownOption",
33
- "_combineFlagAndOptionalValue",
34
- "_defaultCommandName",
35
- "_enablePositionalOptions",
36
- "_passThroughOptions"
37
- ]) {
38
- target[keysToCopy] = source[keysToCopy];
50
+ const sourcePrivateState = source;
51
+ const targetPrivateState = target;
52
+ for (const key of commandSettingKeys) {
53
+ targetPrivateState[key] = sourcePrivateState[key];
39
54
  }
40
55
  target.name(source.name());
41
56
  target.aliases(source.aliases());
42
57
  for (const argument of source.registeredArguments) {
43
58
  target.addArgument(argument);
44
59
  }
45
- if (source.version()) {
46
- target.version(
47
- source.version(),
48
- source.options.find(
49
- (option) => option.attributeName() === source._versionOptionName
50
- )?.flags
51
- );
60
+ const version = source.version();
61
+ if (version) {
62
+ target.version(version, source.options.find((option) => option.attributeName() === sourcePrivateState._versionOptionName)?.flags);
52
63
  }
53
64
  };
54
65
  var disableCommandOutput = (command) => {
@@ -70,22 +81,20 @@ var cloneOption = (option) => {
70
81
  if (option.argChoices) {
71
82
  newOption.choices(option.argChoices);
72
83
  }
73
- newOption.conflicts(
74
- option.conflictsWith
75
- );
84
+ newOption.conflicts(option.conflictsWith);
76
85
  newOption.implied = option.implied;
77
86
  return newOption;
78
87
  };
79
88
  var partialParse = (command, argv, options) => {
80
- const providedOptions = /* @__PURE__ */ new Map();
81
- const providedOptionsSources = /* @__PURE__ */ new Map();
82
- const commandsMap = /* @__PURE__ */ new Map();
89
+ const providedOptions = new Map;
90
+ const providedOptionsSources = new Map;
91
+ const commandsMap = new Map;
83
92
  let matchedCommand;
84
93
  const setProvidedOptionSource = (command2, optionKey, source) => {
85
94
  if (!source) {
86
95
  return;
87
96
  }
88
- const sourcesMap = providedOptionsSources.get(command2) ?? /* @__PURE__ */ new Map();
97
+ const sourcesMap = providedOptionsSources.get(command2) ?? new Map;
89
98
  sourcesMap.set(optionKey, source);
90
99
  providedOptionsSources.set(command2, sourcesMap);
91
100
  };
@@ -95,36 +104,25 @@ var partialParse = (command, argv, options) => {
95
104
  disableCommandOutput(parserCommand2);
96
105
  parserCommand2.exitOverride();
97
106
  for (const option of command2.options) {
98
- if (parserCommand2.options.some(
99
- (parserCommandOption) => parserCommandOption.flags === option.flags
100
- )) {
107
+ if (parserCommand2.options.some((parserCommandOption) => parserCommandOption.flags === option.flags)) {
101
108
  continue;
102
109
  }
103
110
  parserCommand2.addOption(cloneOption(option));
104
111
  }
105
112
  parserCommand2.hook("preSubcommand", (thisCommand, actionCommand) => {
106
113
  for (const cmd of [thisCommand, actionCommand]) {
107
- providedOptions.set(commandsMap.get(cmd), cmd.opts());
114
+ const originalCommand = getOrThrow(commandsMap, cmd);
115
+ providedOptions.set(originalCommand, cmd.opts());
108
116
  for (const optionKey of Object.keys(cmd.opts())) {
109
- setProvidedOptionSource(
110
- cmd,
111
- optionKey,
112
- cmd.getOptionValueSource(optionKey)
113
- );
117
+ setProvidedOptionSource(originalCommand, optionKey, cmd.getOptionValueSource(optionKey));
114
118
  }
115
119
  }
116
120
  });
117
121
  parserCommand2.action(() => {
118
- providedOptions.set(
119
- commandsMap.get(parserCommand2),
120
- parserCommand2.opts()
121
- );
122
+ const originalCommand = getOrThrow(commandsMap, parserCommand2);
123
+ providedOptions.set(originalCommand, parserCommand2.opts());
122
124
  for (const optionKey of Object.keys(parserCommand2.opts())) {
123
- setProvidedOptionSource(
124
- commandsMap.get(parserCommand2),
125
- optionKey,
126
- parserCommand2.getOptionValueSource(optionKey)
127
- );
125
+ setProvidedOptionSource(originalCommand, optionKey, parserCommand2.getOptionValueSource(optionKey));
128
126
  }
129
127
  matchedCommand = command2;
130
128
  });
@@ -134,9 +132,9 @@ var partialParse = (command, argv, options) => {
134
132
  }
135
133
  return parserCommand2;
136
134
  };
137
- const parserCommand = createParserCommand(new Command(), command);
135
+ const parserCommand = createParserCommand(new Command, command);
138
136
  parserCommand.parse(argv, options);
139
- const missingOptions = matchedCommand ? findMissingOptions(matchedCommand, providedOptions) : /* @__PURE__ */ new Map();
137
+ const missingOptions = matchedCommand ? findMissingOptions(matchedCommand, providedOptions) : new Map;
140
138
  return {
141
139
  matchedCommand,
142
140
  missingOptions,
@@ -145,7 +143,9 @@ var partialParse = (command, argv, options) => {
145
143
  };
146
144
  };
147
145
  export {
148
- findMissingOptions,
149
- partialParse
146
+ partialParse,
147
+ findMissingOptions
150
148
  };
151
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/noop.ts", "../src/index.ts"],
  "sourcesContent": ["// eslint-disable-next-line @typescript-eslint/no-empty-function\nexport const noop = () => {};\n", "import { noop } from \"./noop.ts\";\nimport camelCase from \"camelcase\";\nimport {\n  type OptionValues,\n  Command,\n  type ParseOptions,\n  Option,\n  type OptionValueSource,\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 = option.negate\n        ? camelCase(option.long!.replace(/^--no-/, \"\"))\n        : camelCase((option.long ?? option.short)!);\n\n      if (providedOptions?.[key] !== undefined) {\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   * A map of commands to a map of option keys to the source of the option value\n   */\n  providedOptionsSources: Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  for (const keysToCopy of [\n    \"_allowExcessArguments\",\n    \"_allowUnknownOption\",\n    \"_combineFlagAndOptionalValue\",\n    \"_defaultCommandName\",\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  for (const argument of source.registeredArguments) {\n    target.addArgument(argument);\n  }\n\n  if (source.version()) {\n    target.version(\n      source.version()!,\n      source.options.find(\n        (option) =>\n          option.attributeName() ===\n          (source as Command & { _versionOptionName: string })\n            ._versionOptionName,\n      )?.flags,\n    );\n  }\n};\n\nconst disableCommandOutput = (command: Command) => {\n  command.configureOutput({\n    writeOut: noop,\n    writeErr: noop,\n    outputError: noop,\n  });\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.makeOptionMandatory(false);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n\n  newOption.preset((option as Option & { presetArg: unknown }).presetArg);\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n\n  (newOption as Option & { implied: unknown }).implied = (\n    option as Option & { implied: unknown }\n  ).implied;\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 providedOptionsSources = new Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const setProvidedOptionSource = (\n    command: Command,\n    optionKey: string,\n    source: OptionValueSource | undefined,\n  ) => {\n    if (!source) {\n      return;\n    }\n\n    const sourcesMap =\n      providedOptionsSources.get(command) ??\n      new Map<string, OptionValueSource>();\n    sourcesMap.set(optionKey, source);\n    providedOptionsSources.set(command, sourcesMap);\n  };\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n    disableCommandOutput(parserCommand);\n    parserCommand.exitOverride();\n\n    for (const option of command.options) {\n      // Skip adding the option if it's already registered\n      if (\n        parserCommand.options.some(\n          (parserCommandOption) => parserCommandOption.flags === option.flags,\n        )\n      ) {\n        continue;\n      }\n\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      for (const cmd of [thisCommand, actionCommand]) {\n        providedOptions.set(commandsMap.get(cmd)!, cmd.opts());\n\n        for (const optionKey of Object.keys(cmd.opts())) {\n          setProvidedOptionSource(\n            cmd,\n            optionKey,\n            cmd.getOptionValueSource(optionKey),\n          );\n        }\n      }\n    });\n\n    parserCommand.action(() => {\n      providedOptions.set(\n        commandsMap.get(parserCommand)!,\n        parserCommand.opts(),\n      );\n\n      for (const optionKey of Object.keys(parserCommand.opts())) {\n        setProvidedOptionSource(\n          commandsMap.get(parserCommand)!,\n          optionKey,\n          parserCommand.getOptionValueSource(optionKey),\n        );\n      }\n\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand.command(subcommand.name());\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(new Command(), command);\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return {\n    matchedCommand,\n    missingOptions,\n    providedOptions,\n    providedOptionsSources,\n  };\n};\n"],
  "mappings": "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",
  "names": ["command", "parserCommand"]
}

149
+
150
+ //# debugId=0F2D30EA8353D1EC64756E2164756E21
151
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/noop.ts"],
  "sourcesContent": [
    "import camelCase from \"camelcase\";\nimport {\n  Command,\n  Option,\n  type OptionValueSource,\n  type OptionValues,\n  type ParseOptions,\n} from \"commander\";\nimport { noop } from \"./noop.js\";\n\nconst commandSettingKeys = [\n  \"_allowExcessArguments\",\n  \"_allowUnknownOption\",\n  \"_combineFlagAndOptionalValue\",\n  \"_defaultCommandName\",\n  \"_enablePositionalOptions\",\n  \"_passThroughOptions\",\n] as const;\n\ntype CommandSettingKey = (typeof commandSettingKeys)[number];\ntype CommandPrivateState = Command &\n  Record<CommandSettingKey, unknown> & {\n    _versionOptionName?: string;\n  };\n\nconst getOrThrow = <Key, Value>(map: Map<Key, Value>, key: Key): Value => {\n  const value = map.get(key);\n  if (value === undefined) {\n    throw new Error(\"Expected map value to be present\");\n  }\n\n  return value;\n};\n\nexport const findMissingOptions = (\n  command: Command,\n  providedOptionsByCommand: Map<Command, OptionValues>,\n) => {\n  const missingOptionsByCommand = new Map<Command, Set<string>>();\n\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 optionName = option.negate\n        ? option.long?.replace(/^--no-/, \"\")\n        : (option.long ?? option.short);\n      if (!optionName) {\n        continue;\n      }\n\n      const key = camelCase(optionName);\n\n      if (providedOptions?.[key] !== undefined) {\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   * A map of commands to a map of option keys to the source of the option value\n   */\n  providedOptionsSources: Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >;\n};\n\nconst copyCommandSettings = (source: Command, target: Command) => {\n  const sourcePrivateState = source as CommandPrivateState;\n  const targetPrivateState = target as CommandPrivateState;\n\n  for (const key of commandSettingKeys) {\n    targetPrivateState[key] = sourcePrivateState[key];\n  }\n\n  target.name(source.name());\n  target.aliases(source.aliases());\n  for (const argument of source.registeredArguments) {\n    target.addArgument(argument);\n  }\n\n  const version = source.version();\n  if (version) {\n    target.version(\n      version,\n      source.options.find(\n        (option) =>\n          option.attributeName() === sourcePrivateState._versionOptionName,\n      )?.flags,\n    );\n  }\n};\n\nconst disableCommandOutput = (command: Command) => {\n  command.configureOutput({\n    writeOut: noop,\n    writeErr: noop,\n    outputError: noop,\n  });\n};\n\nconst cloneOption = (option: Option) => {\n  const newOption = new Option(option.flags, option.description);\n  newOption.makeOptionMandatory(false);\n  newOption.default(option.defaultValue, option.defaultValueDescription);\n\n  newOption.preset((option as Option & { presetArg: unknown }).presetArg);\n  newOption.env((option as Option & { envVar: string }).envVar);\n  if (option.parseArg) {\n    newOption.argParser(option.parseArg);\n  }\n\n  if (option.argChoices) {\n    newOption.choices(option.argChoices);\n  }\n\n  newOption.conflicts(\n    (option as Option & { conflictsWith: string[] }).conflictsWith,\n  );\n\n  (newOption as Option & { implied: unknown }).implied = (\n    option as Option & { implied: unknown }\n  ).implied;\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 providedOptionsSources = new Map<\n    Command,\n    Map<string, OptionValueSource | undefined>\n  >();\n  const commandsMap = new Map<Command, Command>();\n  let matchedCommand: Command | undefined;\n\n  const setProvidedOptionSource = (\n    command: Command,\n    optionKey: string,\n    source: OptionValueSource | undefined,\n  ) => {\n    if (!source) {\n      return;\n    }\n\n    const sourcesMap =\n      providedOptionsSources.get(command) ??\n      new Map<string, OptionValueSource>();\n    sourcesMap.set(optionKey, source);\n    providedOptionsSources.set(command, sourcesMap);\n  };\n\n  const createParserCommand = (parserCommand: Command, command: Command) => {\n    commandsMap.set(parserCommand, command);\n\n    copyCommandSettings(command, parserCommand);\n    disableCommandOutput(parserCommand);\n    parserCommand.exitOverride();\n\n    for (const option of command.options) {\n      // Skip adding the option if it's already registered\n      if (\n        parserCommand.options.some(\n          (parserCommandOption) => parserCommandOption.flags === option.flags,\n        )\n      ) {\n        continue;\n      }\n\n      parserCommand.addOption(cloneOption(option));\n    }\n\n    parserCommand.hook(\"preSubcommand\", (thisCommand, actionCommand) => {\n      for (const cmd of [thisCommand, actionCommand]) {\n        const originalCommand = getOrThrow(commandsMap, cmd);\n        providedOptions.set(originalCommand, cmd.opts());\n\n        for (const optionKey of Object.keys(cmd.opts())) {\n          setProvidedOptionSource(\n            originalCommand,\n            optionKey,\n            cmd.getOptionValueSource(optionKey),\n          );\n        }\n      }\n    });\n\n    parserCommand.action(() => {\n      const originalCommand = getOrThrow(commandsMap, parserCommand);\n      providedOptions.set(originalCommand, parserCommand.opts());\n\n      for (const optionKey of Object.keys(parserCommand.opts())) {\n        setProvidedOptionSource(\n          originalCommand,\n          optionKey,\n          parserCommand.getOptionValueSource(optionKey),\n        );\n      }\n\n      matchedCommand = command;\n    });\n\n    for (const subcommand of command.commands as Command[]) {\n      const parserSubcommand = parserCommand.command(subcommand.name());\n      createParserCommand(parserSubcommand, subcommand);\n    }\n\n    return parserCommand;\n  };\n\n  const parserCommand = createParserCommand(new Command(), command);\n  parserCommand.parse(argv, options);\n\n  const missingOptions = matchedCommand\n    ? findMissingOptions(matchedCommand, providedOptions)\n    : new Map<Command, Set<string>>();\n\n  return {\n    matchedCommand,\n    missingOptions,\n    providedOptions,\n    providedOptionsSources,\n  };\n};\n",
    "export const noop = () => {};\n"
  ],
  "mappings": "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",
  "debugId": "0F2D30EA8353D1EC64756E2164756E21",
  "names": []
}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "parse-my-command",
3
- "version": "0.4.0",
3
+ "version": "0.5.1",
4
4
  "description": "Parse argv with Commander.js without executing the command",
5
5
  "keywords": [
6
6
  "parser",
@@ -40,43 +40,31 @@
40
40
  "dist/index.js"
41
41
  ],
42
42
  "scripts": {
43
- "fix": "prettier --write . && eslint --ext .js --ext .cjs --ext .mjs --ext .ts --ext .cts --ext .mts --ext .d.ts --fix .",
44
- "lint": "prettier --check . && eslint --ext .js --ext .cjs --ext .mjs --ext .ts --ext .cts --ext .mts --ext .d.ts .",
45
- "prepare": "tsup ./src/index.ts --format esm,cjs --dts --clean --sourcemap inline --silent",
46
- "pretest": "tsc",
47
- "test": "glob -c \"tsx --test --test-reporter spec\" \"test/**/*.test.ts\"",
48
- "posttest": "npm run lint",
49
- "test:coverage": "c8 npm run test"
50
- },
51
- "c8": {
52
- "reporter": [
53
- "lcov"
54
- ]
43
+ "build": "bun run clean && bun run build:esm && bun run build:cjs && bun run build:types",
44
+ "build:cjs": "bun build ./src/index.ts --format cjs --target node --packages external --outdir ./dist --entry-naming index.cjs --sourcemap=inline",
45
+ "build:esm": "bun build ./src/index.ts --format esm --target node --packages external --outdir ./dist --entry-naming index.js --sourcemap=inline",
46
+ "build:types": "tsc -p tsconfig.build.json && cp ./dist/index.d.ts ./dist/index.d.cts",
47
+ "clean": "rm -rf coverage dist",
48
+ "fix": "bunx biome check --write .",
49
+ "lint": "bunx biome check .",
50
+ "prepack": "bun run build",
51
+ "test": "bun run typecheck && bun run test:unit && bun run lint",
52
+ "test:coverage": "bun run typecheck && bun test --coverage --coverage-reporter=lcov",
53
+ "test:unit": "bun test",
54
+ "typecheck": "tsc -p tsconfig.json",
55
+ "update:deps": "bun update --latest && bun run fix"
55
56
  },
56
57
  "dependencies": {
57
- "camelcase": "^8.0.0",
58
- "commander": "^13.1.0"
58
+ "camelcase": "^9.0.0",
59
+ "commander": "^14.0.3"
59
60
  },
60
61
  "devDependencies": {
61
- "@trivago/prettier-plugin-sort-imports": "^4.3.0",
62
- "@types/node": "^20.12.4",
63
- "@typescript-eslint/eslint-plugin": "^7.5.0",
64
- "@typescript-eslint/parser": "^7.5.0",
65
- "c8": "^9.1.0",
66
- "eslint": "^8.57.0",
67
- "eslint-config-prettier": "^9.1.0",
68
- "eslint-config-xo": "^0.44.0",
69
- "eslint-config-xo-typescript": "^4.0.0",
70
- "eslint-plugin-unicorn": "^52.0.0",
71
- "glob": "^10.3.12",
72
- "npm-check-updates": "^16.14.18",
73
- "prettier": "^3.2.5",
74
- "prettier-plugin-packagejson": "^2.4.14",
75
- "tsup": "^8.0.2",
76
- "tsx": "^4.7.2",
77
- "typescript": "^5.4.4"
62
+ "@biomejs/biome": "^2.4.9",
63
+ "@types/bun": "^1.3.11",
64
+ "typescript": "^6.0.2"
78
65
  },
66
+ "packageManager": "bun@1.3.10",
79
67
  "engines": {
80
- "node": ">=18"
68
+ "node": ">=20"
81
69
  }
82
70
  }