Improve block params (#3450)

This commit is contained in:
JT 2021-05-20 16:26:54 +12:00 committed by GitHub
parent 3075e2cfbf
commit 20f6114617
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 48 additions and 18 deletions

View File

@ -89,7 +89,13 @@ pub fn process_row(
context.scope.add_vars(&captured_block.captured.entries); context.scope.add_vars(&captured_block.captured.entries);
if !captured_block.block.params.positional.is_empty() { if !captured_block.block.params.positional.is_empty() {
// FIXME: add check for more than parameter, once that's supported if captured_block.block.params.positional.len() > 1 {
return Err(ShellError::labeled_error(
"Expected block with less than two parameters",
"too many parameters",
captured_block.block.span,
));
}
context context
.scope .scope
.add_var(captured_block.block.params.positional[0].0.name(), input); .add_var(captured_block.block.params.positional[0].0.name(), input);

View File

@ -253,15 +253,6 @@ fn evaluate_reference(
tag: span.into(), tag: span.into(),
}), }),
"$it" => match ctx.scope.get_var("$it") {
Some(v) => Ok(v),
None => Err(ShellError::labeled_error(
"Variable not in scope",
"missing '$it' (note: $it is only available inside of a block)",
span,
)),
},
"$nothing" => Ok(Value { "$nothing" => Ok(Value {
value: UntaggedValue::nothing(), value: UntaggedValue::nothing(),
tag: span.into(), tag: span.into(),

View File

@ -972,6 +972,15 @@ fn parse_arg(
} }
tokens = token_iter.collect(); tokens = token_iter.collect();
if tokens.is_empty() {
return (
garbage(lite_arg.span),
Some(ParseError::mismatch(
"block with parameters",
lite_arg.clone(),
)),
);
}
params params
} else { } else {
vec![] vec![]
@ -986,8 +995,10 @@ fn parse_arg(
let (mut classified_block, err) = classify_block(&lite_block, scope); let (mut classified_block, err) = classify_block(&lite_block, scope);
scope.exit_scope(); scope.exit_scope();
if !params.is_empty() && classified_block.params.positional.is_empty() { if let Some(classified_block) = Arc::get_mut(&mut classified_block) {
if let Some(classified_block) = Arc::get_mut(&mut classified_block) { classified_block.span = lite_arg.span;
if !params.is_empty() {
classified_block.params.positional.clear();
for param in params { for param in params {
classified_block classified_block
.params .params

View File

@ -295,7 +295,7 @@ fn run_custom_command_with_empty_rest() {
} }
#[test] #[test]
fn set_variable() { fn let_variable() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -309,7 +309,7 @@ fn set_variable() {
} }
#[test] #[test]
fn set_doesnt_leak() { fn let_doesnt_leak() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -321,7 +321,7 @@ fn set_doesnt_leak() {
} }
#[test] #[test]
fn set_env_variable() { fn let_env_variable() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -334,7 +334,7 @@ fn set_env_variable() {
} }
#[test] #[test]
fn set_env_doesnt_leak() { fn let_env_doesnt_leak() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -346,7 +346,7 @@ fn set_env_doesnt_leak() {
} }
#[test] #[test]
fn proper_shadow_set_env_aliases() { fn proper_shadow_let_env_aliases() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -357,7 +357,7 @@ fn proper_shadow_set_env_aliases() {
} }
#[test] #[test]
fn proper_shadow_set_aliases() { fn proper_shadow_let_aliases() {
let actual = nu!( let actual = nu!(
cwd: ".", cwd: ".",
r#" r#"
@ -367,6 +367,28 @@ fn proper_shadow_set_aliases() {
assert_eq!(actual.out, "falsetruefalse"); assert_eq!(actual.out, "falsetruefalse");
} }
#[test]
fn block_param_too_many() {
let actual = nu!(
cwd: ".",
r#"
[1, 2, 3] | each { |a, b| echo $a }
"#
);
assert!(actual.err.contains("too many"));
}
#[test]
fn block_params_override() {
let actual = nu!(
cwd: ".",
r#"
[1, 2, 3] | each { |a| echo $it }
"#
);
assert!(actual.err.contains("unknown variable"));
}
#[test] #[test]
fn run_dynamic_blocks() { fn run_dynamic_blocks() {
let actual = nu!( let actual = nu!(