mirror of
https://github.com/nushell/nushell.git
synced 2025-01-25 23:58:41 +01:00
Add params to do
(#3477)
This commit is contained in:
parent
e335e4fddc
commit
6165b6ae77
@ -2,13 +2,16 @@ use crate::prelude::*;
|
|||||||
use nu_engine::run_block;
|
use nu_engine::run_block;
|
||||||
use nu_engine::WholeStreamCommand;
|
use nu_engine::WholeStreamCommand;
|
||||||
use nu_errors::ShellError;
|
use nu_errors::ShellError;
|
||||||
use nu_protocol::{hir::CapturedBlock, hir::ExternalRedirection, Signature, SyntaxShape, Value};
|
use nu_protocol::{
|
||||||
|
hir::CapturedBlock, hir::ExternalRedirection, Signature, SyntaxShape, UntaggedValue, Value,
|
||||||
|
};
|
||||||
|
|
||||||
pub struct Do;
|
pub struct Do;
|
||||||
|
|
||||||
#[derive(Deserialize, Debug)]
|
#[derive(Deserialize, Debug)]
|
||||||
struct DoArgs {
|
struct DoArgs {
|
||||||
block: CapturedBlock,
|
block: CapturedBlock,
|
||||||
|
rest: Vec<Value>,
|
||||||
ignore_errors: bool,
|
ignore_errors: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -25,6 +28,7 @@ impl WholeStreamCommand for Do {
|
|||||||
"ignore errors as the block runs",
|
"ignore errors as the block runs",
|
||||||
Some('i'),
|
Some('i'),
|
||||||
)
|
)
|
||||||
|
.rest(SyntaxShape::Any, "the parameter(s) for the block")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn usage(&self) -> &str {
|
fn usage(&self) -> &str {
|
||||||
@ -47,6 +51,11 @@ impl WholeStreamCommand for Do {
|
|||||||
example: r#"do -i { thisisnotarealcommand }"#,
|
example: r#"do -i { thisisnotarealcommand }"#,
|
||||||
result: Some(vec![]),
|
result: Some(vec![]),
|
||||||
},
|
},
|
||||||
|
Example {
|
||||||
|
description: "Run the block with a parameter",
|
||||||
|
example: r#"do { |x| $x + 100 } 55"#,
|
||||||
|
result: Some(vec![UntaggedValue::int(155).into()]),
|
||||||
|
},
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -58,6 +67,7 @@ fn do_(raw_args: CommandArgs) -> Result<ActionStream, ShellError> {
|
|||||||
let (
|
let (
|
||||||
DoArgs {
|
DoArgs {
|
||||||
ignore_errors,
|
ignore_errors,
|
||||||
|
rest,
|
||||||
block,
|
block,
|
||||||
},
|
},
|
||||||
input,
|
input,
|
||||||
@ -82,6 +92,13 @@ fn do_(raw_args: CommandArgs) -> Result<ActionStream, ShellError> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
context.scope.enter_scope();
|
context.scope.enter_scope();
|
||||||
|
|
||||||
|
context.scope.add_vars(&block.captured.entries);
|
||||||
|
|
||||||
|
for (param, value) in block.block.params.positional.iter().zip(rest) {
|
||||||
|
context.scope.add_var(param.0.name(), value.clone());
|
||||||
|
}
|
||||||
|
|
||||||
let result = run_block(&block.block, &context, input, block_redirection);
|
let result = run_block(&block.block, &context, input, block_redirection);
|
||||||
context.scope.exit_scope();
|
context.scope.exit_scope();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user