From 60212611e504178dd5ca8eee34f60c89166902f3 Mon Sep 17 00:00:00 2001 From: George Pollard Date: Thu, 5 Sep 2019 04:13:07 +1200 Subject: [PATCH] Allow leading space before head of pipeline --- src/parser/parse/parser.rs | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/src/parser/parse/parser.rs b/src/parser/parse/parser.rs index 8e4d995a2d..f230c36c22 100644 --- a/src/parser/parse/parser.rs +++ b/src/parser/parse/parser.rs @@ -552,7 +552,7 @@ pub fn node(input: NomSpan) -> IResult { pub fn pipeline(input: NomSpan) -> IResult { trace_step(input, "pipeline", |input| { let start = input.offset; - let (input, head) = opt(tuple((raw_call, opt(space1))))(input)?; + let (input, head) = opt(tuple((opt(space1), raw_call, opt(space1))))(input)?; let (input, items) = trace_step( input, "many0", @@ -582,7 +582,11 @@ pub fn pipeline(input: NomSpan) -> IResult { } fn make_call_list( - head: Option<(Tagged, Option)>, + head: Option<( + Option, + Tagged, + Option + )>, items: Vec<( NomSpan, Option, @@ -593,7 +597,12 @@ fn make_call_list( let mut out = vec![]; if let Some(head) = head { - let el = PipelineElement::new(None, None, head.0, head.1.map(Span::from)); + let el = PipelineElement::new( + None, + head.0.map(Span::from), + head.1, + head.2.map(Span::from)); + out.push(el); }