From 259314b442e13833ba94b11951035612179ee5d9 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Sun, 29 Jan 2023 12:15:17 +0900 Subject: [PATCH] templater: reuse parse_commit_term() to coerce if() condition to bool This should fix some inconsistent parsing of condition term. --- src/template_parser.rs | 32 ++++++++++++-------------------- tests/test_templater.rs | 3 +++ 2 files changed, 15 insertions(+), 20 deletions(-) diff --git a/src/template_parser.rs b/src/template_parser.rs index f90374a97..0dd55984b 100644 --- a/src/template_parser.rs +++ b/src/template_parser.rs @@ -135,6 +135,13 @@ enum Expression<'a, C> { } impl<'a, C: 'a> Expression<'a, C> { + fn try_into_boolean(self) -> Option + 'a>> { + match self { + Expression::Property(PropertyAndLabels(property, _)) => property.try_into_boolean(), + Expression::Template(_) => None, + } + } + fn into_template(self) -> Box + 'a> { match self { Expression::Property(property_labels) => property_labels.into_template(), @@ -273,24 +280,6 @@ fn parse_commit_keyword<'a>( PropertyAndLabels(property, vec![pair.as_str().to_string()]) } -fn parse_boolean_commit_property<'a>( - repo: RepoRef<'a>, - workspace_id: &WorkspaceId, - pair: Pair, -) -> Box + 'a> { - let mut inner = pair.into_inner(); - let pair = inner.next().unwrap(); - let _method = inner.next().unwrap(); - assert!(inner.next().is_none()); - match pair.as_rule() { - Rule::identifier => parse_commit_keyword(repo, workspace_id, pair.clone()) - .0 - .try_into_boolean() - .unwrap_or_else(|| panic!("cannot yet use this as boolean: {pair:?}")), - _ => panic!("cannot yet use this as boolean: {pair:?}"), - } -} - fn parse_commit_term<'a>( repo: RepoRef<'a>, workspace_id: &WorkspaceId, @@ -349,9 +338,12 @@ fn parse_commit_term<'a>( } "if" => { let condition_pair = args.next().unwrap(); - let condition_template = condition_pair.into_inner().next().unwrap(); let condition = - parse_boolean_commit_property(repo, workspace_id, condition_template); + parse_commit_template_rule(repo, workspace_id, condition_pair.clone()) + .try_into_boolean() + .unwrap_or_else(|| { + panic!("cannot yet use this as boolean: {condition_pair:?}") + }); let true_template = match args.next() { None => panic!("if() requires at least two arguments"), diff --git a/tests/test_templater.rs b/tests/test_templater.rs index 7bb52c787..b6f4c2515 100644 --- a/tests/test_templater.rs +++ b/tests/test_templater.rs @@ -100,6 +100,9 @@ fn test_templater_parsed_tree() { // Parenthesized multiple terms and concatenation insta::assert_snapshot!(render(r#"(commit_id.short() " ") empty"#), @"000000000000 true"); + + // Parenthesized "if" condition + insta::assert_snapshot!(render(r#"if((divergent), "t", "f")"#), @"f"); } fn get_template_output(