Treetop:如何制定组合规则?

发布于 2024-08-13 22:17:23 字数 557 浏览 8 评论 0原文

我想使用 Treetop 制作一个简单的 JSP 解析器。现在,我遇到以下问题:

我的启动基本语法是:

grammar Jspgrammar
    rule jspToken
        '<%'
    end

    rule jspPageToken
        jspToken '@page' 
    end
end

jspToken 应该匹配 '<%' 而 jspPageToken 应该匹配 '<%@page'

当我在 irb 中尝试这个时:

   load 'jspgrammar.rb'
   parser=JspgrammarParser.new
   tree=parser.parse("<%")
   => SyntaxNode offset=0, "<%"

但是当我尝试时

   tree=parser.parse("<%@page")
   => nil

我错过了什么?

I want to make a simple JSP parser by using Treetop. Now, I have the following problem:

My basic grammar for starting is:

grammar Jspgrammar
    rule jspToken
        '<%'
    end

    rule jspPageToken
        jspToken '@page' 
    end
end

jspToken should match '<%' while jspPageToken should match '<%@page'

When I try this in irb:

   load 'jspgrammar.rb'
   parser=JspgrammarParser.new
   tree=parser.parse("<%")
   => SyntaxNode offset=0, "<%"

But when I try

   tree=parser.parse("<%@page")
   => nil

What am I missing?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文