I am trying to implement a language in Coco/r for arithmetic operations in C# which takes operator precedence into consideration. My ATG code looks like this:
/* Coco/R lexer and parser specification for arithmetic expressions. */
/* 2006-09-14 */
/* Build with:
* Coco.exe -namespace Expressions Ex2.ATG
*/
using System.Collections.Generic;
COMPILER Expressions
public int res;
/*--------------------------------------------------------------------------*/
CHARACTERS
letter = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".
digit = "0123456789".
cr = '\r'.
lf = '\n'.
tab = '\t'.
TOKENS
ident = letter {letter | digit}.
number = digit {digit}.
IGNORE cr + lf + tab
PRODUCTIONS
/*------------------------------------------------------------------------*/
Expr<out int n> (. int n1, n2; .)
= Term<out n1> (. n = n1; .)
{
'+' Term<out n2> (. n = n+n2; .)
|
'-' Term<out n2> (. n = n-n2; .)
|
Factor<out int n>
}
.
Factor<out int n>
=
{
"==" Term<out n2> (. if(n1 == n2){ n = 1; } else { n = 2; } .)
|
'<' Term<out n2> (. if(n1 < n2) { n = 1; } else { n = 0; } .)
|
'>' Term<out n2> (. if(n1 > n2) { n = 1; } else { n = 0; } .)
|
"!=" Term<out n2> (. if(n1 != n2){ n = 1; } else { n = 0; } .)
|
"<=" Term<out n2> (. if(n1 <= n2){ n = 1; } else { n = 0; } .)
|
">=" Term<out n2> (. if(n1 >= n2){ n = 1; } else { n = 0; } .)
|
"|" Term<out n2> (. if(n1 != 0 | n2 != 0) { n = 1; } else { n = 0; } .)
|
"&" Term<out n2> (. if(n1 != 0 & n2 != 0){ n = 1; } else { n = 0; } .)
}
.
Term<out int n>
= number (. n = Convert.ToInt32(t.val); .)
{
'*' number (. n = n*Convert.ToInt32(t.val); .)
}
.
Expressions (. int n; .)
= Expr<out n> (. res = n; .)
.
END Expressions.
The operators other than '+' and '-' should have lower precedence. Moreover, the '&' operator should have lower precedence than '|'.
The problem is that when I try to test the code I get the following errors:
Factor deletable
LL1 warning in Expr: contents of [...] or {...} must not be deletable
LL1 warning in Expr: "+" is start of several alternatives
LL1 warning in Expr: "-" is start of several alternatives
LL1 warning in Factor: "==" is start & successor of deletable structure
LL1 warning in Factor: "<" is start & successor of deletable structure
LL1 warning in Factor: ">" is start & successor of deletable structure
LL1 warning in Factor: "!=" is start & successor of deletable structure
LL1 warning in Factor: "<=" is start & successor of deletable structure
LL1 warning in Factor: ">=" is start & successor of deletable structure
LL1 warning in Factor: "|" is start & successor of deletable structure
LL1 warning in Factor: "&" is start & successor of deletable structure
I am really new in Coco/r and EBNF. I had a look into Coco\r's manual, but I don't really see what is the problem; What am i missing?
Thank you in advance!
I think, in
Factor, rather thanyou really want something like
That is, you want to unconditionally require the lead
Term, which can then optionally be followed by exactly one relation. Otherwise you would be allowing statements likea < b > c == d.