Javacc排除令牌

时间:2018-11-01 15:57:34

标签: regex javacc

我有以下代码,并且想在|中排除保留字作为标识符。 (<#DIGIT>)()*>。我知道我可以匹配一个或多个,零个或多个,但如何才能从正则表达式中排除某些内容。任何指导将不胜感激。

TOKEN : /* Numbers and identifiers */
{
< INT : (<DIGIT>)+ >
| < #DIGIT : ["0" - "9"] >
| < ID : (<LETTER>)+("_")*(<#DIGIT>)*(<LETTER>)* >
| < #LETTER : ["a" - "z", "A" - "Z"] >
}


TOKEN : { /* RESERVED WORDS  */ 
 <VARIABLE: "variable">
|  <CONSTANT: "constant">
|  <RETURN: "return">
|  <INTEGER: "integer">
|  <BOOLEAN: "boolean">
|  <VOID: "void">
|  <MAIN: "main">
|  <IF: "if">
|  <ELSE : "else">
|  <TRUE: "true">
|  <FALSE: "false">
|  <WHILE: "while">
|  <BEGIN: "begin">
|  <END: "end">
|  <IS: "is">
|  <SKIP: "skip">
}

1 个答案:

答案 0 :(得分:1)

当两个正则表达式都匹配最长的匹配项时,第一个赢。 (请参见JavaCC FAQ。)

因此解决方案很容易:重新订购产品:

TOKEN : { /* RESERVED WORDS  */ 
   <VARIABLE: "variable">
|  <CONSTANT: "constant">
|  <RETURN: "return">
|  <INTEGER: "integer">
|   ...
}

TOKEN : /* Numbers and identifiers */
{
  < INT : (<DIGIT>)+ >
| < #DIGIT : ["0" - "9"] >
| < ID : (<LETTER>)+("_")*(<#DIGIT>)*(<LETTER>)* >
| < #LETTER : ["a" - "z", "A" - "Z"] >
}