diff options
author | Paul Phillips <paulp@improving.org> | 2012-01-28 23:25:31 -0800 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2012-01-28 23:27:26 -0800 |
commit | 4ab88fbe3ecc5d84a0dec2d8acfbb1687bdd5bd5 (patch) | |
tree | cafc29abaffd5d1e4aac7bf88ce7d5b6b37fed1f /test/files/pos/t3999b.scala | |
parent | d0c5ee4c031a126cee4c552a34cf732716568076 (diff) | |
download | scala-4ab88fbe3ecc5d84a0dec2d8acfbb1687bdd5bd5.tar.gz scala-4ab88fbe3ecc5d84a0dec2d8acfbb1687bdd5bd5.tar.bz2 scala-4ab88fbe3ecc5d84a0dec2d8acfbb1687bdd5bd5.zip |
Bonus test case for SI-3999.
Diffstat (limited to 'test/files/pos/t3999b.scala')
-rw-r--r-- | test/files/pos/t3999b.scala | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/test/files/pos/t3999b.scala b/test/files/pos/t3999b.scala new file mode 100644 index 0000000000..d3fe108479 --- /dev/null +++ b/test/files/pos/t3999b.scala @@ -0,0 +1,20 @@ +object `package` { + trait Score { def toString : String } + trait Test[+T <: Score] { def apply(s : String) : T } + + case class FT(f : Float) extends Score + implicit object FT extends Test[FT] { def apply(s : String) : FT = new FT(s.toFloat) } + + case class IT(i : Int) extends Score + implicit object IT extends Test[IT] { def apply(s : String) : IT = new IT(s.toInt) } +} + +class TT[+T <: Score](implicit val tb : Test[T]) { + def read(s : String) : T = tb(s) +} + +object Tester { + val tt = new TT[FT] + val r = tt.read("1.0") + r.toString +}
\ No newline at end of file |