summaryrefslogtreecommitdiff
path: root/test/files/pos/t3999b.scala
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2012-01-28 23:25:31 -0800
committerPaul Phillips <paulp@improving.org>2012-01-28 23:27:26 -0800
commit4ab88fbe3ecc5d84a0dec2d8acfbb1687bdd5bd5 (patch)
treecafc29abaffd5d1e4aac7bf88ce7d5b6b37fed1f /test/files/pos/t3999b.scala
parentd0c5ee4c031a126cee4c552a34cf732716568076 (diff)
downloadscala-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.scala20
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