summaryrefslogtreecommitdiff
path: root/test/files/neg/unchecked-abstract.scala
blob: 23c8281ca82d4e755a95798374c3c83abb51e958 (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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
trait Contravariant[-X]
trait Invariant[X]
trait Covariant[+X]

abstract class M {
  type H
  type L <: H
  type T >: L <: H

  def h1(x: Contravariant[H]) = {
    /* nowarn */ println(x.isInstanceOf[Contravariant[H]])
    /* nowarn */ println(x.isInstanceOf[Contravariant[T]])
    /* nowarn */ println(x.isInstanceOf[Contravariant[L]])
  }
  def h2(x: Contravariant[T]) = {
    /*   warn */ println(x.isInstanceOf[Contravariant[H]])
    /* nowarn */ println(x.isInstanceOf[Contravariant[T]])
    /* nowarn */ println(x.isInstanceOf[Contravariant[L]])
  }
  def h3(x: Contravariant[L]) = {
    /*   warn */ println(x.isInstanceOf[Contravariant[H]])
    /*   warn */ println(x.isInstanceOf[Contravariant[T]])
    /* nowarn */ println(x.isInstanceOf[Contravariant[L]])
  }
  def h4(x: Invariant[H]) = {
    /* nowarn */ println(x.isInstanceOf[Invariant[H]])
    /*   warn */ println(x.isInstanceOf[Invariant[T]])
    /*   warn */ println(x.isInstanceOf[Invariant[L]])
  }
  def h5(x: Invariant[T]) = {
    /*   warn */ println(x.isInstanceOf[Invariant[H]])
    /* nowarn */ println(x.isInstanceOf[Invariant[T]])
    /*   warn */ println(x.isInstanceOf[Invariant[L]])
  }
  def h6(x: Invariant[L]) = {
    /*   warn */ println(x.isInstanceOf[Invariant[H]])
    /*   warn */ println(x.isInstanceOf[Invariant[T]])
    /* nowarn */ println(x.isInstanceOf[Invariant[L]])
  }
  def h7(x: Covariant[H]) = {
    /* nowarn */ println(x.isInstanceOf[Covariant[H]])
    /*   warn */ println(x.isInstanceOf[Covariant[T]])
    /*   warn */ println(x.isInstanceOf[Covariant[L]])
  }
  def h8(x: Covariant[T]) = {
    /* nowarn */ println(x.isInstanceOf[Covariant[H]])
    /* nowarn */ println(x.isInstanceOf[Covariant[T]])
    /*   warn */ println(x.isInstanceOf[Covariant[L]])
  }
  def h9(x: Covariant[L]) = {
    /* nowarn */ println(x.isInstanceOf[Covariant[H]])
    /* nowarn */ println(x.isInstanceOf[Covariant[T]])
    /* nowarn */ println(x.isInstanceOf[Covariant[L]])
  }
}

object Test extends M {
  type H = Any
  type T = Int
  type L = Nothing

  val conh = new Contravariant[H] { }
  val cont = new Contravariant[T] { }
  val conl = new Contravariant[L] { }

  val invh = new Invariant[H] { }
  val invt = new Invariant[T] { }
  val invl = new Invariant[L] { }

  val covh = new Covariant[H] { }
  val covt = new Covariant[T] { }
  val covl = new Covariant[L] { }

  def main(args: Array[String]): Unit = {
    h1(conh)
    h2(conh)
    h2(cont)
    h3(conh)
    h3(cont)
    h3(conl)

    h4(invh)
    h5(invt)
    h6(invl)

    h7(covh)
    h7(covt)
    h7(covl)
    h8(covt)
    h8(covl)
    h9(covl)
  }
}