-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Option to disable runtime-validation in debug release? #4405
Comments
Could you expand on why parsing the default twice in debug builds is a problem?
One way of doing this is feature flags but they have problems and should be limited in when we use them. We do have The original issue is #3202 and PR is #3423. The big problem we are trying to address is that users can only catch some invalid cases by exhaustive testing of their CLI. Doing this in debug asserts lets users detect this sooner. |
So we are currently using I guess our setup isn't really using clap APIs "correctly". The X problem here is that there isn't an API to supply a function to calculate the default value without implementing
I understand the motivation of having this validation and I agree that having clap to validate it before it making to production is very helpful. I'm wondering if we can do the validation separately if we were to have an option disabling this runtime check. |
If there isn't a default value to show in help, why give the default to clap instead of making the value optional and calculating it after parsing? btw we are looking at generalizing how defaulting works. We've started brainstorming it at #3476 |
As the original request is about providing clap with a sentinel default value that could just as well be handled by not providing a default, I'm inclined to close this. As listed above, we also are looking at allowing defaults to be handled in a different way. If people have input on that, see #3476. |
Please complete the following tasks
Rust Version
rust playground 1.64.0
Clap Version
4.0.6
Minimal reproducible code
https://play.rust-lang.org/?version=stable&mode=debug&edition=2021&gist=42894c861ebd752bb5d6f8624cdb88ca
Steps to reproduce the bug with the above code
Click Run button in playground.
Actual Behaviour
got input
got called twice, once with the default empty string and once with supplied string.Expected Behaviour
When the user supplies any value, the default value should not be used and parsed.
It looks like this happens in debug mode for validating supplied default values. Specifically this call here:
clap/src/builder/command.rs
Lines 3905 to 3906 in 6328c14
Would it be possible to consider at least making this configurable? We run tests in both debug and release mode and this discrepancy is hard to work around. I can either write code in my parse function to cheat in debug mode (which is kinda awkward) or to avoid using
default_value
entirely. :(Additional Context
No response
Debug Output
No response
The text was updated successfully, but these errors were encountered: