mirror of
https://github.com/nushell/nushell.git
synced 2025-05-08 20:14:26 +02:00
feat(where): Support closures stored in variables
This commit is contained in:
parent
520f11fb8f
commit
a70867ed34
@ -35,7 +35,10 @@ not supported."#
|
|||||||
])
|
])
|
||||||
.required(
|
.required(
|
||||||
"row_condition",
|
"row_condition",
|
||||||
SyntaxShape::RowCondition,
|
SyntaxShape::OneOf(vec![
|
||||||
|
SyntaxShape::RowCondition,
|
||||||
|
SyntaxShape::Closure(Some(vec![SyntaxShape::Any])),
|
||||||
|
]),
|
||||||
"Filter condition.",
|
"Filter condition.",
|
||||||
)
|
)
|
||||||
.allow_variants_without_examples(true)
|
.allow_variants_without_examples(true)
|
||||||
@ -125,9 +128,24 @@ not supported."#
|
|||||||
description: "same as above but with regex only",
|
description: "same as above but with regex only",
|
||||||
example: "ls | where name =~ '(?i)readme'",
|
example: "ls | where name =~ '(?i)readme'",
|
||||||
result: None,
|
result: None,
|
||||||
}
|
},
|
||||||
|
Example {
|
||||||
|
description: "Filter rows of a table according to a stored condition",
|
||||||
|
example: "let cond = {|x| $x.a > 1}; [{a: 1} {a: 2}] | where $cond",
|
||||||
|
result: Some(Value::test_list(vec![Value::test_record(record! {
|
||||||
|
"a" => Value::test_int(2),
|
||||||
|
})])),
|
||||||
|
},
|
||||||
|
Example {
|
||||||
|
description: "List all numbers above 3, using an existing closure condition",
|
||||||
|
example: "let a = {$in > 3}; [1, 2, 5, 6] | where $a",
|
||||||
|
result: Some(Value::test_list(
|
||||||
|
vec![
|
||||||
|
Value::test_int(5),
|
||||||
|
Value::test_int(6)
|
||||||
|
],
|
||||||
|
)),
|
||||||
|
},
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -209,3 +209,16 @@ fn has_operator() {
|
|||||||
let actual = nu!(r#"{foo: 1} has bar "#);
|
let actual = nu!(r#"{foo: 1} has bar "#);
|
||||||
assert_eq!(actual.out, "false");
|
assert_eq!(actual.out, "false");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn stored_condition() {
|
||||||
|
let actual = nu!(r#"let cond = { $in mod 2 == 0 }; 1..10 | where $cond | to nuon"#);
|
||||||
|
assert_eq!(actual.out, r#"[2, 4, 6, 8, 10]"#)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn nested_stored_condition() {
|
||||||
|
let actual =
|
||||||
|
nu!(r#"let nested = {cond: { $in mod 2 == 0 }}; 1..10 | where $nested.cond | to nuon"#);
|
||||||
|
assert_eq!(actual.out, r#"[2, 4, 6, 8, 10]"#)
|
||||||
|
}
|
||||||
|
@ -3613,6 +3613,16 @@ pub fn parse_row_condition(working_set: &mut StateWorkingSet, spans: &[Span]) ->
|
|||||||
let block_id = match expression.expr {
|
let block_id = match expression.expr {
|
||||||
Expr::Block(block_id) => block_id,
|
Expr::Block(block_id) => block_id,
|
||||||
Expr::Closure(block_id) => block_id,
|
Expr::Closure(block_id) => block_id,
|
||||||
|
Expr::FullCellPath(ref box_fcp) if box_fcp.head.as_var() != Some(var_id) => {
|
||||||
|
let mut expression = expression;
|
||||||
|
expression.ty = Type::Any;
|
||||||
|
return expression;
|
||||||
|
}
|
||||||
|
Expr::Var(arg_var_id) if arg_var_id != var_id => {
|
||||||
|
let mut expression = expression;
|
||||||
|
expression.ty = Type::Any;
|
||||||
|
return expression;
|
||||||
|
}
|
||||||
_ => {
|
_ => {
|
||||||
// We have an expression, so let's convert this into a block.
|
// We have an expression, so let's convert this into a block.
|
||||||
let mut block = Block::new();
|
let mut block = Block::new();
|
||||||
|
Loading…
Reference in New Issue
Block a user