diff options
author | Paul Phillips <paulp@improving.org> | 2012-01-30 07:59:35 -0800 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2012-01-30 08:00:57 -0800 |
commit | 66b0e759258ff1185def1689bd0a1b67105922bf (patch) | |
tree | 8ac70da8805309eb4d0493b8bc8d5c97a9c71a22 /test/files/pos | |
parent | 6eb066dade3f6541fb33a0b325c67ca98aa413ad (diff) | |
parent | 5e9dd4a05c25f463f29d0fbc2f1bec194bf7700b (diff) | |
download | scala-66b0e759258ff1185def1689bd0a1b67105922bf.tar.gz scala-66b0e759258ff1185def1689bd0a1b67105922bf.tar.bz2 scala-66b0e759258ff1185def1689bd0a1b67105922bf.zip |
Merge branch 'master' into inline
Conflicts:
src/compiler/scala/reflect/internal/Definitions.scala
Diffstat (limited to 'test/files/pos')
-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 |