- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 794
✨ Add support for optional values of CLI Options #1063
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
base: master
Are you sure you want to change the base?
Conversation
| 📝 Docs preview for commit e8b83d6 at: https://791524f2.typertiangolo.pages.dev Modified Pages | 
| 📝 Docs preview for commit 8bb363d at: https://d878ac4e.typertiangolo.pages.dev Modified Pages | 
| 📝 Docs preview for commit b9fbaf9 at: https://1f8f8cb4.typertiangolo.pages.dev Modified Pages | 
b9fbaf9    to
    9e7afc3      
    Compare
  
    | 📝 Docs preview for commit 9e7afc3 at: https://85fa57a2.typertiangolo.pages.dev Modified Pages | 
| 📝 Docs preview for commit 9116d7f at: https://c57e1705.typertiangolo.pages.dev Modified Pages | 
9116d7f    to
    37b74b4      
    Compare
  
    | 📝 Docs preview for commit 37b74b4 at: https://24fe9493.typertiangolo.pages.dev Modified Pages | 
| This pull request has a merge conflict that needs to be resolved. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@MatteoBouvier, thanks for your interest and efforts!
I think this feature looks unintuitive in such implementation:
- BOOLEAN|TEXT [default: False (en)]in docs looks confusing..
- behavior is different from how it works in Click: in Click the default value is used if option is not used and flag_valueis used if option is used without value
Anyway, I would wait for Sebastian to approve the idea of feature request first
Click allows to make cli option values optional, using a default value when not provided (https://click.palletsprojects.com/en/stable/options/#optional-value).
This feature is not currently supported by Typer but there is interest from people (including myself) : cf #873, #608.
My use case was creating a
--docoption for displaying a detailed documentation of a command, in english by default but in another language if passing a language name such as--doc fr.To stick to the type annotation philosophy of Typer, this PR defines Options with optional values (with type T) by annotating them as
bool | T:--doc, the doc parameter gets a value ofFalse--doc <value>as usual, the doc parameter gets the value--docwith no value, the doc parameter gets the default value"en"The
helpmessage for the Options is rendered as:note : This PR does not implement type unions for Options, only
bool | Tis parsed