Я довольно новичок в javaCC, и я пытаюсь создать парсер miniJava, но я не знаю, как пропустить семантическое действие.Как совместить 0 токенов в JavCC
SKIP : /* Definition of white-space and comments here */
{
" "
| "\t"
| "\n"
| "\r"
| "\f"
| < "//" (~["\n","\r"])* ("\n"|"\r"|"\r\n") >
}
TOKEN : /* Definition of the MiniJava tokens here. */
{
< NUM: (["0"-"9"])+ >
| < LPAREN: "(" >
| < RPAREN: ")" >
| < COMMA: "," >
| < IDENTIFIER: ["a"-"z","A"-"Z"](["a"-"z","A"-"Z","0"-"9","_"])* >
...
Это метод, который им пытаются использовать пропустить дальше.
public void nt_FormalList() :
{}
{
nt_Type() <IDENTIFIER> (nt_FormalRest())*
| SKIP
}
public void nt_FormalRest() :
{}
{
<COMMA> nt_Type() <IDENTIFIER>
}
public void nt_Type() :
{}
{
<INT>
| <BOOLEAN>
| <INT> <LSQBR> <RSQBR>
| <IDENTIFIER>
}
Можете ли вы пояснить, что вы подразумеваете под «включать пробел». –