File: t4063.scala

package info (click to toggle)
scala 2.11.12-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 62,924 kB
  • sloc: javascript: 28,808; java: 13,415; xml: 3,135; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (39 lines) | stat: -rw-r--r-- 1,150 bytes parent folder | download | duplicates (4)
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
trait Parallel
trait Parallelizable[+ParRepr <: Parallel]

trait PIterableLike[+T, +Repr <: Parallel] extends Parallel with Parallelizable[PIterableLike[T, Repr]]

trait PMap[K, V] extends PIterableLike[(K, V), PMap[K, V]]
trait PSet[T] extends PIterableLike[T, PSet[T]]

trait CIterableLike[+T, +Repr]

trait CSet[T] extends CIterableLike[T, CSet[T]] with Parallelizable[PSet[T]]

trait CMap[K, V] extends CIterableLike[(K, V), CMap[K, V]] with Parallelizable[PMap[K, V]]

object Test {
  var x = 0

  def main() {
    val map: CMap[Int, CSet[Int]] = new CMap[Int, CSet[Int]] {}
    val set: CSet[Int] = new CSet[Int] {}

    // should infer type argument
    //map.synchronized[CIterableLike[Any, Any] with Parallelizable[PIterableLike[Any, Parallel with Parallelizable[Parallel]]]] {
    // or:
    //map.synchronized[CIterableLike[Any, Any] with Parallelizable[PIterableLike[Any, Parallel]]] {
    // or, maybe it could also infer existential types:
    //map.synchronized[CIterableLike[Any, _] with Parallelizable[PIterableLike[Any, _]]] {

    map.synchronized {
      if (x == 0) {
        map
      } else {
        set
      }
    }

  }
}