File: t0786.scala

package info (click to toggle)
scala 2.9.2%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 67,252 kB
  • ctags: 6,602
  • sloc: java: 27,488; xml: 4,412; python: 2,297; sh: 734; makefile: 16; ansic: 6
file content (29 lines) | stat: -rw-r--r-- 675 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
object ImplicitProblem {
  class M[T]

  def nullval[T] = null.asInstanceOf[T];
    
  trait Rep[T] {
    def eval: Int
  }
    
  implicit def toRep0(n: Int) = new Rep[Int] {
    def eval = 0
  }
    
  implicit def toRepN[T](n: M[T])(implicit f: T => Rep[T]) = new Rep[M[T]] {
    def eval = f(nullval[T]).eval + 1
  }

  def depth[T <% Rep[T]](n: T) = n.eval

  def main(args: Array[String]) {
    println(depth(nullval[M[Int]]))  // (1) this works   
    println(nullval[M[Int]].eval)    // (2) this works
      
    type m = M[Int]
    println(depth(nullval[m]))     // (3) this doesn't compile on 2.7.RC1    
    println(nullval[m].eval)       // (4) this works
  }

}