blob: 2c701150e4bd5c6bb5083332e62def7efe632db9 (
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
|
/* The problem here is that we cannot insert an implicit to
* add a polymorphic method which is then instantiated to the
* right type. When searching for the implicit in the `fails to compile
* line':
*
* val failure = 1.0 + new Op[Int]
*
* we reduce the problem to finding a function from Double to
* {+: _ >: Op[Int] <: Any}, that is, a method which takes
* an argument which is an Op[Int] or a supertype thereof.
* Class Rich is not a subtype of this structural record, because
* polymorphic method instantiation is not contained in subtyping.
* That is: The method type [I](op : Op[I]): Op[I] is not a subtype
* of (Op[Int]): Op[Int].
* At present it is unclear whether this problem can be solved.
*/
object Test {
class Op[I];
class IntOp extends Op[Int];
class Rich(x : Double) {
def + (op : IntOp): IntOp = op;
def + [I](op : Op[I]): Op[I] = op;
def plus [I](op : Op[I]): Op[I] = op;
}
implicit def iToRich(x : Double) =
new Rich(x);
// fails to compile
val x = 1.0 + new Op[Int]
// works as expected --
// problem isn't in adding new "+"
val a = 1.0 + new IntOp;
// works as expected --
// problem isn't in binding type variable I
val b = 1.0 plus new Op[Int];
// works as expected --
// problem isn't in using Rich.+[I](op : Op[I])
val c = iToRich(1.0) + new Op[Int];
}
|