From 6c31377c2186befe5f532a953a1bf2ff9c007cc7 Mon Sep 17 00:00:00 2001 From: JT <547158+jntrnr@users.noreply.github.com> Date: Sat, 6 Nov 2021 20:31:28 +1300 Subject: [PATCH] Fix precedence parse (#298) --- crates/nu-parser/src/parser.rs | 52 +++++++++++++++++----------------- src/tests.rs | 5 ++++ 2 files changed, 31 insertions(+), 26 deletions(-) diff --git a/crates/nu-parser/src/parser.rs b/crates/nu-parser/src/parser.rs index 73f0f2353a..cab7dacef9 100644 --- a/crates/nu-parser/src/parser.rs +++ b/crates/nu-parser/src/parser.rs @@ -2916,35 +2916,35 @@ pub fn parse_math_expression( let (rhs, err) = parse_value(working_set, spans[idx], &SyntaxShape::Any); error = error.or(err); - if op_prec <= last_prec { - while expr_stack.len() > 1 { - // Collapse the right associated operations first - // so that we can get back to a stack with a lower precedence - let mut rhs = expr_stack - .pop() - .expect("internal error: expression stack empty"); - let mut op = expr_stack - .pop() - .expect("internal error: expression stack empty"); - let mut lhs = expr_stack - .pop() - .expect("internal error: expression stack empty"); + if op_prec <= last_prec && expr_stack.len() > 1 { + // Collapse the right associated operations first + // so that we can get back to a stack with a lower precedence + let mut rhs = expr_stack + .pop() + .expect("internal error: expression stack empty"); + let mut op = expr_stack + .pop() + .expect("internal error: expression stack empty"); - if let Some(row_var_id) = lhs_row_var_id { - expand_to_cell_path(working_set, &mut lhs, row_var_id); - } + let mut lhs = expr_stack + .pop() + .expect("internal error: expression stack empty"); - let (result_ty, err) = math_result_type(working_set, &mut lhs, &mut op, &mut rhs); - error = error.or(err); - - let op_span = span(&[lhs.span, rhs.span]); - expr_stack.push(Expression { - expr: Expr::BinaryOp(Box::new(lhs), Box::new(op), Box::new(rhs)), - span: op_span, - ty: result_ty, - custom_completion: None, - }); + if let Some(row_var_id) = lhs_row_var_id { + expand_to_cell_path(working_set, &mut lhs, row_var_id); } + + let (result_ty, err) = math_result_type(working_set, &mut lhs, &mut op, &mut rhs); + error = error.or(err); + + let op_span = span(&[lhs.span, rhs.span]); + expr_stack.push(Expression { + expr: Expr::BinaryOp(Box::new(lhs), Box::new(op), Box::new(rhs)), + span: op_span, + ty: result_ty, + custom_completion: None, + }); + // } } expr_stack.push(op); expr_stack.push(rhs); diff --git a/src/tests.rs b/src/tests.rs index 95a9c78207..45e7a15acb 100644 --- a/src/tests.rs +++ b/src/tests.rs @@ -844,3 +844,8 @@ fn update_cell_path_1() -> TestResult { fn range_and_reduction() -> TestResult { run_test(r#"1..6..36 | math sum"#, "148") } + +#[test] +fn precedence_of_or_groups() -> TestResult { + run_test(r#"4 mod 3 == 0 || 5 mod 5 == 0"#, "true") +}