Given the following code:
/**
* Created by danap on 12/8/15.
*/
object ImplicitTest {
trait EC {
override def toString : String = s"EC"
}
trait DEC extends EC {
def sub : EC
override def toString : String = s"DEC - $sub"
}
def usesEC(implicit ec : EC) = ec.toString
class B(implicit val dec: DEC) {
def whichEC = usesEC
}
class C(implicit val dec: DEC) {
implicit val _ec = dec.sub
def whichEC = usesEC
def whichECExplicit = usesEC(_ec)
}
def main(args:Array[String]): Unit = {
implicit val dec : DEC = new DEC {
val sub = new EC {}
}
val b = new B
val c = new C
println(s"b class = ${b.whichEC}")
println(s"c class = ${c.whichEC}")
println(s"c class = ${c.whichECExplicit}")
}
}
The output for scala 2.11 is:
b class = DEC - EC
c class = DEC - EC
c class = EC
I expected it to be:
b class = DEC - EC
c class = EC
c class = EC
Because the implicit val _ec
is declared "closer" to the call to usesEC
in whichEC
. Why does this happen? Also,how I might be able to force _ec
to be used implicitly in C.whichEC
?