summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorAntonio Cunei <antonio.cunei@epfl.ch>2009-05-15 15:44:54 +0000
committerAntonio Cunei <antonio.cunei@epfl.ch>2009-05-15 15:44:54 +0000
commit10830eaae2955766378369b8d1bcc0e6963b9b7f (patch)
tree595d0d162d94eda17062d4d13710378930b7ac7f /test
parentfbf991833d5ec0d9890ac1e7df9f53209e313552 (diff)
downloadscala-10830eaae2955766378369b8d1bcc0e6963b9b7f.tar.gz
scala-10830eaae2955766378369b8d1bcc0e6963b9b7f.tar.bz2
scala-10830eaae2955766378369b8d1bcc0e6963b9b7f.zip
1.4-related cleanup and reorganization.
Removed a bunch of now useless 1.4 code, merged back jvm5-specific partest tests into the general jvm tests, documentation updates.
Diffstat (limited to 'test')
-rw-r--r--test/files/jvm/NestedAnnotations.java (renamed from test/files/jvm5/NestedAnnotations.java)0
-rw-r--r--test/files/jvm/OuterEnum.java (renamed from test/files/jvm5/OuterEnum.java)0
-rw-r--r--test/files/jvm/OuterTParams.java (renamed from test/files/jvm5/OuterTParams.java)0
-rw-r--r--test/files/jvm/SourceAnnotation.java (renamed from test/files/jvm5/SourceAnnotation.java)0
-rw-r--r--test/files/jvm/annotations.check (renamed from test/files/jvm5/annotations.check)0
-rw-r--r--test/files/jvm/annotations.scala (renamed from test/files/jvm5/annotations.scala)0
-rw-r--r--test/files/jvm/bug676.check (renamed from test/files/jvm5/bug676.check)0
-rw-r--r--test/files/jvm/bug676.scala (renamed from test/files/jvm5/bug676.scala)0
-rw-r--r--test/files/jvm/bug680.check (renamed from test/files/jvm5/bug680.check)0
-rw-r--r--test/files/jvm/bug680.scala (renamed from test/files/jvm5/bug680.scala)0
-rw-r--r--test/files/jvm/console.check (renamed from test/files/jvm5/console.check)0
-rw-r--r--test/files/jvm/console.scala (renamed from test/files/jvm5/console.scala)0
-rw-r--r--test/files/jvm/genericNest.scala (renamed from test/files/jvm5/genericNest.scala)0
-rw-r--r--test/files/jvm/interpreter.check (renamed from test/files/jvm5/interpreter.check)0
-rw-r--r--test/files/jvm/interpreter.scala (renamed from test/files/jvm5/interpreter.scala)0
-rwxr-xr-xtest/files/jvm/mkAnnotationsJar.sh (renamed from test/files/jvm5/mkAnnotationsJar.sh)0
-rw-r--r--test/files/jvm/outerEnum.check (renamed from test/files/jvm5/outerEnum.check)0
-rw-r--r--test/files/jvm/outerEnum.scala (renamed from test/files/jvm5/outerEnum.scala)0
-rw-r--r--test/files/jvm/stringbuilder.scala (renamed from test/files/jvm5/stringbuilder.scala)0
-rw-r--r--test/files/jvm/sync-var.check (renamed from test/files/jvm5/sync-var.check)0
-rw-r--r--test/files/jvm/sync-var.scala (renamed from test/files/jvm5/sync-var.scala)0
-rw-r--r--test/files/jvm/t0014.check (renamed from test/files/jvm5/t0014.check)0
-rw-r--r--test/files/jvm/t0014.scala (renamed from test/files/jvm5/t0014.scala)0
-rw-r--r--test/files/jvm/t1461.scala (renamed from test/files/jvm5/t1461.scala)0
-rw-r--r--test/files/jvm/t1464.check (renamed from test/files/jvm5/t1464.check)0
-rw-r--r--test/files/jvm/t1464/MyTrait.scala (renamed from test/files/jvm5/t1464/MyTrait.scala)0
-rw-r--r--test/files/jvm/t1464/Test.java (renamed from test/files/jvm5/t1464/Test.java)0
-rw-r--r--test/files/jvm/throws-annot.check (renamed from test/files/jvm5/throws-annot.check)0
-rw-r--r--test/files/jvm/throws-annot.scala (renamed from test/files/jvm5/throws-annot.scala)0
-rwxr-xr-x[-rw-r--r--]test/files/jvm/typerep.check2
-rwxr-xr-x[-rw-r--r--]test/files/jvm/typerep.scala25
-rwxr-xr-xtest/files/jvm5/typerep.check49
-rwxr-xr-xtest/files/jvm5/typerep.scala383
-rw-r--r--test/files/pos/chang/Outer.java (renamed from test/files/pos5/chang/Outer.java)0
-rw-r--r--test/files/pos/chang/Test.scala (renamed from test/files/pos5/chang/Test.scala)0
-rw-r--r--test/files/pos/ilya/J.java (renamed from test/files/pos5/ilya/J.java)0
-rw-r--r--test/files/pos/ilya/S.scala (renamed from test/files/pos5/ilya/S.scala)0
-rw-r--r--test/files/pos/ilya2/A.scala (renamed from test/files/pos5/ilya2/A.scala)0
-rw-r--r--test/files/pos/ilya2/B.java (renamed from test/files/pos5/ilya2/B.java)0
-rw-r--r--test/files/pos/ilya2/Nullable.java (renamed from test/files/pos5/ilya2/Nullable.java)0
-rw-r--r--test/files/pos/signatures/Test.java (renamed from test/files/pos5/signatures/Test.java)0
-rw-r--r--test/files/pos/signatures/sig.scala (renamed from test/files/pos5/signatures/sig.scala)0
-rw-r--r--test/files/pos/t0695/JavaClass.java (renamed from test/files/pos5/t0695/JavaClass.java)0
-rw-r--r--test/files/pos/t0695/Test.scala (renamed from test/files/pos5/t0695/Test.scala)0
-rw-r--r--test/files/pos/t1101/J.java (renamed from test/files/pos5/t1101/J.java)0
-rw-r--r--test/files/pos/t1101/S.scala (renamed from test/files/pos5/t1101/S.scala)0
-rw-r--r--test/files/pos/t1102/J.java (renamed from test/files/pos5/t1102/J.java)0
-rw-r--r--test/files/pos/t1102/S.scala (renamed from test/files/pos5/t1102/S.scala)0
-rw-r--r--test/files/pos/t1150/J.java (renamed from test/files/pos5/t1150/J.java)0
-rw-r--r--test/files/pos/t1150/S.scala (renamed from test/files/pos5/t1150/S.scala)0
-rw-r--r--test/files/pos/t1152/J.java (renamed from test/files/pos5/t1152/J.java)0
-rw-r--r--test/files/pos/t1152/S.scala (renamed from test/files/pos5/t1152/S.scala)0
-rw-r--r--test/files/pos/t1176/J.java (renamed from test/files/pos5/t1176/J.java)0
-rw-r--r--test/files/pos/t1176/S.scala (renamed from test/files/pos5/t1176/S.scala)0
-rw-r--r--test/files/pos/t1186/t1186.java (renamed from test/files/pos5/t1186/t1186.java)0
-rw-r--r--test/files/pos/t1196/J.java (renamed from test/files/pos5/t1196/J.java)0
-rw-r--r--test/files/pos/t1196/S.scala (renamed from test/files/pos5/t1196/S.scala)0
-rw-r--r--test/files/pos/t1197/J.java (renamed from test/files/pos5/t1197/J.java)0
-rw-r--r--test/files/pos/t1197/S.scala (renamed from test/files/pos5/t1197/S.scala)0
-rw-r--r--test/files/pos/t1203/J.java (renamed from test/files/pos5/t1203/J.java)0
-rw-r--r--test/files/pos/t1203/S.scala (renamed from test/files/pos5/t1203/S.scala)0
-rw-r--r--test/files/pos/t1230/J.java (renamed from test/files/pos5/t1230/J.java)0
-rw-r--r--test/files/pos/t1230/S.scala (renamed from test/files/pos5/t1230/S.scala)0
-rw-r--r--test/files/pos/t1231/J.java (renamed from test/files/pos5/t1231/J.java)0
-rw-r--r--test/files/pos/t1231/S.scala (renamed from test/files/pos5/t1231/S.scala)0
-rwxr-xr-xtest/files/pos/t1232/J.java (renamed from test/files/pos5/t1232/J.java)0
-rwxr-xr-xtest/files/pos/t1232/J2.java (renamed from test/files/pos5/t1232/J2.java)0
-rwxr-xr-xtest/files/pos/t1232/S.scala (renamed from test/files/pos5/t1232/S.scala)0
-rw-r--r--test/files/pos/t1235/Test.java (renamed from test/files/pos5/t1235/Test.java)0
-rw-r--r--test/files/pos/t1254/t1254.java (renamed from test/files/pos5/t1254/t1254.java)0
-rw-r--r--test/files/pos/t1263/Test.java (renamed from test/files/pos5/t1263/Test.java)0
-rw-r--r--test/files/pos/t1263/test.scala (renamed from test/files/pos5/t1263/test.scala)0
-rw-r--r--test/files/pos/t1711/Seq.scala (renamed from test/files/pos5/t1711/Seq.scala)0
-rw-r--r--test/files/pos/t1711/Test.java (renamed from test/files/pos5/t1711/Test.java)0
-rw-r--r--test/pending/jvm/annotations.scala (renamed from test/pending/jvm5/annotations.scala)0
-rw-r--r--test/pending/jvm/t1464.check (renamed from test/pending/jvm5/t1464.check)0
-rw-r--r--test/pending/pos/misc/A.java (renamed from test/pending/pos5/misc/A.java)0
-rw-r--r--test/pending/pos/misc/B.scala (renamed from test/pending/pos5/misc/B.scala)0
-rw-r--r--test/pending/pos/misc/J.java (renamed from test/pending/pos5/misc/J.java)0
-rw-r--r--test/pending/pos/misc/S.scala (renamed from test/pending/pos5/misc/S.scala)0
-rw-r--r--test/pending/pos/t1745/J.java (renamed from test/pending/pos5/t1745/J.java)0
-rw-r--r--test/pending/pos/t1745/S.scala (renamed from test/pending/pos5/t1745/S.scala)0
82 files changed, 19 insertions, 440 deletions
diff --git a/test/files/jvm5/NestedAnnotations.java b/test/files/jvm/NestedAnnotations.java
index 8f2327dcce..8f2327dcce 100644
--- a/test/files/jvm5/NestedAnnotations.java
+++ b/test/files/jvm/NestedAnnotations.java
diff --git a/test/files/jvm5/OuterEnum.java b/test/files/jvm/OuterEnum.java
index 75d3f34223..75d3f34223 100644
--- a/test/files/jvm5/OuterEnum.java
+++ b/test/files/jvm/OuterEnum.java
diff --git a/test/files/jvm5/OuterTParams.java b/test/files/jvm/OuterTParams.java
index 1d3db49fcf..1d3db49fcf 100644
--- a/test/files/jvm5/OuterTParams.java
+++ b/test/files/jvm/OuterTParams.java
diff --git a/test/files/jvm5/SourceAnnotation.java b/test/files/jvm/SourceAnnotation.java
index 047751ddfe..047751ddfe 100644
--- a/test/files/jvm5/SourceAnnotation.java
+++ b/test/files/jvm/SourceAnnotation.java
diff --git a/test/files/jvm5/annotations.check b/test/files/jvm/annotations.check
index 418301331f..418301331f 100644
--- a/test/files/jvm5/annotations.check
+++ b/test/files/jvm/annotations.check
diff --git a/test/files/jvm5/annotations.scala b/test/files/jvm/annotations.scala
index 9af2d333ba..9af2d333ba 100644
--- a/test/files/jvm5/annotations.scala
+++ b/test/files/jvm/annotations.scala
diff --git a/test/files/jvm5/bug676.check b/test/files/jvm/bug676.check
index 5d1c9925f9..5d1c9925f9 100644
--- a/test/files/jvm5/bug676.check
+++ b/test/files/jvm/bug676.check
diff --git a/test/files/jvm5/bug676.scala b/test/files/jvm/bug676.scala
index bcd27e4e21..bcd27e4e21 100644
--- a/test/files/jvm5/bug676.scala
+++ b/test/files/jvm/bug676.scala
diff --git a/test/files/jvm5/bug680.check b/test/files/jvm/bug680.check
index e69de29bb2..e69de29bb2 100644
--- a/test/files/jvm5/bug680.check
+++ b/test/files/jvm/bug680.check
diff --git a/test/files/jvm5/bug680.scala b/test/files/jvm/bug680.scala
index b0b0c9f7c0..b0b0c9f7c0 100644
--- a/test/files/jvm5/bug680.scala
+++ b/test/files/jvm/bug680.scala
diff --git a/test/files/jvm5/console.check b/test/files/jvm/console.check
index ef7c169844..ef7c169844 100644
--- a/test/files/jvm5/console.check
+++ b/test/files/jvm/console.check
diff --git a/test/files/jvm5/console.scala b/test/files/jvm/console.scala
index b07765675c..b07765675c 100644
--- a/test/files/jvm5/console.scala
+++ b/test/files/jvm/console.scala
diff --git a/test/files/jvm5/genericNest.scala b/test/files/jvm/genericNest.scala
index c1b0210117..c1b0210117 100644
--- a/test/files/jvm5/genericNest.scala
+++ b/test/files/jvm/genericNest.scala
diff --git a/test/files/jvm5/interpreter.check b/test/files/jvm/interpreter.check
index 86d6adbbec..86d6adbbec 100644
--- a/test/files/jvm5/interpreter.check
+++ b/test/files/jvm/interpreter.check
diff --git a/test/files/jvm5/interpreter.scala b/test/files/jvm/interpreter.scala
index 21c88734e0..21c88734e0 100644
--- a/test/files/jvm5/interpreter.scala
+++ b/test/files/jvm/interpreter.scala
diff --git a/test/files/jvm5/mkAnnotationsJar.sh b/test/files/jvm/mkAnnotationsJar.sh
index 0cd5e631a7..0cd5e631a7 100755
--- a/test/files/jvm5/mkAnnotationsJar.sh
+++ b/test/files/jvm/mkAnnotationsJar.sh
diff --git a/test/files/jvm5/outerEnum.check b/test/files/jvm/outerEnum.check
index ebd7525b33..ebd7525b33 100644
--- a/test/files/jvm5/outerEnum.check
+++ b/test/files/jvm/outerEnum.check
diff --git a/test/files/jvm5/outerEnum.scala b/test/files/jvm/outerEnum.scala
index 18794b7dbe..18794b7dbe 100644
--- a/test/files/jvm5/outerEnum.scala
+++ b/test/files/jvm/outerEnum.scala
diff --git a/test/files/jvm5/stringbuilder.scala b/test/files/jvm/stringbuilder.scala
index cbbfa022b0..cbbfa022b0 100644
--- a/test/files/jvm5/stringbuilder.scala
+++ b/test/files/jvm/stringbuilder.scala
diff --git a/test/files/jvm5/sync-var.check b/test/files/jvm/sync-var.check
index e77aa319a5..e77aa319a5 100644
--- a/test/files/jvm5/sync-var.check
+++ b/test/files/jvm/sync-var.check
diff --git a/test/files/jvm5/sync-var.scala b/test/files/jvm/sync-var.scala
index aa6ae9fa34..aa6ae9fa34 100644
--- a/test/files/jvm5/sync-var.scala
+++ b/test/files/jvm/sync-var.scala
diff --git a/test/files/jvm5/t0014.check b/test/files/jvm/t0014.check
index bece7db7af..bece7db7af 100644
--- a/test/files/jvm5/t0014.check
+++ b/test/files/jvm/t0014.check
diff --git a/test/files/jvm5/t0014.scala b/test/files/jvm/t0014.scala
index a1948702dc..a1948702dc 100644
--- a/test/files/jvm5/t0014.scala
+++ b/test/files/jvm/t0014.scala
diff --git a/test/files/jvm5/t1461.scala b/test/files/jvm/t1461.scala
index f0e3cea6cd..f0e3cea6cd 100644
--- a/test/files/jvm5/t1461.scala
+++ b/test/files/jvm/t1461.scala
diff --git a/test/files/jvm5/t1464.check b/test/files/jvm/t1464.check
index c508d5366f..c508d5366f 100644
--- a/test/files/jvm5/t1464.check
+++ b/test/files/jvm/t1464.check
diff --git a/test/files/jvm5/t1464/MyTrait.scala b/test/files/jvm/t1464/MyTrait.scala
index 0b8ccc412b..0b8ccc412b 100644
--- a/test/files/jvm5/t1464/MyTrait.scala
+++ b/test/files/jvm/t1464/MyTrait.scala
diff --git a/test/files/jvm5/t1464/Test.java b/test/files/jvm/t1464/Test.java
index 235848b1df..235848b1df 100644
--- a/test/files/jvm5/t1464/Test.java
+++ b/test/files/jvm/t1464/Test.java
diff --git a/test/files/jvm5/throws-annot.check b/test/files/jvm/throws-annot.check
index a0ed82b106..a0ed82b106 100644
--- a/test/files/jvm5/throws-annot.check
+++ b/test/files/jvm/throws-annot.check
diff --git a/test/files/jvm5/throws-annot.scala b/test/files/jvm/throws-annot.scala
index 90b58b9976..90b58b9976 100644
--- a/test/files/jvm5/throws-annot.scala
+++ b/test/files/jvm/throws-annot.scala
diff --git a/test/files/jvm/typerep.check b/test/files/jvm/typerep.check
index ff98348304..ca93180946 100644..100755
--- a/test/files/jvm/typerep.check
+++ b/test/files/jvm/typerep.check
@@ -9,10 +9,12 @@ Float
Double
String
Unit
+Class[Int]
Some[Int]
Some[Int]
Some[Some[Int]]
+Some[List[Int]]
None
None
diff --git a/test/files/jvm/typerep.scala b/test/files/jvm/typerep.scala
index 47bd335d32..fc94817adf 100644..100755
--- a/test/files/jvm/typerep.scala
+++ b/test/files/jvm/typerep.scala
@@ -49,7 +49,7 @@ object testPrimitives {
println(getType(0.0d))
println(getType("abc"))
println(getType(())) // Unit
-// println(getType(classOf[Int])) // Class
+ println(getType(classOf[Int])) // Class
println
}
@@ -58,6 +58,8 @@ object testOptions {
val x: Option[Int] = Some(2)
println(getType(x))
println(getType(Some(Some(3))))
+ println(getType(Some(List(3))))
+ //println(getType(Some(None: List[Int]))) // error: no implicit argument matching parameter type TypeRep[object None] was foun
println(getType(None: Option[Int]))
val y: Option[Int] = None
println(getType(y))
@@ -156,7 +158,7 @@ object TypeRep {
def getType[A](x: Option[A])(implicit rep: TypeRep[A]): TypeRep[Option[A]] = (x match {
case Some(v) => SomeRep(rep)
- case None => NoneRep // or NoneRep(rep)
+ case None => NoneRep
}).asInstanceOf[TypeRep[Option[A]]]
def getType[A](x: List[A])(implicit rep: TypeRep[A]): TypeRep[List[A]] = (x match {
@@ -174,12 +176,14 @@ object TypeRep {
implicit def doubleRep: TypeRep[Double] = DoubleRep
implicit def unitRep: TypeRep[Unit] = UnitRep
-// implicit def classRep: TypeRep[Class] = ClassRep
implicit def stringRep: TypeRep[String] = StringRep
- implicit def noneRep: TypeRep[Option[Nothing]] = NoneRep[Nothing](NothingRep.asInstanceOf[TypeRep[Nothing]])
+ //implicit def noneRep: TypeRep[None.type] = NoneRep//[Nothing](NothingRep.asInstanceOf[TypeRep[Nothing]])
implicit def anyRep: TypeRep[Any] = AnyRep
implicit def nothingRep: TypeRep[Nothing] = NothingRep
+ implicit def classRep[A](implicit elemrep: TypeRep[A]): TypeRep[Class[A]] =
+ ClassRep(elemrep)
+
implicit def someRep[A](implicit elemrep: TypeRep[A]): TypeRep[Some[A]] =
SomeRep(elemrep)
@@ -189,9 +193,10 @@ object TypeRep {
implicit def arrayRep[A](implicit elemrep: TypeRep[A]): TypeRep[Array[A]] =
ArrayRep(elemrep)
- implicit def tuple2Rep[A1, A2](implicit _1: TypeRep[A1], _2: TypeRep[A2]): TypeRep[Tuple2[A1, A2]] =
+ implicit def tuple2Rep[A1, A2](implicit _1: TypeRep[A1], _2: TypeRep[A2]): TypeRep[(A1, A2)] =
Tuple2Rep(_1, _2)
- implicit def tuple3Rep[A1, A2, A3](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3]): TypeRep[Tuple3[A1, A2, A3]] =
+
+ implicit def tuple3Rep[A1, A2, A3](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3]): TypeRep[(A1, A2, A3)] =
Tuple3Rep(_1, _2, _3)
implicit def tuple4Rep[A1, A2, A3, A4](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4]): TypeRep[Tuple4[A1, A2, A3, A4]] =
Tuple4Rep(_1, _2, _3, _4)
@@ -263,7 +268,7 @@ object TypeRep {
case object StringRep extends TypeRep[String] {
override def toString = "String"
}
- case object NoneRep extends TypeRep[Option[Nothing]] {
+ case object NoneRep extends TypeRep[None.type] {
override def toString = "None"
}
case object NilRep extends TypeRep[Nil.type] {
@@ -277,6 +282,10 @@ object TypeRep {
}
@serializable
+ case class ClassRep[A](elemRep: TypeRep[A]) extends TypeRep[Class[A]] {
+ override def toString = "Class[" + elemRep + "]"
+ }
+ @serializable
case class SomeRep[A](elemRep: TypeRep[A]) extends TypeRep[Some[A]] {
override def toString = "Some[" + elemRep + "]"
}
@@ -296,7 +305,7 @@ object TypeRep {
}
@serializable
- case class Tuple2Rep[A1, A2](_1: TypeRep[A1], _2: TypeRep[A2]) extends TypeRep[Tuple2[A1, A2]] {
+ case class Tuple2Rep[A1, A2](_1: TypeRep[A1], _2: TypeRep[A2]) extends TypeRep[(A1, A2)] {
override def toString = "Tuple2[" + _1 + ", " + _2 + "]"
}
@serializable
diff --git a/test/files/jvm5/typerep.check b/test/files/jvm5/typerep.check
deleted file mode 100755
index ca93180946..0000000000
--- a/test/files/jvm5/typerep.check
+++ /dev/null
@@ -1,49 +0,0 @@
-Boolean
-Boolean
-true
-Byte
-Char
-Int
-Long
-Float
-Double
-String
-Unit
-Class[Int]
-
-Some[Int]
-Some[Int]
-Some[Some[Int]]
-Some[List[Int]]
-None
-None
-
-List[Int]
-List[Int]
-List[List[Int]]
-Nil
-List[Any]
-
-Array[Int]
-Array[Array[Int]]
-Array[Int]
-Array[Int]
-Array[Int]
-Array[Int]
-
-Tuple2[Int, String]
-Tuple3[Char, Char, String]
-Tuple2[Tuple2[Int, String], Tuple2[Int, String]]
-Tuple2[Tuple2[Some[Char], Int], Tuple2[Some[Char], Int]]
-
-Function1[Int, Int]
-Int
-Function1[Int, Int]
-Int
-Function1[Int, Function1[Int, Int]]
-Function1[Int, Int]
-Int
-Function3[Boolean, List[Char], Int, Int]
-Function2[Function1[Int, Int], Int, Int]
-Int
-
diff --git a/test/files/jvm5/typerep.scala b/test/files/jvm5/typerep.scala
deleted file mode 100755
index fc94817adf..0000000000
--- a/test/files/jvm5/typerep.scala
+++ /dev/null
@@ -1,383 +0,0 @@
-//############################################################################
-// Type Representation at runtime
-//############################################################################
-// $Id: $
-
-import TypeRep._
-
-object Test extends Application {
- testPrimitives
- testOptions
- testLists
- testArrays
- testTuples
- testFuncs
- testClasses
-}
-
-object serialize {
- import java.io._
-
- @throws(classOf[IOException])
- def write[A](o: A): Array[Byte] = {
- val ba = new ByteArrayOutputStream(512)
- val out = new ObjectOutputStream(ba)
- out.writeObject(o)
- out.close()
- ba.toByteArray()
- }
- @throws(classOf[IOException])
- @throws(classOf[ClassNotFoundException])
- def read[A](buffer: Array[Byte]): A = {
- val in =
- new ObjectInputStream(new ByteArrayInputStream(buffer))
- in.readObject().asInstanceOf[A]
- }
-}
-
-object testPrimitives {
- println(getType(true))
- val b = false; val bt = getType(b)
- println(bt)
- val bt1: TypeRep[Boolean] = serialize.read(serialize.write(bt))
- println(bt1 == bt)
- println(getType(16.toByte))
- println(getType('a'))
- println(getType(3))
- println(getType(3l))
- println(getType(0.0f))
- println(getType(0.0d))
- println(getType("abc"))
- println(getType(())) // Unit
- println(getType(classOf[Int])) // Class
- println
-}
-
-object testOptions {
- println(getType(Some(2)))
- val x: Option[Int] = Some(2)
- println(getType(x))
- println(getType(Some(Some(3))))
- println(getType(Some(List(3))))
- //println(getType(Some(None: List[Int]))) // error: no implicit argument matching parameter type TypeRep[object None] was foun
- println(getType(None: Option[Int]))
- val y: Option[Int] = None
- println(getType(y))
- println
-}
-
-object testLists {
- println(getType(List(3)))
- println(getType(3 :: Nil))
- println(getType(List(List(3))))
- println(getType(Nil: List[Int]))
- println(getType(List(1, "abc")))
- println
-}
-
-object testArrays {
- println(getType(Array(3)))
- println(getType(Array(Array(3), Array(4))))
- println(getType(new Array[Int](0)))
- println(getType(List(1).toArray))
- println(getType(List[Int]().toArray))
- println(getType(Array(3).drop(1).toArray)) // empty
- println
-}
-
-object testTuples {
- println(getType((3, "abc")))
- println(getType(Triple('a', 'b', "c")))
- println(getType(((3, "abc"), (4, "xyz"))))
- println(getType(((Some('b'), 3), (Some('a'), 4))))
- //println(getType(((Some('b'), 3), (None, 4))))
- println
-}
-
-object testFuncs {
- def f1(x: Int): Int = 2 * x
- println(getType(f1 _))
- println(getType(f1(2)))
- val f2 = (x: Int) => 2 * x
- println(getType(f2))
- println(getType(f2(2)))
- val f3 = (x: Int) => (y: Int) => x + y
- println(getType(f3))
- println(getType(f3(2)))
- println(getType(f3(2)(2)))
- def f4(b: Boolean, c: List[Char], i: Int): Int = i
- println(getType(f4 _))
- def f5(f: Int => Int, x: Int) = f(x)
- println(getType(f5 _))
- println(getType(f5(f1, 1)))
- println
-}
-
-class Foo {
- class Bar(x: Int)
-}
-
-
-object foo extends Foo
-
-package pkg1 {
- class C1
- object c1 extends C1
-}
-
-object testClasses {
- /*
- case object FooRep extends TypeRep[Foo] {
- override def toString = "Foo"
- }
- implicit def fooRep[A](x: A)(implicit rep: TypeRep[foo.type]): TypeRep[foo.type] = rep
- println(getType(foo))
- println(getType(new foo.Bar(0)))
- val foo2 = new Foo
- println(getType(foo2))
- println(getType(new foo2.Bar(1)))
- println
-
- println(getType(pkg1.c1))
- val c1 = new pkg1.C1
- println(getType(c1))
- println
- */
-}
-
-
-/**
- * @author Stephane Micheloud
- * @version 1.0
- */
-abstract class TypeRep[A]
-
-object TypeRep {
-
- def getType[A](x: A)(implicit rep: TypeRep[A]): TypeRep[A] = rep
-
- def getType[A](x: Option[A])(implicit rep: TypeRep[A]): TypeRep[Option[A]] = (x match {
- case Some(v) => SomeRep(rep)
- case None => NoneRep
- }).asInstanceOf[TypeRep[Option[A]]]
-
- def getType[A](x: List[A])(implicit rep: TypeRep[A]): TypeRep[List[A]] = (x match {
- case h :: t => ListRep(getType(h))
- case Nil => NilRep
- }).asInstanceOf[TypeRep[List[A]]]
-
- implicit def boolRep: TypeRep[Boolean] = BooleanRep
- implicit def byteRep: TypeRep[Byte] = ByteRep
- implicit def charRep: TypeRep[Char] = CharRep
- implicit def shortRep: TypeRep[Short] = ShortRep
- implicit def intRep: TypeRep[Int] = IntRep
- implicit def longRep: TypeRep[Long] = LongRep
- implicit def floatRep: TypeRep[Float] = FloatRep
- implicit def doubleRep: TypeRep[Double] = DoubleRep
-
- implicit def unitRep: TypeRep[Unit] = UnitRep
- implicit def stringRep: TypeRep[String] = StringRep
- //implicit def noneRep: TypeRep[None.type] = NoneRep//[Nothing](NothingRep.asInstanceOf[TypeRep[Nothing]])
- implicit def anyRep: TypeRep[Any] = AnyRep
- implicit def nothingRep: TypeRep[Nothing] = NothingRep
-
- implicit def classRep[A](implicit elemrep: TypeRep[A]): TypeRep[Class[A]] =
- ClassRep(elemrep)
-
- implicit def someRep[A](implicit elemrep: TypeRep[A]): TypeRep[Some[A]] =
- SomeRep(elemrep)
-
- implicit def listRep[A](implicit elemrep: TypeRep[A]): TypeRep[List[A]] =
- ListRep(elemrep)
-
- implicit def arrayRep[A](implicit elemrep: TypeRep[A]): TypeRep[Array[A]] =
- ArrayRep(elemrep)
-
- implicit def tuple2Rep[A1, A2](implicit _1: TypeRep[A1], _2: TypeRep[A2]): TypeRep[(A1, A2)] =
- Tuple2Rep(_1, _2)
-
- implicit def tuple3Rep[A1, A2, A3](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3]): TypeRep[(A1, A2, A3)] =
- Tuple3Rep(_1, _2, _3)
- implicit def tuple4Rep[A1, A2, A3, A4](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4]): TypeRep[Tuple4[A1, A2, A3, A4]] =
- Tuple4Rep(_1, _2, _3, _4)
- implicit def tuple5Rep[A1, A2, A3, A4, A5](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5]): TypeRep[Tuple5[A1, A2, A3, A4, A5]] =
- Tuple5Rep(_1, _2, _3, _4, _5)
- implicit def tuple6Rep[A1, A2, A3, A4, A5, A6](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5], _6: TypeRep[A6]): TypeRep[Tuple6[A1, A2, A3, A4, A5, A6]] =
- Tuple6Rep(_1, _2, _3, _4, _5, _6)
- implicit def tuple7Rep[A1, A2, A3, A4, A5, A6, A7](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5], _6: TypeRep[A6], _7: TypeRep[A7]): TypeRep[Tuple7[A1, A2, A3, A4, A5, A6, A7]] =
- Tuple7Rep(_1, _2, _3, _4, _5, _6, _7)
- implicit def tuple8Rep[A1, A2, A3, A4, A5, A6, A7, A8](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5], _6: TypeRep[A6], _7: TypeRep[A7], _8: TypeRep[A8]): TypeRep[Tuple8[A1, A2, A3, A4, A5, A6, A7, A8]] =
- Tuple8Rep(_1, _2, _3, _4, _5, _6, _7, _8)
- implicit def tuple9Rep[A1, A2, A3, A4, A5, A6, A7, A8, A9](implicit _1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5], _6: TypeRep[A6], _7: TypeRep[A7], _8: TypeRep[A8], _9: TypeRep[A9]): TypeRep[Tuple9[A1, A2, A3, A4, A5, A6, A7, A8, A9]] =
- Tuple9Rep(_1, _2, _3, _4, _5, _6, _7, _8, _9)
-
- implicit def func1Rep[A1, B](implicit a1: TypeRep[A1], b: TypeRep[B]): TypeRep[Function1[A1, B]] =
- Function1Rep(a1, b)
- implicit def func2Rep[A1, A2, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], b: TypeRep[B]): TypeRep[Function2[A1, A2, B]] =
- Function2Rep(a1, a2, b)
- implicit def func3Rep[A1, A2, A3, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], b: TypeRep[B]): TypeRep[Function3[A1, A2, A3, B]] =
- Function3Rep(a1, a2, a3, b)
- implicit def func4Rep[A1, A2, A3, A4, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], b: TypeRep[B]): TypeRep[Function4[A1, A2, A3, A4, B]] =
- Function4Rep(a1, a2, a3, a4, b)
- implicit def func5Rep[A1, A2, A3, A4, A5, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], b: TypeRep[B]): TypeRep[Function5[A1, A2, A3, A4, A5, B]] =
- Function5Rep(a1, a2, a3, a4, a5, b)
- implicit def func6Rep[A1, A2, A3, A4, A5, A6, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], b: TypeRep[B]): TypeRep[Function6[A1, A2, A3, A4, A5, A6, B]] =
- Function6Rep(a1, a2, a3, a4, a5, a6, b)
- implicit def func7Rep[A1, A2, A3, A4, A5, A6, A7, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], b: TypeRep[B]): TypeRep[Function7[A1, A2, A3, A4, A5, A6, A7, B]] =
- Function7Rep(a1, a2, a3, a4, a5, a6, a7, b)
- implicit def func8Rep[A1, A2, A3, A4, A5, A6, A7, A8, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], a8: TypeRep[A8], b: TypeRep[B]): TypeRep[Function8[A1, A2, A3, A4, A5, A6, A7, A8, B]] =
- Function8Rep(a1, a2, a3, a4, a5, a6, a7, a8, b)
- implicit def func9Rep[A1, A2, A3, A4, A5, A6, A7, A8, A9, B](implicit a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], a8: TypeRep[A8], a9: TypeRep[A9], b: TypeRep[B]): TypeRep[Function9[A1, A2, A3, A4, A5, A6, A7, A8, A9, B]] =
- Function9Rep(a1, a2, a3, a4, a5, a6, a7, a8, a9, b)
-/*
- implicit def objectRep[A <: AnyRef](obj: A)(implicit rep: TypeRep[A]): TypeRep[AnyClass] =
- ObjectRep(obj.getClass)
-*/
-
- case object BooleanRep extends TypeRep[Boolean] {
- override def toString = "Boolean"
- }
- case object ByteRep extends TypeRep[Byte] {
- override def toString = "Byte"
- }
- case object CharRep extends TypeRep[Char] {
- override def toString = "Char"
- }
- case object ShortRep extends TypeRep[Short] {
- override def toString = "Short"
- }
- case object IntRep extends TypeRep[Int] {
- override def toString = "Int"
- }
- case object LongRep extends TypeRep[Long] {
- override def toString = "Long"
- }
- case object FloatRep extends TypeRep[Float] {
- override def toString = "Float"
- }
- case object DoubleRep extends TypeRep[Double] {
- override def toString = "Double"
- }
-
- case object UnitRep extends TypeRep[Unit] {
- override def toString = "Unit"
- }
-// case object ClassRep extends TypeRep[AnyClass] {
-// override def toString = "Class"
-// }
- case object StringRep extends TypeRep[String] {
- override def toString = "String"
- }
- case object NoneRep extends TypeRep[None.type] {
- override def toString = "None"
- }
- case object NilRep extends TypeRep[Nil.type] {
- override def toString = "Nil"
- }
- case object AnyRep extends TypeRep[Any] {
- override def toString = "Any"
- }
- case object NothingRep extends TypeRep[Nothing] {
- override def toString = "Nothing"
- }
-
- @serializable
- case class ClassRep[A](elemRep: TypeRep[A]) extends TypeRep[Class[A]] {
- override def toString = "Class[" + elemRep + "]"
- }
- @serializable
- case class SomeRep[A](elemRep: TypeRep[A]) extends TypeRep[Some[A]] {
- override def toString = "Some[" + elemRep + "]"
- }
- @serializable
- case class NoneRep[A](elemRep: TypeRep[A]) extends TypeRep[Option[A]] {
- override def toString = "None[" + elemRep + "]"
- }
-
- @serializable
- case class ListRep[A](elemRep: TypeRep[A]) extends TypeRep[List[A]] {
- override def toString = "List[" + elemRep + "]"
- }
-
- @serializable
- case class ArrayRep[A](elemRep: TypeRep[A]) extends TypeRep[Array[A]] {
- override def toString = "Array[" + elemRep + "]"
- }
-
- @serializable
- case class Tuple2Rep[A1, A2](_1: TypeRep[A1], _2: TypeRep[A2]) extends TypeRep[(A1, A2)] {
- override def toString = "Tuple2[" + _1 + ", " + _2 + "]"
- }
- @serializable
- case class Tuple3Rep[A1, A2, A3](_1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3]) extends TypeRep[Tuple3[A1, A2, A3]] {
- override def toString = "Tuple3[" + _1 + ", " + _2 + ", " + _3 + "]"
- }
- @serializable
- case class Tuple4Rep[A1, A2, A3, A4](_1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4]) extends TypeRep[Tuple4[A1, A2, A3, A4]] {
- override def toString = "Tuple4[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + "]"
- }
- @serializable
- case class Tuple5Rep[A1, A2, A3, A4, A5](_1: TypeRep[A1], _2: TypeRep[A2], _3: TypeRep[A3], _4: TypeRep[A4], _5: TypeRep[A5]) extends TypeRep[Tuple5[A1, A2, A3, A4, A5]] {
- override def toString = "Tuple5[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + ", " + _5 + "]"
- }
- @serializable
- case class Tuple6Rep[A1, A2, A3, A4, A5, A6](val _1: TypeRep[A1], val _2: TypeRep[A2], val _3: TypeRep[A3], val _4: TypeRep[A4], val _5: TypeRep[A5], val _6: TypeRep[A6]) extends TypeRep[Tuple6[A1, A2, A3, A4, A5, A6]] {
- override def toString = "Tuple6[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + ", " + _5 + ", " + _6 + "]"
- }
- @serializable
- case class Tuple7Rep[A1, A2, A3, A4, A5, A6, A7](val _1: TypeRep[A1], val _2: TypeRep[A2], val _3: TypeRep[A3], val _4: TypeRep[A4], val _5: TypeRep[A5], val _6: TypeRep[A6], val _7: TypeRep[A7]) extends TypeRep[Tuple7[A1, A2, A3, A4, A5, A6, A7]] {
- override def toString = "Tuple7[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + ", " + _5 + ", " + _6 + ", " + _7 + "]"
- }
- @serializable
- case class Tuple8Rep[A1, A2, A3, A4, A5, A6, A7, A8](val _1: TypeRep[A1], val _2: TypeRep[A2], val _3: TypeRep[A3], val _4: TypeRep[A4], val _5: TypeRep[A5], val _6: TypeRep[A6], val _7: TypeRep[A7], val _8: TypeRep[A8]) extends TypeRep[Tuple8[A1, A2, A3, A4, A5, A6, A7, A8]] {
- override def toString = "Tuple8[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + ", " + _5 + ", " + _6 + ", " + _7 + ", " + _8 + "]"
- }
- @serializable
- case class Tuple9Rep[A1, A2, A3, A4, A5, A6, A7, A8, A9](val _1: TypeRep[A1], val _2: TypeRep[A2], val _3: TypeRep[A3], val _4: TypeRep[A4], val _5: TypeRep[A5], val _6: TypeRep[A6], val _7: TypeRep[A7], val _8: TypeRep[A8], val _9: TypeRep[A9]) extends TypeRep[Tuple9[A1, A2, A3, A4, A5, A6, A7, A8, A9]] {
- override def toString = "Tuple9[" + _1 + ", " + _2 + ", " + _3 + ", " + _4 + ", " + _5 + ", " + _6 + ", " + _7 + ", " + _8 + ", " + _9 + "]"
- }
-
- @serializable
- case class Function1Rep[A1, B](a1: TypeRep[A1], b: TypeRep[B]) extends TypeRep[Function1[A1, B]] {
- override def toString = "Function1[" + a1 + ", " + b + "]"
- }
- @serializable
- case class Function2Rep[A1, A2, B](a1: TypeRep[A1], a2: TypeRep[A2], b: TypeRep[B]) extends TypeRep[Function2[A1, A2, B]] {
- override def toString = "Function2[" + a1 + ", " + a2 + ", " + b + "]"
- }
- @serializable
- case class Function3Rep[A1, A2, A3, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], b: TypeRep[B]) extends TypeRep[Function3[A1, A2, A3, B]] {
- override def toString = "Function3[" + a1 + ", " + a2 + ", " + a3 + ", " + b + "]"
- }
- @serializable
- case class Function4Rep[A1, A2, A3, A4, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], b: TypeRep[B]) extends TypeRep[Function4[A1, A2, A3, A4, B]] {
- override def toString = "Function4[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + b + "]"
- }
- @serializable
- case class Function5Rep[A1, A2, A3, A4, A5, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], b: TypeRep[B]) extends TypeRep[Function5[A1, A2, A3, A4, A5, B]] {
- override def toString = "Function5[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + a5 + ", " + b + "]"
- }
- @serializable
- case class Function6Rep[A1, A2, A3, A4, A5, A6, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], b: TypeRep[B]) extends TypeRep[Function6[A1, A2, A3, A4, A5, A6, B]] {
- override def toString = "Function6[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + a5 + ", " + a6 + ", " + b + "]"
- }
- @serializable
- case class Function7Rep[A1, A2, A3, A4, A5, A6, A7, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], b: TypeRep[B]) extends TypeRep[Function7[A1, A2, A3, A4, A5, A6, A7, B]] {
- override def toString = "Function7[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + a5 + ", " + a6 + ", " + a7 + ", " + b + "]"
- }
- @serializable
- case class Function8Rep[A1, A2, A3, A4, A5, A6, A7, A8, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], a8: TypeRep[A8], b: TypeRep[B]) extends TypeRep[Function8[A1, A2, A3, A4, A5, A6, A7, A8, B]] {
- override def toString = "Function8[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + a5 + ", " + a6 + ", " + a7 + ", " + a8 + b + "]"
- }
- @serializable
- case class Function9Rep[A1, A2, A3, A4, A5, A6, A7, A8, A9, B](a1: TypeRep[A1], a2: TypeRep[A2], a3: TypeRep[A3], a4: TypeRep[A4], a5: TypeRep[A5], a6: TypeRep[A6], a7: TypeRep[A7], a8: TypeRep[A8], a9: TypeRep[A9], b: TypeRep[B]) extends TypeRep[Function9[A1, A2, A3, A4, A5, A6, A7, A8, A9, B]] {
- override def toString = "Function9[" + a1 + ", " + a2 + ", " + a3 + ", " + a4 + ", " + a5 + ", " + a6 + ", " + a7 + ", " + a8 + ", " + b + "]"
- }
-/*
- @serializable
- case class ObjectRep[A](c: Class) extends TypeRep[A] {
- override def toString = c.getName
- }
-*/
-}
-
diff --git a/test/files/pos5/chang/Outer.java b/test/files/pos/chang/Outer.java
index acdb4e2904..acdb4e2904 100644
--- a/test/files/pos5/chang/Outer.java
+++ b/test/files/pos/chang/Outer.java
diff --git a/test/files/pos5/chang/Test.scala b/test/files/pos/chang/Test.scala
index 9bb745e377..9bb745e377 100644
--- a/test/files/pos5/chang/Test.scala
+++ b/test/files/pos/chang/Test.scala
diff --git a/test/files/pos5/ilya/J.java b/test/files/pos/ilya/J.java
index c44169ca1b..c44169ca1b 100644
--- a/test/files/pos5/ilya/J.java
+++ b/test/files/pos/ilya/J.java
diff --git a/test/files/pos5/ilya/S.scala b/test/files/pos/ilya/S.scala
index 952c004ccc..952c004ccc 100644
--- a/test/files/pos5/ilya/S.scala
+++ b/test/files/pos/ilya/S.scala
diff --git a/test/files/pos5/ilya2/A.scala b/test/files/pos/ilya2/A.scala
index 923b50f04d..923b50f04d 100644
--- a/test/files/pos5/ilya2/A.scala
+++ b/test/files/pos/ilya2/A.scala
diff --git a/test/files/pos5/ilya2/B.java b/test/files/pos/ilya2/B.java
index 4771493fdd..4771493fdd 100644
--- a/test/files/pos5/ilya2/B.java
+++ b/test/files/pos/ilya2/B.java
diff --git a/test/files/pos5/ilya2/Nullable.java b/test/files/pos/ilya2/Nullable.java
index ebbb013d7e..ebbb013d7e 100644
--- a/test/files/pos5/ilya2/Nullable.java
+++ b/test/files/pos/ilya2/Nullable.java
diff --git a/test/files/pos5/signatures/Test.java b/test/files/pos/signatures/Test.java
index 8ecac29910..8ecac29910 100644
--- a/test/files/pos5/signatures/Test.java
+++ b/test/files/pos/signatures/Test.java
diff --git a/test/files/pos5/signatures/sig.scala b/test/files/pos/signatures/sig.scala
index 4236f27bed..4236f27bed 100644
--- a/test/files/pos5/signatures/sig.scala
+++ b/test/files/pos/signatures/sig.scala
diff --git a/test/files/pos5/t0695/JavaClass.java b/test/files/pos/t0695/JavaClass.java
index a765f7e324..a765f7e324 100644
--- a/test/files/pos5/t0695/JavaClass.java
+++ b/test/files/pos/t0695/JavaClass.java
diff --git a/test/files/pos5/t0695/Test.scala b/test/files/pos/t0695/Test.scala
index 7318867bf7..7318867bf7 100644
--- a/test/files/pos5/t0695/Test.scala
+++ b/test/files/pos/t0695/Test.scala
diff --git a/test/files/pos5/t1101/J.java b/test/files/pos/t1101/J.java
index 2bc1d53e09..2bc1d53e09 100644
--- a/test/files/pos5/t1101/J.java
+++ b/test/files/pos/t1101/J.java
diff --git a/test/files/pos5/t1101/S.scala b/test/files/pos/t1101/S.scala
index af7a591e58..af7a591e58 100644
--- a/test/files/pos5/t1101/S.scala
+++ b/test/files/pos/t1101/S.scala
diff --git a/test/files/pos5/t1102/J.java b/test/files/pos/t1102/J.java
index 530102b91c..530102b91c 100644
--- a/test/files/pos5/t1102/J.java
+++ b/test/files/pos/t1102/J.java
diff --git a/test/files/pos5/t1102/S.scala b/test/files/pos/t1102/S.scala
index 9beee8d901..9beee8d901 100644
--- a/test/files/pos5/t1102/S.scala
+++ b/test/files/pos/t1102/S.scala
diff --git a/test/files/pos5/t1150/J.java b/test/files/pos/t1150/J.java
index 68fa04a178..68fa04a178 100644
--- a/test/files/pos5/t1150/J.java
+++ b/test/files/pos/t1150/J.java
diff --git a/test/files/pos5/t1150/S.scala b/test/files/pos/t1150/S.scala
index 41dd064037..41dd064037 100644
--- a/test/files/pos5/t1150/S.scala
+++ b/test/files/pos/t1150/S.scala
diff --git a/test/files/pos5/t1152/J.java b/test/files/pos/t1152/J.java
index 6e562e573d..6e562e573d 100644
--- a/test/files/pos5/t1152/J.java
+++ b/test/files/pos/t1152/J.java
diff --git a/test/files/pos5/t1152/S.scala b/test/files/pos/t1152/S.scala
index 7f751c5090..7f751c5090 100644
--- a/test/files/pos5/t1152/S.scala
+++ b/test/files/pos/t1152/S.scala
diff --git a/test/files/pos5/t1176/J.java b/test/files/pos/t1176/J.java
index 0d82c75fcb..0d82c75fcb 100644
--- a/test/files/pos5/t1176/J.java
+++ b/test/files/pos/t1176/J.java
diff --git a/test/files/pos5/t1176/S.scala b/test/files/pos/t1176/S.scala
index a7fc3e0cea..a7fc3e0cea 100644
--- a/test/files/pos5/t1176/S.scala
+++ b/test/files/pos/t1176/S.scala
diff --git a/test/files/pos5/t1186/t1186.java b/test/files/pos/t1186/t1186.java
index c1bfcecab8..c1bfcecab8 100644
--- a/test/files/pos5/t1186/t1186.java
+++ b/test/files/pos/t1186/t1186.java
diff --git a/test/files/pos5/t1196/J.java b/test/files/pos/t1196/J.java
index 2ec7a711bb..2ec7a711bb 100644
--- a/test/files/pos5/t1196/J.java
+++ b/test/files/pos/t1196/J.java
diff --git a/test/files/pos5/t1196/S.scala b/test/files/pos/t1196/S.scala
index f17cd249a7..f17cd249a7 100644
--- a/test/files/pos5/t1196/S.scala
+++ b/test/files/pos/t1196/S.scala
diff --git a/test/files/pos5/t1197/J.java b/test/files/pos/t1197/J.java
index b4e0a4255c..b4e0a4255c 100644
--- a/test/files/pos5/t1197/J.java
+++ b/test/files/pos/t1197/J.java
diff --git a/test/files/pos5/t1197/S.scala b/test/files/pos/t1197/S.scala
index 7c9c15440f..7c9c15440f 100644
--- a/test/files/pos5/t1197/S.scala
+++ b/test/files/pos/t1197/S.scala
diff --git a/test/files/pos5/t1203/J.java b/test/files/pos/t1203/J.java
index 7fae118e04..7fae118e04 100644
--- a/test/files/pos5/t1203/J.java
+++ b/test/files/pos/t1203/J.java
diff --git a/test/files/pos5/t1203/S.scala b/test/files/pos/t1203/S.scala
index 68eac4bf6d..68eac4bf6d 100644
--- a/test/files/pos5/t1203/S.scala
+++ b/test/files/pos/t1203/S.scala
diff --git a/test/files/pos5/t1230/J.java b/test/files/pos/t1230/J.java
index 35aefd2505..35aefd2505 100644
--- a/test/files/pos5/t1230/J.java
+++ b/test/files/pos/t1230/J.java
diff --git a/test/files/pos5/t1230/S.scala b/test/files/pos/t1230/S.scala
index f8a691b6de..f8a691b6de 100644
--- a/test/files/pos5/t1230/S.scala
+++ b/test/files/pos/t1230/S.scala
diff --git a/test/files/pos5/t1231/J.java b/test/files/pos/t1231/J.java
index 1dfc9490eb..1dfc9490eb 100644
--- a/test/files/pos5/t1231/J.java
+++ b/test/files/pos/t1231/J.java
diff --git a/test/files/pos5/t1231/S.scala b/test/files/pos/t1231/S.scala
index ee08866e04..ee08866e04 100644
--- a/test/files/pos5/t1231/S.scala
+++ b/test/files/pos/t1231/S.scala
diff --git a/test/files/pos5/t1232/J.java b/test/files/pos/t1232/J.java
index af3aad928d..af3aad928d 100755
--- a/test/files/pos5/t1232/J.java
+++ b/test/files/pos/t1232/J.java
diff --git a/test/files/pos5/t1232/J2.java b/test/files/pos/t1232/J2.java
index dc117d360f..dc117d360f 100755
--- a/test/files/pos5/t1232/J2.java
+++ b/test/files/pos/t1232/J2.java
diff --git a/test/files/pos5/t1232/S.scala b/test/files/pos/t1232/S.scala
index 1b6bca7327..1b6bca7327 100755
--- a/test/files/pos5/t1232/S.scala
+++ b/test/files/pos/t1232/S.scala
diff --git a/test/files/pos5/t1235/Test.java b/test/files/pos/t1235/Test.java
index 7bb83a8491..7bb83a8491 100644
--- a/test/files/pos5/t1235/Test.java
+++ b/test/files/pos/t1235/Test.java
diff --git a/test/files/pos5/t1254/t1254.java b/test/files/pos/t1254/t1254.java
index 25b733cf28..25b733cf28 100644
--- a/test/files/pos5/t1254/t1254.java
+++ b/test/files/pos/t1254/t1254.java
diff --git a/test/files/pos5/t1263/Test.java b/test/files/pos/t1263/Test.java
index 0eb43e881a..0eb43e881a 100644
--- a/test/files/pos5/t1263/Test.java
+++ b/test/files/pos/t1263/Test.java
diff --git a/test/files/pos5/t1263/test.scala b/test/files/pos/t1263/test.scala
index 92d8c1cdfa..92d8c1cdfa 100644
--- a/test/files/pos5/t1263/test.scala
+++ b/test/files/pos/t1263/test.scala
diff --git a/test/files/pos5/t1711/Seq.scala b/test/files/pos/t1711/Seq.scala
index c18f05cd73..c18f05cd73 100644
--- a/test/files/pos5/t1711/Seq.scala
+++ b/test/files/pos/t1711/Seq.scala
diff --git a/test/files/pos5/t1711/Test.java b/test/files/pos/t1711/Test.java
index 5ec0f2297c..5ec0f2297c 100644
--- a/test/files/pos5/t1711/Test.java
+++ b/test/files/pos/t1711/Test.java
diff --git a/test/pending/jvm5/annotations.scala b/test/pending/jvm/annotations.scala
index 98b82edad4..98b82edad4 100644
--- a/test/pending/jvm5/annotations.scala
+++ b/test/pending/jvm/annotations.scala
diff --git a/test/pending/jvm5/t1464.check b/test/pending/jvm/t1464.check
index c508d5366f..c508d5366f 100644
--- a/test/pending/jvm5/t1464.check
+++ b/test/pending/jvm/t1464.check
diff --git a/test/pending/pos5/misc/A.java b/test/pending/pos/misc/A.java
index bc8ea48dd0..bc8ea48dd0 100644
--- a/test/pending/pos5/misc/A.java
+++ b/test/pending/pos/misc/A.java
diff --git a/test/pending/pos5/misc/B.scala b/test/pending/pos/misc/B.scala
index a6889e3c8b..a6889e3c8b 100644
--- a/test/pending/pos5/misc/B.scala
+++ b/test/pending/pos/misc/B.scala
diff --git a/test/pending/pos5/misc/J.java b/test/pending/pos/misc/J.java
index 4805791154..4805791154 100644
--- a/test/pending/pos5/misc/J.java
+++ b/test/pending/pos/misc/J.java
diff --git a/test/pending/pos5/misc/S.scala b/test/pending/pos/misc/S.scala
index c5bfb26f18..c5bfb26f18 100644
--- a/test/pending/pos5/misc/S.scala
+++ b/test/pending/pos/misc/S.scala
diff --git a/test/pending/pos5/t1745/J.java b/test/pending/pos/t1745/J.java
index 8444eabb24..8444eabb24 100644
--- a/test/pending/pos5/t1745/J.java
+++ b/test/pending/pos/t1745/J.java
diff --git a/test/pending/pos5/t1745/S.scala b/test/pending/pos/t1745/S.scala
index 70210ba502..70210ba502 100644
--- a/test/pending/pos5/t1745/S.scala
+++ b/test/pending/pos/t1745/S.scala