⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testsyntax.scala

📁 JAVA 语言的函数式编程扩展
💻 SCALA
字号:
package examples.parsing.lambda/** * Parser for an untyped lambda calculus: abstract syntax tree * * @author Miles Sabin (adapted slightly by Adriaan Moors) */trait TestSyntax {  trait Term     case class Unit extends Term  {    override def toString = "unit"  }    case class Lit(n: int) extends Term  {    override def toString = n.toString  }    case class Bool(b: boolean) extends Term  {    override def toString = b.toString  }    case class Name(name: String) extends Term  {    override def toString = name  }  case class Ref(n: Name) extends Term  {    def value = n  }    case class Lam(n: Name, l: Term) extends Term  {    override def toString = "(\\ "+n+" -> "+l+")"  }     case class App(t1: Term, t2: Term) extends Term  {    override def toString = "("+t1+" "+t2+")"  }     case class Let(n: Name, t1: Term, t2: Term) extends Term  {    override def toString = "let "+n+" = "+t1+" in "+t2  }    case class If(c: Term, t1: Term, t2: Term) extends Term  {    override def toString = "if "+c+" then "+t1+" else "+t2  }    trait PrimTerm extends Term  {    def apply(n: Lit) : Term  }  case class PrimPlus extends PrimTerm  {    def apply(x: Lit) = new PrimTerm { def apply(y: Lit) = Lit(x.n+y.n) }  }  case class PrimMinus extends PrimTerm  {    def apply(x: Lit) = new PrimTerm { def apply(y: Lit) = Lit(x.n-y.n) }  }    case class PrimMultiply extends PrimTerm  {    def apply(x: Lit) = new PrimTerm { def apply(y: Lit) = Lit(x.n*y.n) }  }  case class PrimDivide extends PrimTerm  {    def apply(x: Lit) = new PrimTerm { def apply(y: Lit) = Lit(x.n/y.n) }  }  case class PrimEquals extends PrimTerm  {    def apply(x: Lit) = new PrimTerm { def apply(y: Lit) = Bool(x.n == y.n) }  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -