From dbf547645d26baee030d7db0535e0c0be72c13cc Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 19 Feb 2004 13:11:12 +0000 Subject: * Resolve an ambiguity between ifs and attribute selection, e.g., `if b then x else y.z'. --- src/libexpr/parser.y | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) (limited to 'src/libexpr/parser.y') diff --git a/src/libexpr/parser.y b/src/libexpr/parser.y index 257c0cd38ab2..bfd539a3f094 100644 --- a/src/libexpr/parser.y +++ b/src/libexpr/parser.y @@ -32,7 +32,7 @@ void yyerror(YYLTYPE * loc, yyscan_t scanner, void * data, char * s) ATermList ts; } -%type start expr expr_function expr_assert expr_op +%type start expr expr_function expr_assert expr_if expr_op %type expr_app expr_select expr_simple bind inheritsrc formal %type binds ids expr_list formals %token ID INT STR PATH URI @@ -60,6 +60,12 @@ expr_function expr_assert : ASSERT expr ';' expr_assert { $$ = ATmake("Assert(, )", $2, $4); } + | expr_if + ; + +expr_if + : IF expr THEN expr ELSE expr + { $$ = ATmake("If(, , )", $2, $4, $6); } | expr_op ; @@ -102,8 +108,6 @@ expr_simple | '{' binds '}' { $$ = fixAttrs(0, $2); } | '[' expr_list ']' { $$ = ATmake("List()", $2); } - | IF expr THEN expr ELSE expr - { $$ = ATmake("If(, , )", $2, $4, $6); } ; binds -- cgit 1.4.1