summaryrefslogtreecommitdiff
path: root/test/files/pos
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2012-01-30 07:59:35 -0800
committerPaul Phillips <paulp@improving.org>2012-01-30 08:00:57 -0800
commit66b0e759258ff1185def1689bd0a1b67105922bf (patch)
tree8ac70da8805309eb4d0493b8bc8d5c97a9c71a22 /test/files/pos
parent6eb066dade3f6541fb33a0b325c67ca98aa413ad (diff)
parent5e9dd4a05c25f463f29d0fbc2f1bec194bf7700b (diff)
downloadscala-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.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