mirror of
https://github.com/nushell/nushell.git
synced 2025-01-25 15:51:28 +01:00
Fix rest parsing (#4765)
* More nuon tests, fix table print * Fix rest type parsing
This commit is contained in:
parent
0b6b321ad6
commit
a2723c2ba4
@ -2749,6 +2749,7 @@ pub fn parse_signature_helper(
|
|||||||
|
|
||||||
enum Arg {
|
enum Arg {
|
||||||
Positional(PositionalArg, bool), // bool - required
|
Positional(PositionalArg, bool), // bool - required
|
||||||
|
RestPositional(PositionalArg),
|
||||||
Flag(Flag),
|
Flag(Flag),
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2759,7 +2760,6 @@ pub fn parse_signature_helper(
|
|||||||
error = error.or(err);
|
error = error.or(err);
|
||||||
|
|
||||||
let mut args: Vec<Arg> = vec![];
|
let mut args: Vec<Arg> = vec![];
|
||||||
let mut rest_arg = None;
|
|
||||||
let mut parse_mode = ParseMode::ArgMode;
|
let mut parse_mode = ParseMode::ArgMode;
|
||||||
|
|
||||||
for token in &output {
|
for token in &output {
|
||||||
@ -2930,19 +2930,12 @@ pub fn parse_signature_helper(
|
|||||||
|
|
||||||
let var_id = working_set.add_variable(contents_vec, Type::Unknown);
|
let var_id = working_set.add_variable(contents_vec, Type::Unknown);
|
||||||
|
|
||||||
if rest_arg.is_none() {
|
args.push(Arg::RestPositional(PositionalArg {
|
||||||
rest_arg = Some(Arg::Positional(
|
|
||||||
PositionalArg {
|
|
||||||
desc: String::new(),
|
desc: String::new(),
|
||||||
name,
|
name,
|
||||||
shape: SyntaxShape::Any,
|
shape: SyntaxShape::Any,
|
||||||
var_id: Some(var_id),
|
var_id: Some(var_id),
|
||||||
},
|
}));
|
||||||
false,
|
|
||||||
));
|
|
||||||
} else {
|
|
||||||
error = error.or(Some(ParseError::MultipleRestParams(span)))
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
let name = String::from_utf8_lossy(contents).to_string();
|
let name = String::from_utf8_lossy(contents).to_string();
|
||||||
let contents_vec = contents.to_vec();
|
let contents_vec = contents.to_vec();
|
||||||
@ -2972,6 +2965,12 @@ pub fn parse_signature_helper(
|
|||||||
working_set.set_variable_type(var_id.expect("internal error: all custom parameters must have var_ids"), syntax_shape.to_type());
|
working_set.set_variable_type(var_id.expect("internal error: all custom parameters must have var_ids"), syntax_shape.to_type());
|
||||||
*shape = syntax_shape;
|
*shape = syntax_shape;
|
||||||
}
|
}
|
||||||
|
Arg::RestPositional(PositionalArg {
|
||||||
|
shape, var_id, ..
|
||||||
|
}) => {
|
||||||
|
working_set.set_variable_type(var_id.expect("internal error: all custom parameters must have var_ids"), syntax_shape.to_type());
|
||||||
|
*shape = syntax_shape;
|
||||||
|
}
|
||||||
Arg::Flag(Flag { arg, var_id, .. }) => {
|
Arg::Flag(Flag { arg, var_id, .. }) => {
|
||||||
// Flags with a boolean type are just present/not-present switches
|
// Flags with a boolean type are just present/not-present switches
|
||||||
if syntax_shape != SyntaxShape::Boolean {
|
if syntax_shape != SyntaxShape::Boolean {
|
||||||
@ -3012,6 +3011,12 @@ pub fn parse_signature_helper(
|
|||||||
}
|
}
|
||||||
positional.desc.push_str(&contents);
|
positional.desc.push_str(&contents);
|
||||||
}
|
}
|
||||||
|
Arg::RestPositional(positional) => {
|
||||||
|
if !positional.desc.is_empty() {
|
||||||
|
positional.desc.push('\n');
|
||||||
|
}
|
||||||
|
positional.desc.push_str(&contents);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3021,7 +3026,17 @@ pub fn parse_signature_helper(
|
|||||||
|
|
||||||
let mut sig = Signature::new(String::new());
|
let mut sig = Signature::new(String::new());
|
||||||
|
|
||||||
if let Some(Arg::Positional(positional, ..)) = rest_arg {
|
for arg in args {
|
||||||
|
match arg {
|
||||||
|
Arg::Positional(positional, required) => {
|
||||||
|
if required {
|
||||||
|
sig.required_positional.push(positional)
|
||||||
|
} else {
|
||||||
|
sig.optional_positional.push(positional)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Arg::Flag(flag) => sig.named.push(flag),
|
||||||
|
Arg::RestPositional(positional) => {
|
||||||
if positional.name.is_empty() {
|
if positional.name.is_empty() {
|
||||||
error = error.or(Some(ParseError::RestNeedsName(span)))
|
error = error.or(Some(ParseError::RestNeedsName(span)))
|
||||||
} else if sig.rest_positional.is_none() {
|
} else if sig.rest_positional.is_none() {
|
||||||
@ -3034,16 +3049,6 @@ pub fn parse_signature_helper(
|
|||||||
error = error.or(Some(ParseError::MultipleRestParams(span)))
|
error = error.or(Some(ParseError::MultipleRestParams(span)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for arg in args {
|
|
||||||
match arg {
|
|
||||||
Arg::Positional(positional, required) => {
|
|
||||||
if required {
|
|
||||||
sig.required_positional.push(positional)
|
|
||||||
} else {
|
|
||||||
sig.optional_positional.push(positional)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Arg::Flag(flag) => sig.named.push(flag),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -339,3 +339,13 @@ fn string_escape() -> TestResult {
|
|||||||
fn string_escape_interpolation() -> TestResult {
|
fn string_escape_interpolation() -> TestResult {
|
||||||
run_test(r#"$"\u015B(char hamburger)abc""#, "ś≡abc")
|
run_test(r#"$"\u015B(char hamburger)abc""#, "ś≡abc")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn proper_rest_types() -> TestResult {
|
||||||
|
run_test(
|
||||||
|
r#"def foo [--verbose(-v): bool, # my test flag
|
||||||
|
...rest: int # my rest comment
|
||||||
|
] { if $verbose { print "verbose!" } else { print "not verbose!" } }; foo"#,
|
||||||
|
"not verbose!",
|
||||||
|
)
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user