mirror of
https://github.com/nushell/nushell
synced 2025-01-27 20:35:43 +00:00
Fix $in
in range expressions (#13447)
# Description Fixes #13441. I must have forgotten that `Expr::Range` can contain other expressions, so I wasn't searching for `$in` to replace within it. Easy fix. # User-Facing Changes Bug fix, ranges like `6 | 3..$in` work as expected now. # Tests + Formatting Added regression test.
This commit is contained in:
parent
9f90d611e1
commit
6446f26283
2 changed files with 21 additions and 1 deletions
|
@ -432,7 +432,17 @@ impl Expression {
|
|||
Expr::Int(_) => {}
|
||||
Expr::Float(_) => {}
|
||||
Expr::Binary(_) => {}
|
||||
Expr::Range(_) => {}
|
||||
Expr::Range(range) => {
|
||||
if let Some(from) = &mut range.from {
|
||||
from.replace_in_variable(working_set, new_var_id);
|
||||
}
|
||||
if let Some(next) = &mut range.next {
|
||||
next.replace_in_variable(working_set, new_var_id);
|
||||
}
|
||||
if let Some(to) = &mut range.to {
|
||||
to.replace_in_variable(working_set, new_var_id);
|
||||
}
|
||||
}
|
||||
Expr::Var(var_id) | Expr::VarDecl(var_id) => {
|
||||
if *var_id == IN_VARIABLE_ID {
|
||||
*var_id = new_var_id;
|
||||
|
|
|
@ -75,6 +75,16 @@ fn in_used_twice_and_also_in_pipeline() -> TestResult {
|
|||
)
|
||||
}
|
||||
|
||||
// #13441
|
||||
#[test]
|
||||
fn in_used_in_range_from() -> TestResult {
|
||||
run_test(r#"6 | $in..10 | math sum"#, "40")
|
||||
}
|
||||
#[test]
|
||||
fn in_used_in_range_to() -> TestResult {
|
||||
run_test(r#"6 | 3..$in | math sum"#, "18")
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn help_works_with_missing_requirements() -> TestResult {
|
||||
run_test(r#"each --help | lines | length"#, "72")
|
||||
|
|
Loading…
Reference in a new issue