forked from extern/nushell
Improve block params (#3450)
This commit is contained in:
parent
3075e2cfbf
commit
20f6114617
@ -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);
|
||||||
|
@ -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(),
|
||||||
|
@ -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
|
||||||
|
@ -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!(
|
||||||
|
Loading…
Reference in New Issue
Block a user