summaryrefslogtreecommitdiff
path: root/test/files/pos/test5.scala
blob: 4dbafc9ac39489ae7d93402be21e8773f1773ec3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import scala._;

object test {

  trait F[If] {}

  def f[Jf](h: Jf):F[Jf] = f[Jf](h);

  trait G[Ig] {}

  def g[Jg](h: Jg):G[Jg] = g[Jg](h);

  class M[P]() {
      abstract class I[X]() {
	  // Methods to check the type X and P as seen from instances of I
	  def chk_ix(x: X): Unit = ();
	  def chk_ip(p: P): Unit;

	  // Value with type X as seen from instances of I
	  def val_ix: X = val_ix;
      }

      val i:I[G[P]] = null;

      // Values with types P and i.X as seen from instances of M
      def val_mp: P = val_mp;
      def val_mix: G[P] = g[P](val_mp);
  }

  class N[Q]() extends M[F[Q]]() {
      val j:J[G[Q]] = null;

      abstract class J[Y]() extends I[G[Y]]() {
	  // Values with types Y and X as seen from instances of J
	  def val_jy: Y = val_jy;
	  def val_jx: G[Y] = g[Y](val_jy);

	  // Check type P
	  chk_ip(val_mp);
	  chk_ip(val_np);
      }

      // Values with types Q, X.P, i.X, j.Y and j.X as seen from instances of N
      def val_nq: Q = val_nq;
      def val_np: F[Q] = f[Q](val_nq);
      def val_nix: G[F[Q]] = g[F[Q]](val_np);
      def val_njy: G[Q] = g[Q](val_nq);
      def val_njx: G[G[Q]] = g[G[Q]](val_njy);

      // Check type i.P
      i.chk_ip(val_mp);
      i.chk_ip(val_np);

      // Check type j.P
      j.chk_ip(val_mp);
      j.chk_ip(val_np);

      // Check type i.X
      i.chk_ix(i.val_ix);
      i.chk_ix(val_mix);
      i.chk_ix(val_nix);

      // Check j.X
      j.chk_ix(j.val_ix);
      j.chk_ix(j.val_jx);
      j.chk_ix(val_njx);
  }
}