C# Coco/r:可删除因子
我正在尝试用Coco/r实现一种语言,用于C语言中的算术运算,它考虑了运算符优先级。我的ATG代码如下所示:C# Coco/r:可删除因子,c#,ebnf,cocor,C#,Ebnf,Cocor,我正在尝试用Coco/r实现一种语言,用于C语言中的算术运算,它考虑了运算符优先级。我的ATG代码如下所示: /* Coco/R lexer and parser specification for arithmetic expressions. */ /* 2006-09-14 */ /* Build with: * Coco.exe -namespace Expressions Ex2.ATG */ using System.Collections.Generic; COMPI
/* 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.
“+”和“-”以外的运算符应具有较低的优先级。此外,“&”运算符的优先级应低于“|”
问题是,当我尝试测试代码时,会出现以下错误:
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
我对Coco/r和EBNF真的很陌生。我看过Coco\r的手册,但我真的不知道问题出在哪里;我错过了什么
提前谢谢你 我认为,在因素上,而不是
Factor<out int n>
=
{
"==" Term<out n2> (. if(n1 == n2){ n = 1; } else { n = 2; } .)
|
...
}
你真的想要这样的东西吗
Factor<out int n>
=
Term<out n1>
[
"==" Term<out n2> (. if(n1 == n2){ n = 1; } else { n = 2; } .)
|
...
]
也就是说,您希望无条件地要求前置项,然后可以选择后面紧跟一个关系。否则,您将允许像ac==d这样的语句。Coco/R是一个LL1解析器。这些错误基本上是告诉你你写了语法,它无法通过向前看1个符号来解决。您要么需要重构语法,要么提供冲突解决程序。我会尝试重构语法,因为我认为这里不需要冲突解决程序。有关更多详细信息,请参阅关于冲突的用户手册