首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Scala rep()和结合性

Scala rep()和结合性
EN

Stack Overflow用户
提问于 2013-09-29 12:51:44
回答 1查看 222关注 0票数 0

我想用scala StdTokenParsers来表达这个语法:

代码语言:javascript
复制
expr -> expr ("+"|"-") ~ muldivexpr | muldivexpr

"+“和"-”是左关联的。

语法是左递归的,所以它导致了无限的递归。我可以重写以删除左递归,但它将更改为右关联性。

现在,我计划使用scala rep()将其重写为:

代码语言:javascript
复制
expr -> rep(muldivexpr ("+"|"-")) ~ muldivexpr

但是rep()会改变关联性吗?rep()在这种情况下是如何工作的?

我问这个问题是因为我必须在将来输出AST。

EN

回答 1

Stack Overflow用户

发布于 2013-09-29 13:57:12

您最有可能要找的是:

代码语言:javascript
复制
chainl1[T](p: => Parser[T], q: => Parser[(T, T) => T]): Parser[T]

一般的想法是p是一个操作数,而q是一个分隔符,产生一个可以组合两个操作数的函数,例如

代码语言:javascript
复制
chainl1(muldivexpr,
  "+" ^^^ { (l: Expr, r: Expr) => Addition(l, r)    }
| "-" ^^^ { (l: Expr, r: Expr) => Subtraction(l, r) }
)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19074543

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档