Scala Library: scala.collection.mutable.SortedSet
scala.collection.mutable.SortedSet
object SortedSet extends MutableSortedSetFactory[SortedSet]A template for mutable sorted set companion objects.
Type Members
type Coll = SortedSet[_]
- Definition Classes
- SortedSetFactory
class SortedSetCanBuildFrom[A] extends CanBuildFrom[Coll, A, CC[A]]
- Definition Classes
- SortedSetFactory
Value Members From scala.collection.generic.MutableSortedSetFactory
def newBuilder[A](implicit ord: Ordering[A]): Builder[A, SortedSet[A]]
mutable.SetBuilder uses ‘+’ which is not a primitive for anything extending mutable.SetLike, this causes serious performance issues since each time ‘elems = elems + x’ is evaluated elems is cloned (which is O(n)).
Fortunately GrowingBuilder comes to rescue.
- Definition Classes
- MutableSortedSetFactory → SortedSetFactory
(defined at scala.collection.generic.MutableSortedSetFactory)
Value Members From scala.collection.generic.SortedSetFactory
def apply[A](elems: A*)(implicit ord: Ordering[A]): SortedSet[A]
- Definition Classes
- SortedSetFactory
(defined at scala.collection.generic.SortedSetFactory)
Value Members From scala.collection.mutable.SortedSet
def canBuildFrom[A](implicit ord: Ordering[A]): CanBuildFrom[Coll, A, SortedSet[A]]
(defined at scala.collection.mutable.SortedSet)
def empty[A](implicit ord: Ordering[A]): SortedSet[A]
- Definition Classes
- SortedSet → SortedSetFactory
(defined at scala.collection.mutable.SortedSet)
implicit def newCanBuildFrom[A](implicit ord: Ordering[A]): CanBuildFrom[Coll, A, SortedSet[A]]
- Definition Classes
- SortedSet → SortedSetFactory (defined at scala.collection.mutable.SortedSet)
Full Source:
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala
package collection
package mutable
import generic._
/**
* Base trait for mutable sorted set.
*
* @define Coll `mutable.SortedSet`
* @define coll mutable sorted set
*
* @author Lucien Pereira
*
*/
trait SortedSet[A] extends scala.collection.SortedSet[A] with scala.collection.SortedSetLike[A,SortedSet[A]]
with mutable.Set[A] with mutable.SetLike[A, SortedSet[A]] {
/** Needs to be overridden in subclasses. */
override def empty: SortedSet[A] = SortedSet.empty[A]
}
/**
* A template for mutable sorted set companion objects.
*
* @define Coll `mutable.SortedSet`
* @define coll mutable sorted set
* @define factoryInfo
* This object provides a set of operations needed to create sorted sets of type mutable.SortedSet.
* @define sortedSetCanBuildFromInfo
* Standard `CanBuildFrom` instance for sorted sets.
*
* @author Lucien Pereira
*
*/
object SortedSet extends MutableSortedSetFactory[SortedSet] {
def canBuildFrom[A](implicit ord: Ordering[A]): CanBuildFrom[Coll, A, SortedSet[A]] = new SortedSetCanBuildFrom[A]
def empty[A](implicit ord: Ordering[A]): SortedSet[A] = TreeSet.empty[A]
// Force a declaration here so that BitSet (which does not inherit from SortedSetFactory) can be more specific
override implicit def newCanBuildFrom[A](implicit ord : Ordering[A]): CanBuildFrom[Coll, A, SortedSet[A]] = super.newCanBuildFrom
}
/** Explicit instantiation of the `SortedSet` trait to reduce class file size in subclasses. */
abstract class AbstractSortedSet[A] extends scala.collection.mutable.AbstractSet[A] with SortedSet[A]Interested in Scala?
I send out weekly, personalized emails with articles and conference talks.
Subscribe now.