mirror of
https://github.com/nushell/nushell.git
synced 2025-08-09 08:06:03 +02:00
Fix incorrect handling of boolean flags for builtin commands (#11492)
# Description
Possible fix of #11456
This PR fixes a bug where builtin commands did not respect the logic of
dynamically passed boolean flags. The reason is
[has_flag](6f59abaf43/crates/nu-protocol/src/ast/call.rs (L204C5-L212C6)
)
method did not evaluate and take into consideration expression used with
flag.
To address this issue a solution is proposed:
1. `has_flag` method is moved to `CallExt` and new logic to evaluate
expression and check if it is a boolean value is added
2. `has_flag_const` method is added to `CallExt` which is a constant
version of `has_flag`
3. `has_named` method is added to `Call` which is basically the old
logic of `has_flag`
4. All usages of `has_flag` in code are updated, mostly to pass
`engine_state` and `stack` to new `has_flag`. In `run_const` commands it
is replaced with `has_flag_const`. And in a few select places: parser,
`to nuon` and `into string` old logic via `has_named` is used.
# User-Facing Changes
Explicit values of boolean flags are now respected in builtin commands.
Before:

After:

Another example:
Before:

After:

# Tests + Formatting
Added test reproducing some variants of original issue.
This commit is contained in:
@ -108,7 +108,7 @@ pub(crate) fn parse_commandline_args(
|
||||
call.get_flag(engine_state, &mut stack, "table-mode")?;
|
||||
|
||||
// ide flags
|
||||
let lsp = call.has_flag("lsp");
|
||||
let lsp = call.has_flag(engine_state, &mut stack, "lsp")?;
|
||||
let include_path = call.get_flag_expr("include-path");
|
||||
let ide_goto_def: Option<Value> =
|
||||
call.get_flag(engine_state, &mut stack, "ide-goto-def")?;
|
||||
@ -150,7 +150,7 @@ pub(crate) fn parse_commandline_args(
|
||||
let execute = extract_contents(execute)?;
|
||||
let include_path = extract_contents(include_path)?;
|
||||
|
||||
let help = call.has_flag("help");
|
||||
let help = call.has_flag(engine_state, &mut stack, "help")?;
|
||||
|
||||
if help {
|
||||
let full_help = get_full_help(
|
||||
@ -166,7 +166,7 @@ pub(crate) fn parse_commandline_args(
|
||||
std::process::exit(0);
|
||||
}
|
||||
|
||||
if call.has_flag("version") {
|
||||
if call.has_flag(engine_state, &mut stack, "version")? {
|
||||
let version = env!("CARGO_PKG_VERSION").to_string();
|
||||
let _ = std::panic::catch_unwind(move || {
|
||||
stdout_write_all_and_flush(format!("{version}\n"))
|
||||
|
Reference in New Issue
Block a user