Advertisement
Guest User

Untitled

a guest
Oct 11th, 2012
204
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. object Book extends App {
  2.   abstract class Expr { def eval: Double }
  3.  
  4.   type op = (Double, Double) => (Double)
  5.  
  6.   class Op(name: String, op: op, var left: Expr = null, var right: Expr = null) extends Expr {
  7.     def apply(_left:Expr , _right: Expr) = {left = _left; right = _right; this}
  8.     def eval = op(left.eval, right.eval)
  9.     override def toString = "%s(%s, %s)".format(name, left, right)
  10.   }
  11.  
  12.   case class Value(eval:Double) extends Expr { override def toString = eval.toString }
  13.  
  14.   implicit def MakeValue(d: Double) = new Value(d)
  15.  
  16.   def MakeOperator(name: String, op: op): Op = new Op(name, op)
  17.  
  18.   def prod = MakeOperator("prod", _*_)
  19.   def sum = MakeOperator("sum", _+_ )
  20.   def div = MakeOperator("div", _/_)
  21.  
  22.   def test(x: Expr) { println(x + " = " + x.eval) }
  23.  
  24.   test(prod(sum(sum(2, 3), 1), 5))
  25.   test(div(sum(28, 2), prod(5, 2)))
  26. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement