summaryrefslogtreecommitdiff
path: root/test/pending/pos/t1756.scala
blob: c22d5509e17f83576565c216fda465f4842911b7 (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
trait Ring[T <: Ring[T]] {
  def +(that: T): T
  def *(that: T): T
}

class A extends Ring[A] {
  def +(that: A) = new A
  def *(that: A) = new A
}

class Poly[C <: Ring[C]](val c: C) extends Ring[Poly[C]] {
  def +(that: Poly[C]) = new Poly(this.c+that.c)
  def *(that: Poly[C]) = new Poly(this.c*that.c)
}

implicit def coef2poly[C <: Ring[C]](c: C) = new Poly(c)

val a = new A
val x = new Poly(new A)

x+a // works
a+x // works

val y = new Poly(new Poly(new A))

x+y*x // works
x*y+x // works
y*x+x // works

x+x*y