- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个用于解析特定于域的语言的词法分析器。我有一组保留 token (RESERVED 片段)和一个转义字符。每当出现未转义的保留标记时,词法分析器就应进行拆分。
SEP: ';';
AND: '&&';
fragment ESCAPE: '/';
fragment RESERVED: SEP | AND | ESCAPE;
SINGLETOKEN : (~(RESERVED) | (ESCAPE RESERVED))+;
只要 RESERVED 仅包含单个字符标记,这就可以正常工作。求反运算 ~ 仅适用于单个字符。
不幸的是,我也需要它与字符串标记一起使用。因此标记包含超过 1 个字符(请参阅示例中的 AND)。有没有一种简单的方法可以做到这一点?我需要在不内联 java 或 c 代码的情况下解决问题,因为这必须编译为不同的语言,并且我不想维护单独的副本。
希望有人能帮助我
<小时/>创建;假;假;1.key = bla; trig;true;false;(1.key1 ~ .*thisIsRegex || 2.oldKey1 €) && (1.bla=2.blub || 1.blub=bla);
在词法分析器之后,它应该看起来像这样 |标记分隔符空格并不重要:|create|;|false|;|false|;|1.|key| =|bla|;| trig|;|true|;|false|;|(|1.|key1| ~| .*thisIsRegex| || |2.|oldKey1| €|)| && |(|1.|bla|=|2.|blub| || |1.|blub|=|bla|)|;|
整个脚本可以在 http://pastebin.com/Cz520VW4 上找到(请注意,此链接将在一个月后过期)目前还不适用于正则表达式部分。
<小时/>我找到了一个可能的解决方案,但它确实很糟糕,并且使脚本更容易出错。所以我更愿意找到更干净的东西。
我目前正在做的是手写否定(~保留)。
SEP: ';';
AND: '&&';
fragment ESCAPE: '/';
fragment RESERVED: SEP | AND | ESCAPE;
NOT_RESERVED:
: '&' ~('&' | SEP | ESCAPE)
// any two chars starting with '&' followed by a character other then a reserve character
| ~('&' | SEP | ESCAPE) ~(SEP | ESCAPE)
// other than reserved character followed by '&' followed by any char
;
SINGELTON : (NOT_RESERVED | (ESCAPE RESERVED))+;
真实的脚本有超过 5 个多字符标记,以后可能会有更多超过 2 个字符,所以这种解决问题的方法会变得相当复杂。
最佳答案
It currently does not work for the regex part yet ...
那是因为您已将正则表达式文字声明为任何内容。如果正则表达式文字以保留标记开头,如下所示:1.key1 ~ falser
会怎样?
简而言之,我不建议您按照现在尝试的方式实现词法分析器。相反,就像几乎所有编程语言都实现正则表达式文字一样:让它们由分隔符(或带引号的字符串)封装:
1.key1 ~ /falser/
或者:
1.key1 ~ "falser"
您可以在词法分析器中添加一个标志,每当遇到 ~
时就会翻转该标志,并根据该标志创建一个正则表达式文字。下面是一个关于如何执行此操作的小演示:
grammar TriggerDescription;
options {
output=AST;
}
tokens {
// seperator
SEP = ';';
// md identifier
OLDMD = '1.';
NEWMD = '2.';
// boolean
TRUE = 'true';
FALSE = 'false';
//atoms
EX = '€';
EQ = '=';
SMEQ = '<=';
GREQ = '>=';
GR = '>';
SM = '<';
// literals
AND = '&&';
OR = '||';
NOT = '!';
OPENP = '(';
CLOSEP = ')';
// token identifier
TRIGGER = 'TRIGGER';
REPFLAG = 'REPFLAG';
LOCALFLAG = 'LOCALFLAG';
TRIGGERID = 'TRIGGERID';
EVALUATOR = 'EVALUATOR';
ROOT = 'ROOT';
}
@lexer::members {
private boolean regexExpected = false;
}
parse
: trigger+ EOF -> ^(ROOT trigger+)
//(t=. {System.out.printf("\%-15s '\%s'\n", tokenNames[$t.type], $t.text);})* EOF
;
trigger
: triggerid SEP repflag SEP exeflag SEP mdEval SEP -> ^(TRIGGER triggerid repflag exeflag mdEval)
;
triggerid
: rs = WORD -> ^(TRIGGERID[$rs])
;
repflag
: rs = TRUE -> ^(REPFLAG[$rs])
| rs = FALSE -> ^(REPFLAG[$rs])
;
exeflag
: rs = TRUE -> ^(LOCALFLAG[$rs])
| rs = FALSE -> ^(LOCALFLAG[$rs])
;
mdEval
: orExp -> ^(EVALUATOR orExp)
;
orExp
: andExp (OR^ andExp)* // Make `||` root
;
andExp
: notExp (AND^ notExp)* // Make `##` root
;
notExp
: (NOT^)*atom // Make `!` root
;
atom
: key EX^
| key MT^ REGEX
| key EQ^ (key | WORD)
| key GREQ^ (key | WORD)
| key SMEQ^ (key | WORD)
| key GR^ (key | WORD)
| key SM^ (key | WORD)
| OPENP orExp CLOSEP -> orExp // removing the parenthesis
;
key : OLDMD rs = WORD -> ^(OLDMD[$rs])
| NEWMD rs = WORD -> ^(NEWMD[$rs])
;
/*------------------------------------------------------------------
* LEXER RULES
*------------------------------------------------------------------*/
// chars used for words might need to be extended
fragment CHAR
: 'a'..'z' | 'A'..'Z' | '0'..'9'
;
// chars used in regex
fragment REG_CHAR
: '|' | '[' | '\\' | '^' | '$' | '.' | '?' | '*' | '+' | '(' | ')'
;
fragment RESERVED
: SEP | ESCAPE | EQ
;
// white spaces taps etc
fragment WS
: '\t' | ' ' | '\r' | '\n'| '\u000C'
;
fragment ESCAPE
: '/'
;
MT
: '~' {regexExpected = true;}
;
REGEX
@after{regexExpected = false;}
: {regexExpected}?=> WS* ~WS+
;
LINE_COMMENT
: '//' ~('\n'|'\r')* '\r'? '\n' {$channel=HIDDEN;}
;
WHITESPACE
: WS+ { $channel = HIDDEN; }
;
COMMENT
: '/*' .* '*/' {$channel=HIDDEN;}
;
WORD : CHAR+
;
这将为您发布的示例输入创建以下 AST:
但是,请意识到这只是一个快速演示。我现在定义 REGEX 的方式是它将消耗它看到的任何非空格字符。换句话说,要结束 REGEX
,您必须在其后面直接放置一个空格。调整我的示例以满足您自己的需要。
祝你好运!
PS。顺便说一句,REGEX
规则中的奇怪
{ ... }?=>
语法称为“门控语义谓词”。在这里了解更多信息:
What is a 'semantic predicate' in ANTLR?
关于escaping - ANTLR 词法分析器排除字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11952369/
我最近开始使用 Scala 编程。我正在寻找免费的 Scala 分析器。从该语言的官方网站阅读后,我找到了 YourKit ,但该程序不是免费的。 谷歌搜索“scala profiler”没有给我任何
是否有一个程序可以让我获得有关脚本的详细信息:具体来说,我希望能够跟踪其内存占用情况并查看内存中有多少对象。 Firebug 有一个分析器,似乎可以提供计时信息,但我对内存管理更感兴趣。 最佳答案 G
Erlang 有没有好的代码分析器/分析器?我需要一些可以为我的代码构建调用图的东西。 最佳答案 对于静态代码分析,您有 Xref和 Dialyzer ,对于分析,您可以使用 cprof、fprof
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
什么是“self”和“total”列? “总计”列加起来不等于 100%(高得多),看起来像 self 一样。我怀疑 self 是非累积的,而 total 是。因此,如果 methodA 调用 met
在 Perl 中,有一个非常好的分析器,称为 NYTProf。 在其报告中包含 flame graph ,这样就很容易找到程序的瓶颈 是否有一个等效的 java profiler 可以生成相同的报告?
我想知道是否有办法在c++程序中查看特定部分的调用路径。我在开源代码中工作,其中包含许多库。我尝试按照最终在模板中的路径中的代码进行操作。那么,是否有这样的库或分析器来显示代码特定部分的调用路径? 谢
我正在寻找支持每个请求分析统计的分析器,最好是沿着程序流(而不是通常的线程调用堆栈)。所以基本上是每个请求的探查器调用堆栈 + 顺序调用 View ,如下所示: doGet
如何让 symfony profiler 在 phpstorm 中工作?它应该在状态栏中,但是当我打开那个窗口时,它总是说:“这里什么都没有”。缓存目录在配置中正确定义,symfony 插件本身工作正
人们在 Unix 中用来解析/分析日志文件的流行工具是什么?进行计数,查找唯一性,选择/复制具有特定模式的特定行。请提供一些工具或一些关键字。因为我相信以前肯定有类似的问题,但我对关键字一无所知。谢谢
我设置了一个过滤器来计算执行的查询数量,并在超过某个限制时将一些内容写入我的数据库。 它在我的开发环境中运行良好,但是当我在生产环境中测试它时,我的数据库不再返回分析器。我认为这是一个为开发环境启用数
你找到这样的工具并成功使用了吗? 最佳答案 我也在寻找 AS 的分析器,但我想要一个与 FlashDevelop 和 Flex SDK 配合使用的免费软件/开源解决方案。我没有找到。所以我写了一个简单
我需要扩展 SonarQube,以便我可以向其中添加新的分析器。我尝试使用 xpath 为 java 文件添加新规则。我想知道如何在 SonarQube 中添加新语言的代码分析器,例如对于 .meta
我可以在C#(嵌套)中使用elasticsearch 2.3.0版本 我想将分析与索引一起使用, 但是索引设置不会改变,我也不知道为什么。 这是我的代码: private void b
我有一个正在wireshark中查看的自定义协议(protocol)。我认为如果wireshark可以帮我剖析它,这样我就不必解码十六进制了,这会很有用。尽管我在程序日志中执行此操作,但wiresha
我正在考虑使用 Elasticsearch 来提供我们网站的搜索功能。 我一直在试验它,但无法启用 Porterstem 分析器(以便搜索战斗匹配战斗和战斗)。 这是我输入的摘要。 curl
我正在尝试运行一个基于java的java分析器来找出我的专用机器上的java应用程序的资源消耗情况。我尝试使用的分析器称为 Warmroast。 运行时出现以下错误。 java -jar warmro
我没有从我的分析器获得预期结果,并且想测试标记化过程。 此问题的答案:How to use a Lucene Analyzer to tokenize a String? List result =
我在 Lucene 中有特殊的分析需求,但我想继续使用 StandardAnalyzer 机制的部分内容。 特别是,我想要字符串 “-苹果--胡萝卜-番茄?” 被标记为: “-苹果-”2.“-胡萝卜-
有什么好的 JSF 分析器推荐吗? 我正在使用 Tomcat 6 JSF2、 hibernate 和 Spring 最佳答案 如果您使用的是 Eclipse 或 Netbeans 之类的 IDE,那么
我是一名优秀的程序员,十分优秀!