diff options
Diffstat (limited to 'src/library/scala/collection/mutable/ImmutableSetAdaptor.scala')
-rw-r--r-- | src/library/scala/collection/mutable/ImmutableSetAdaptor.scala | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/library/scala/collection/mutable/ImmutableSetAdaptor.scala b/src/library/scala/collection/mutable/ImmutableSetAdaptor.scala new file mode 100644 index 0000000000..623074b3d9 --- /dev/null +++ b/src/library/scala/collection/mutable/ImmutableSetAdaptor.scala @@ -0,0 +1,50 @@ +/* __ *\ +** ________ ___ / / ___ Scala API ** +** / __/ __// _ | / / / _ | (c) 2003, LAMP/EPFL ** +** __\ \/ /__/ __ |/ /__/ __ | ** +** /____/\___/_/ |_/____/_/ | | ** +** |/ ** +** $Id$ +\* */ + +package scala.collection.mutable; + + +/** This class can be used as an adaptor to create mutable sets from + * immutable set implementations. Only method <code>empty</code> has + * to be redefined if the immutable set on which this mutable set is + * originally based is not empty. <code>empty</code> is supposed to + * return the representation of an empty set. + * + * @author Matthias Zenger + * @version 1.0, 21/07/2003 + */ +[serializable] +class ImmutableSetAdaptor[A](s: scala.collection.immutable.Set[A]) extends Set[A] { + + protected var set = s; + + def size: Int = set.size; + + override def isEmpty: Boolean = set.isEmpty; + + def contains(elem: A): Boolean = set.contains(elem); + + override def foreach(f: A => Unit): Unit = set.foreach(f); + + override def exists(p: A => Boolean): Boolean = set.exists(p); + + override def toList: List[A] = set.toList; + + override def toString() = set.toString(); + + def elements: Iterator[A] = set.elements; + + def +=(elem: A): Unit = { set = set + elem; } + + def -=(elem: A): Unit = { set = set - elem; } + + def clear: Unit = { set = empty; } + + protected def empty: scala.collection.immutable.Set[A] = s; +} |