arithmeticparsers.scala
来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 71 行
SCALA
71 行
package examples.parsingimport scala.util.parsing.combinator1.syntactical.StandardTokenParsersobject ArithmeticParsers extends StandardTokenParsers { lexical.delimiters ++= List("(", ")", "+", "-", "*", "/") def expr: Parser[Any] = term ~ rep("+" ~ term | "-" ~ term) def term = factor ~ rep("*" ~ factor | "/" ~ factor) def factor: Parser[Any] = "(" ~ expr ~ ")" | numericLit def main(args: Array[String]) { val tokens = new lexical.Scanner(args(0)) println(args(0)) println(phrase(expr)(tokens)) }}object ArithmeticParsers1 extends StandardTokenParsers { lexical.delimiters ++= List("(", ")", "+", "-", "*", "/") val reduceList: Int ~ List[String ~ Int] => Int = { case i ~ ps => (i /: ps)(reduce) } def reduce(x: Int, r: String ~ Int) = (r: @unchecked) match { case "+" ~ y => x + y case "-" ~ y => x - y case "*" ~ y => x * y case "/" ~ y => x / y } def expr : Parser[Int] = term ~ rep ("+" ~ term | "-" ~ term) ^^ reduceList def term : Parser[Int] = factor ~ rep ("*" ~ factor | "/" ~ factor) ^^ reduceList def factor: Parser[Int] = "(" ~> expr <~ ")" | numericLit ^^ (_.toInt) def main(args: Array[String]) { val tokens = new lexical.Scanner(args(0)) println(args(0)) println(phrase(expr)(tokens)) }}class Exprcase class BinOp(op: String, l: Expr, r: Expr) extends Exprcase class Num(n: Int) extends Exprobject ArithmeticParsers2 extends StandardTokenParsers { lexical.delimiters ++= List("(", ")", "+", "-", "*", "/") val reduceList: Expr ~ List[String ~ Expr] => Expr = { case i ~ ps => (i /: ps)(reduce) } def reduce(l: Expr, r: String ~ Expr) = BinOp(r._1, l, r._2) def mkNum(s: String) = Num(s.toInt) def expr : Parser[Expr] = term ~ rep ("+" ~ term | "-" ~ term) ^^ reduceList def term : Parser[Expr] = factor ~ rep ("*" ~ factor | "/" ~ factor) ^^ reduceList def factor: Parser[Expr] = "(" ~> expr <~ ")" | numericLit ^^ ((s: String) => Num(s.toInt)) def main(args: Array[String]) { val parse = phrase(expr) val tokens = new lexical.Scanner(args(0)) println(args(0)) println(parse(tokens)) }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?