aboutsummaryrefslogtreecommitdiff
path: root/tests/pickling
diff options
context:
space:
mode:
authorMartin Odersky <odersky@gmail.com>2016-04-09 12:28:06 +0200
committerMartin Odersky <odersky@gmail.com>2016-04-09 12:29:14 +0200
commit6942127668d0c9fe60e4b11d952adf2f7e1fee72 (patch)
tree0c3f7c0e0b976ff78d15e77feb640bbde52b99c8 /tests/pickling
parent0907f5bd5cc9f57b01c5b73403463c20b857d632 (diff)
downloaddotty-6942127668d0c9fe60e4b11d952adf2f7e1fee72.tar.gz
dotty-6942127668d0c9fe60e4b11d952adf2f7e1fee72.tar.bz2
dotty-6942127668d0c9fe60e4b11d952adf2f7e1fee72.zip
Rearrange pickle tests
1) Move passing test to pickling 2) Add test case for #1212 in pending 3) Disable annotations/internal in pickling tests. They lead to a stable symbol error which is explainable (modifiers are read before symbol is created).
Diffstat (limited to 'tests/pickling')
-rw-r--r--tests/pickling/i94-nada.scala45
1 files changed, 45 insertions, 0 deletions
diff --git a/tests/pickling/i94-nada.scala b/tests/pickling/i94-nada.scala
new file mode 100644
index 000000000..ce8dc98ad
--- /dev/null
+++ b/tests/pickling/i94-nada.scala
@@ -0,0 +1,45 @@
+package i94
+
+import scala.language.higherKinds
+
+trait Base {
+ type Rep[T]
+}
+
+trait BaseExp extends Base {
+ type Rep[T] = Exp[T]
+ case class Exp[T](v: T)
+}
+
+trait BaseStr extends Base {
+ type Rep[T] = String
+}
+
+trait BaseDirect extends Base {
+ type Rep[T] = T
+}
+
+trait Test1 {
+ trait Monad[X] {
+ def x: X
+ }
+ sealed abstract class Either[A,B]
+ case class Left[A,B](x: A) extends Either[A,B] with Monad[A]
+ case class Right[A,B](x: B) extends Either[A,B] with Monad[B]
+ def flatMap[X,Y,M[X]<:Monad[X]](m: M[X], f: X => M[Y]): M[Y] = f(m.x)
+ println(flatMap(Left(1), {x: Int => Left(x)}))
+}
+trait Test2 {
+ trait Monad[X] {
+ def x: X
+ }
+ sealed abstract class Either[A,B]
+ case class Left[A,B](x: A) extends Either[A,B] with Monad[A]
+ case class Right[A,B](x: B) extends Either[A,B] with Monad[B]
+ def flatMap[X,Y,M[X]](m: M[X], f: X => M[Y]): M[Y]
+ println(flatMap(Left(1), {x: Int => Left(x)}))
+}
+trait Test3 {
+ def flatMap[X,Y,M[X]](m: M[X], f: X => M[Y]): M[Y]
+ println(flatMap(Some(1), {x: Int => Some(x)}))
+}