blob: 8c9be4d5c4ef6f990a17200c74840c46798629c5 (
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
|
trait Builder[C[_], T] {
def +=(x: T)
def finalise: C[T]
}
trait Buildable[C[_]] {
def builder[T]: Builder[C,T]
}
object Test {
implicit object buildableList extends Buildable[List] {
def builder[T] = new Builder[List,T] {
val buf = new scala.collection.mutable.ListBuffer[T]
def +=(x: T) = buf += x
def finalise = buf.toList
}
}
def foo[C[_],T](x: T)(implicit b: Buildable[C]): C[T] = {
val builder = b.builder[T]
builder += x
builder.finalise
}
val l: List[Int] = foo(8)
}
|