Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Scala (https://www.scala-lang.org)
*
* Copyright EPFL and Lightbend, Inc.
*
* Licensed under Apache License 2.0
* (http://www.apache.org/licenses/LICENSE-2.0).
*
* See the NOTICE file distributed with this work for
* additional information regarding copyright ownership.
*/
package scala.collection
package generic
import IsMap.Tupled
import scala.collection.immutable.{IntMap, LongMap}
/**
* Type class witnessing that a collection type `Repr`
* has keys of type `K`, values of type `V` and has a conversion to
* `MapOps[K, V, Iterable, C]`, for some types `K`, `V` and `C`.
*
* This type enables simple enrichment of `Map`s with extension methods.
*
* @see [[scala.collection.generic.IsIterable]]
* @tparam Repr Collection type (e.g. `Map[Int, String]`)
*/
trait IsMap[Repr] extends IsIterable[Repr] {
/** The type of keys */
type K
/** The type of values */
type V
type A = (K, V)
/** A conversion from the type `Repr` to `MapOps[K, V, Iterable, C]`
*
* @note The third type parameter of the returned `MapOps` value is
* still `Iterable` (and not `Map`) because `MapView[K, V]` only
* extends `MapOps[K, V, View, View[A]]`.
*/
override def apply(c: Repr): MapOps[K, V, Tupled[Iterable]#Ap, C]
}
object IsMap {
/** Convenient type level function that takes a unary type constructor `F[_]`
* and returns a binary type constructor that tuples its parameters and passes
* them to `F`.
*
* `Tupled[F]#Ap` is equivalent to `({ type Ap[X, +Y] = F[(X, Y)] })#Ap`.
*/
type Tupled[F[+_]] = { type Ap[X, Y] = F[(X, Y)] }
// Map collections
implicit def mapOpsIsMap[CC0[X, Y] <: MapOps[X, Y, Tupled[Iterable]#Ap, CC0[X, Y]], K0, V0]: IsMap[CC0[K0, V0]] { type K = K0; type V = V0; type C = CC0[K, V] } =
new IsMap[CC0[K0, V0]] {
type K = K0
type V = V0
type C = CC0[K0, V0]
def apply(c: CC0[K0, V0]): MapOps[K0, V0, Tupled[Iterable]#Ap, C] = c
}
// MapView
implicit def mapViewIsMap[CC0[X, Y] <: MapView[X, Y], K0, V0]: IsMap[CC0[K0, V0]] { type K = K0; type V = V0; type C = View[(K0, V0)] } =
new IsMap[CC0[K0, V0]] {
type K = K0
type V = V0
type C = View[(K, V)]
def apply(c: CC0[K0, V0]): MapOps[K0, V0, Tupled[Iterable]#Ap, View[(K0, V0)]] = c
}
// AnyRefMap has stricter bounds than the ones used by the mapOpsIsMap definition
implicit def anyRefMapIsMap[K0 <: AnyRef, V0]: IsMap[mutable.AnyRefMap[K0, V0]] { type K = K0; type V = V0; type C = mutable.AnyRefMap[K0, V0] } =
new IsMap[mutable.AnyRefMap[K0, V0]] {
type K = K0
type V = V0
type C = mutable.AnyRefMap[K0, V0]
def apply(c: mutable.AnyRefMap[K0, V0]): MapOps[K0, V0, Tupled[Iterable]#Ap, mutable.AnyRefMap[K0, V0]] = c
}
// IntMap takes one type parameter only whereas mapOpsIsMap uses a parameter CC0 with two type parameters
implicit def intMapIsMap[V0]: IsMap[IntMap[V0]] { type K = Int; type V = V0; type C = IntMap[V0] } =
new IsMap[IntMap[V0]] {
type K = Int
type V = V0
type C = IntMap[V0]
def apply(c: IntMap[V0]): MapOps[Int, V0, Tupled[Iterable]#Ap, IntMap[V0]] = c
}
// LongMap is in a similar situation as IntMap
implicit def longMapIsMap[V0]: IsMap[LongMap[V0]] { type K = Long; type V = V0; type C = LongMap[V0] } =
new IsMap[LongMap[V0]] {
type K = Long
type V = V0
type C = LongMap[V0]
def apply(c: LongMap[V0]): MapOps[Long, V0, Tupled[Iterable]#Ap, LongMap[V0]] = c
}
// mutable.LongMap is in a similar situation as LongMap and IntMap
implicit def mutableLongMapIsMap[V0]: IsMap[mutable.LongMap[V0]] { type K = Long; type V = V0; type C = mutable.LongMap[V0] } =
new IsMap[mutable.LongMap[V0]] {
type K = Long
type V = V0
type C = mutable.LongMap[V0]
def apply(c: mutable.LongMap[V0]): MapOps[Long, V0, Tupled[Iterable]#Ap, mutable.LongMap[V0]] = c
}
}