mirror of
https://github.com/nushell/nushell.git
synced 2025-01-22 22:29:10 +01:00
Add support for arbitrarily nested subcommands (#3688)
This commit is contained in:
parent
6cdd8a2b07
commit
b1970f79ee
@ -1841,21 +1841,25 @@ fn parse_call(
|
||||
error = error.or(err);
|
||||
return (Some(ClassifiedCommand::Expr(Box::new(expr))), error);
|
||||
} else if lite_cmd.parts.len() > 1 {
|
||||
// Check if it's a sub-command
|
||||
if let Some(signature) = scope.get_signature(&format!(
|
||||
"{} {}",
|
||||
lite_cmd.parts[0].item, lite_cmd.parts[1].item
|
||||
)) {
|
||||
let (mut internal_command, err) =
|
||||
parse_internal_command(&lite_cmd, scope, &signature, 1);
|
||||
// FIXME: only build up valid subcommands instead of all arguments
|
||||
// by checking each part to see if it's a valid identifier name
|
||||
let mut parts: Vec<_> = lite_cmd.parts.clone().into_iter().map(|x| x.item).collect();
|
||||
|
||||
error = error.or(err);
|
||||
internal_command.args.external_redirection = if end_of_pipeline {
|
||||
ExternalRedirection::None
|
||||
} else {
|
||||
ExternalRedirection::Stdout
|
||||
};
|
||||
return (Some(ClassifiedCommand::Internal(internal_command)), error);
|
||||
while parts.len() > 1 {
|
||||
// Check if it's a sub-command
|
||||
if let Some(signature) = scope.get_signature(&parts.join(" ")) {
|
||||
let (mut internal_command, err) =
|
||||
parse_internal_command(&lite_cmd, scope, &signature, parts.len() - 1);
|
||||
|
||||
error = error.or(err);
|
||||
internal_command.args.external_redirection = if end_of_pipeline {
|
||||
ExternalRedirection::None
|
||||
} else {
|
||||
ExternalRedirection::Stdout
|
||||
};
|
||||
return (Some(ClassifiedCommand::Internal(internal_command)), error);
|
||||
}
|
||||
parts.pop();
|
||||
}
|
||||
}
|
||||
// Check if it's an internal command
|
||||
|
@ -1059,6 +1059,30 @@ fn better_subexpr_lex() {
|
||||
assert_eq!(actual.out, "6");
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn subsubcommand() {
|
||||
let actual = nu!(
|
||||
cwd: ".", pipeline(
|
||||
r#"
|
||||
def "aws s3 rb" [url] { $url + " loaded" }; aws s3 rb localhost
|
||||
"#)
|
||||
);
|
||||
|
||||
assert_eq!(actual.out, "localhost loaded");
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn manysubcommand() {
|
||||
let actual = nu!(
|
||||
cwd: ".", pipeline(
|
||||
r#"
|
||||
def "aws s3 rb ax vf qqqq rrrr" [url] { $url + " loaded" }; aws s3 rb ax vf qqqq rrrr localhost
|
||||
"#)
|
||||
);
|
||||
|
||||
assert_eq!(actual.out, "localhost loaded");
|
||||
}
|
||||
|
||||
mod parse {
|
||||
use nu_test_support::nu;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user