Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug] Wrong types for defaultValue #2236

Closed
Sadzurami opened this issue Aug 21, 2024 · 3 comments
Closed

[Bug] Wrong types for defaultValue #2236

Sadzurami opened this issue Aug 21, 2024 · 3 comments

Comments

@Sadzurami
Copy link

Example:

import { program } from 'commander';
program.option('-n, --num', 'test num value', 10)

Result:

No overload matches this call.
  Overload 1 of 3, '(flags: string, description?: string, defaultValue?: string | boolean | string[]): Command', gave the following error.
    Argument of type '10' is not assignable to parameter of type 'string | boolean | string[]'.
  Overload 2 of 3, '(flags: string, description: string, parseArg: (value: string, previous: unknown) => unknown, defaultValue?: unknown): Command', gave the following error.
    Argument of type 'number' is not assignable to parameter of type '(value: string, previous: unknown) => unknown'.
  Overload 3 of 3, '(flags: string, description: string, regexp: RegExp, defaultValue?: string | boolean | string[]): Command', gave the following error.
    Argument of type 'number' is not assignable to parameter of type 'RegExp'.
@shadowspawn
Copy link
Collaborator

shadowspawn commented Aug 21, 2024

The TypeScript types are deliberately stricter than the JavaScript implementation to help guide users to safer patterns by default. In this case if this was silently allowed, you would have your option value being a number if it came from the default and a string if from the parsed arguments.

See similar closed PR #1792

@shadowspawn
Copy link
Collaborator

The Pull Request that removed multiple uses of any including for the .option() default value: #1119

@shadowspawn
Copy link
Collaborator

In many cases, you can get the type you want and strict types by also specifying a custom option processing function.

If that isn't a match for what you want you can also use the Option class directly and it allows any type in the .default() call:

.addOption(new Option('-n, --num <value>', 'test num value').default(10));

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants