Start env shorthand

This commit is contained in:
JT 2021-07-31 17:20:40 +12:00
parent b82a4869d5
commit cb11f042ab
3 changed files with 29 additions and 3 deletions

View File

@ -192,7 +192,7 @@ fn main() -> std::io::Result<()> {
); );
if let Some(err) = err { if let Some(err) = err {
eprintln!("Parse Error: {:?}", err); eprintln!("Parse Error: {:?}", err);
break; continue;
} }
(output, working_set.render()) (output, working_set.render())
}; };

View File

@ -783,11 +783,32 @@ impl<'a> ParserWorkingSet<'a> {
pub fn parse_call(&mut self, spans: &[Span]) -> (Expression, Option<ParseError>) { pub fn parse_call(&mut self, spans: &[Span]) -> (Expression, Option<ParseError>) {
// assume spans.len() > 0? // assume spans.len() > 0?
let name = self.get_span_contents(spans[0]); let mut pos = 0;
let mut shorthand = vec![];
while pos < spans.len() {
// First, check if there is any environment shorthand
let name = self.get_span_contents(spans[pos]);
let split: Vec<_> = name.splitn(2, |x| *x == b'=').collect();
if split.len() == 2 {
shorthand.push(split);
pos += 1;
} else {
break;
}
}
if pos == spans.len() {
return (
Expression::garbage(span(spans)),
Some(ParseError::UnknownCommand(spans[0])),
);
}
let name = self.get_span_contents(spans[pos]);
pos += 1;
if let Some(mut decl_id) = self.find_decl(name) { if let Some(mut decl_id) = self.find_decl(name) {
let mut name = name.to_vec(); let mut name = name.to_vec();
let mut pos = 1;
while pos < spans.len() { while pos < spans.len() {
// look to see if it's a subcommand // look to see if it's a subcommand
let mut new_name = name.to_vec(); let mut new_name = name.to_vec();

View File

@ -123,3 +123,8 @@ fn predecl_check() -> TestResult {
fn def_with_no_dollar() -> TestResult { fn def_with_no_dollar() -> TestResult {
run_test("def bob [x] { $x + 3 }; bob 4", "7") run_test("def bob [x] { $x + 3 }; bob 4", "7")
} }
#[test]
fn env_shorthand() -> TestResult {
run_test("FOO=BAR if $false { 3 } else { 4 }", "4")
}