- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要创建一个(非常)简单的 XPath 表达式解析器。我正在尝试使用 JavaCC 来实现此目的。我对 JavaCC 完全陌生(尽管我们在学校学习了 Flex 和 Bison),因此我尝试通过一次添加一小部分功能来逐步构建 JJ 脚本。
到目前为止,我掌握了以下语法:
XPATHEXPRESSION ::= ("/" <STEP>)+
STEP ::= <AXIS_NAME> ":" <NODE_TEST> ( "[" <EXPRESSION> "]" )*
EXPRESSION ::= <XPATHEXPRESSION> "=" """ <IDENTIFIER> """
相关的 JJ 文件如下所示:
options {
STATIC = false ;
}
PARSER_BEGIN(XPathParser)
package cz.me.generator.parser;
import cz.me.generator.expression.*;
import java.io.Reader;
import java.io.StringReader;
public class XPathParser
{
public static XPathExpr parse(String exprLiteral)
throws TokenMgrError, ParseException
{
Reader in = new StringReader(exprLiteral);
XPathParser parser = new XPathParser(in);
return parser.XPathExpr();
}
}
PARSER_END(XPathParser)
SKIP : { " " }
TOKEN : { < SLASH : "/" > }
TOKEN : { < COLON : ":" > }
TOKEN : { < OPEN_PAR : "[" > }
TOKEN : { < CLOSE_PAR : "]" > }
TOKEN : { < QUOTE : "\"" > }
TOKEN : { < EQ : "=" > }
TOKEN : { < GT : ">" > }
TOKEN : { < LT : "<" > }
TOKEN : { < IDENTIFIER : (["a"-"z","A"-"Z","0"-"9"])+ > }
TOKEN : { < NUMBER : (["0"-"9"])+ > }
Expression Expression() :
{
Token t;
XPathExpr xPathExpr;
String value;
}
{
xPathExpr = XPathExpr()
<EQ>
<QUOTE>
t = <IDENTIFIER>
{ value = t.image; }
<QUOTE>
{ return new EqExpr(xPathExpr, new StringLiteral(value)); }
}
XPathExpr XPathExpr() :
{
XPathExpr xPathExpr;
Step step;
}
{
{ xPathExpr = new XPathExpr(); }
(
<SLASH>
step = Step()
{ xPathExpr.addStep(step); }
)+
<EOF>
{ return xPathExpr; }
}
Step Step() :
{
Token t;
Step step;
Axis axis;
NodeTest nodeTest;
Expression predicate;
}
{
t = <IDENTIFIER>
{ axis = Axis.valueOf(t.image); }
<COLON>
t = <IDENTIFIER>
{ nodeTest = new NodeNameTest(t.image); }
{ step = new Step(axis, nodeTest); }
(
<OPEN_PAR>
predicate = Expression()
{ step.addPredicate(predicate); }
<CLOSE_PAR>
)*
{ return step; }
}
但是,这不起作用。
以下代码:
XPathExpr expr = XPathParser.parse("/self:house/child:window[/child:material = \"glass\"]");
System.out.println(expr);
产生以下输出(在 Debug模式下运行 JavaCC 时):
Call: XPathExpr
Consumed token: <"/" at line 1 column 1>
Call: Step
Consumed token: <<IDENTIFIER>: "self" at line 1 column 2>
Consumed token: <":" at line 1 column 6>
Consumed token: <<IDENTIFIER>: "house" at line 1 column 7>
Return: Step
Consumed token: <"/" at line 1 column 12>
Call: Step
Consumed token: <<IDENTIFIER>: "child" at line 1 column 13>
Consumed token: <":" at line 1 column 18>
Consumed token: <<IDENTIFIER>: "window" at line 1 column 19>
Consumed token: <"[" at line 1 column 25>
Call: Expression
Call: XPathExpr
Consumed token: <"/" at line 1 column 26>
Call: Step
Consumed token: <<IDENTIFIER>: "child" at line 1 column 27>
Consumed token: <":" at line 1 column 32>
Consumed token: <<IDENTIFIER>: "material" at line 1 column 33>
Return: Step
Return: XPathExpr
Return: Expression
Return: Step
Return: XPathExpr
Exception in thread "main" cz.me.generator.parser.ParseException: Encountered " "=" "= "" at line 1, column 42.
Was expecting one of:
<EOF>
"/" ...
"[" ...
at cz.me.generator.parser.XPathParser.generateParseException(XPathParser.java:270)
at cz.me.generator.parser.XPathParser.jj_consume_token(XPathParser.java:207)
at cz.me.generator.parser.XPathParser.XPathExpr(XPathParser.java:65)
at cz.me.generator.parser.XPathParser.Expression(XPathParser.java:32)
at cz.me.generator.parser.XPathParser.Step(XPathParser.java:100)
at cz.me.generator.parser.XPathParser.XPathExpr(XPathParser.java:54)
at cz.me.generator.parser.XPathParser.parse(XPathParser.java:22)
at cz.me.generator.Main.main(Main.java:17)
我尝试了一些变体来查看 JavaCC 是否没有递归问题,但问题似乎出在其他地方。
出了什么问题?
最佳答案
问题是<EOF>
在 XPathExpr 中。把那个拿出来。添加生产
void Start() :
{ }
{
XPathExpr()
< EOF >
}
并重写parse
使用“开始”。
关于JavaCC - XPath 解析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16587787/
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我是第一次使用 JavaCC,我注意到它生成了大量死代码。有很多行看起来像(请原谅间距,它是自动的): {if ("" != null) return result;} throw new E
在 JavaCC 中,如何定义由重复字符组成的标记,如下例所示: "..." what would correspond to TOKEN : { TripleDot : "..." } 或 "::"
根据JavaCC documentation ,如果我想自定义词法分析器中错误给出的消息: To customize error reporting by the lexer, the lexer c
我正在尝试创建一个包含所有函数名称的映射。我可以在扫描阶段或解析阶段执行此操作,但似乎无法获得两者都可以访问的相同变量。 我需要的是在开始解析之前将所有函数名称保存在映射中,因为函数可以在其调用点下方
我有以下javacc语法。 规则UnaryExpr创建了一些实现java.util.function.Predicate<>的匿名类。 options { static=false; DEBUG_PA
如果可能,我的 void decleration() 应该根据图像解析字符串输入。 SKIP : { | | } TOKEN : { } TOKEN : { } TOKEN : /* KEYW
我目前正在为我的语法开发一个解析器。我的目标是在没有前瞻的情况下实现它,而这正是我真正正在努力解决的问题。 这是一个缩小的示例,我相信它足以证明我遇到的问题。 void main() : {} {
我使用这个语法来计算数学表达式: // Konfiguration (JavaCC-Manual konsultieren) options { STATIC = true; // a
我们正在使用 javacc 实现一个版本的乱码来构建我们的抽象语法树。我们有许多用 java 实现的类,由我们的 Parser.jj 程序调用。但是,Parser.jj 无法识别任何已实现的类,即使它
我正在尝试为这样的源代码创建一个解析器: [code table 1.0] code table code_table_name id = 500 desc = "my code ta
我的语法如下: PARSER_BEGIN(Parser) package parser; public class Parser {} PARSER_END(Parser) SKIP:
我正在尝试使用 javacc 创建一阶逻辑解析器,但遇到以下问题。 我有这个: ()* > 哪里 | | | ) > ,但我想从中排除一些词。特别是我想排除单词 sum、count、a
我需要使用 javaCC 来解析数据文件,例如: //This is comment to skip //This is also comment to skip //student Table Be
我是 JavaCC 的新手,无法弄清楚如何让它运行。我使用的是 Mac OS X,我安装了 javacc-6.0.zip 并解压了它。在键入 javacc 时,我无法从我的路径访问 javacc 脚本
我有一个语法,我必须使用 JJTree 和 JavaCC 来创建一个符号表和一个 AST。虽然我完全理解创建表和树的作业部分,但给我的语法含糊不清,包含左递归和间接左递归。它也需要留下因素。我在整个互
在我的语法中,有最初包含间接左递归的表达式和片段的产生规则。这是我删除了递归之后的规则。 String expression() #Expression : {String number; Token
匹配 任何内容 的正则表达式是什么,除了这些字符串: =>, | ? 如果您熟悉 javacc,我正在尝试定义我的 ANYTHING 标记,如下所示: TOKEN : { " > | | |
所以我是 JavaCC 的初学者,我只想在没有重复项的情况下接受这个字符串。因此,如果输入如下: A B C A' B' C' A'' B'' C'' 只有当`B != B' != B''时解析器才会
我已经为此困惑了好几天,搜索似乎没有给出任何结果。让我想知道这是否可能。例如: funct functionNAME (Object o) { o+1 }; 重点是用户必须在大括号内使用标识符“o”,
我是一名优秀的程序员,十分优秀!