diff options
author | Martin Odersky <odersky@gmail.com> | 2010-03-19 17:35:58 +0000 |
---|---|---|
committer | Martin Odersky <odersky@gmail.com> | 2010-03-19 17:35:58 +0000 |
commit | c059e09cc7fee862e605c4d4d054447bc460aa2a (patch) | |
tree | 3f74ebdfc248e7fa2f7a43151ff0c771a9699909 /src/library/scala/collection/SeqViewLike.scala | |
parent | 05c22ec2eed257c7b5e93aa4830a7666831fff48 (diff) | |
download | scala-c059e09cc7fee862e605c4d4d054447bc460aa2a.tar.gz scala-c059e09cc7fee862e605c4d4d054447bc460aa2a.tar.bz2 scala-c059e09cc7fee862e605c4d4d054447bc460aa2a.zip |
Spring cleaning of collection libraries.
If people think some operations can be more lazy, please provide
patches/do changes. Also brought proxies and forwarders into line.
Diffstat (limited to 'src/library/scala/collection/SeqViewLike.scala')
-rw-r--r-- | src/library/scala/collection/SeqViewLike.scala | 49 |
1 files changed, 44 insertions, 5 deletions
diff --git a/src/library/scala/collection/SeqViewLike.scala b/src/library/scala/collection/SeqViewLike.scala index 1a8cd20013..7014833a46 100644 --- a/src/library/scala/collection/SeqViewLike.scala +++ b/src/library/scala/collection/SeqViewLike.scala @@ -21,8 +21,8 @@ import TraversableView.NoBuilder * @version 2.8 */ trait SeqViewLike[+A, - +Coll, - +This <: SeqView[A, Coll] with SeqViewLike[A, Coll, This]] + +Coll, + +This <: SeqView[A, Coll] with SeqViewLike[A, Coll, This]] extends Seq[A] with SeqLike[A, This] with IterableView[A, Coll] with IterableViewLike[A, Coll, This] { self => @@ -31,6 +31,11 @@ trait SeqViewLike[+A, override def apply(idx: Int): B } + trait Forced[B] extends Transformed[B] with super.Forced[B] { + override def length = forced.length + override def apply(idx: Int) = forced.apply(idx) + } + trait Sliced extends Transformed[A] with super.Sliced { override def length = ((until min self.length) - from) max 0 override def apply(idx: Int): A = @@ -104,7 +109,8 @@ trait SeqViewLike[+A, trait Zipped[B] extends Transformed[(A, B)] with super.Zipped[B] { protected[this] lazy val thatSeq = other.toSeq - override def length: Int = self.length min thatSeq.length + /* Have to be careful here - other may be an infinite sequence. */ + override def length = if ((thatSeq lengthCompare self.length) <= 0) thatSeq.length else self.length override def apply(idx: Int) = (self.apply(idx), thatSeq.apply(idx)) } @@ -143,9 +149,20 @@ trait SeqViewLike[+A, override def stringPrefix = self.stringPrefix+"P" } + trait Prepended[B >: A] extends Transformed[B] { + protected[this] val fst: B + override def iterator: Iterator[B] = Iterator.single(fst) ++ self.iterator + override def length: Int = 1 + self.length + override def apply(idx: Int): B = + if (idx == 0) fst + else self.apply(idx - 1) + override def stringPrefix = self.stringPrefix+"A" + } + /** Boilerplate method, to override in each subclass * This method could be eliminated if Scala had virtual classes */ + protected override def newForced[B](xs: => Seq[B]): Transformed[B] = new Forced[B] { val forced = xs } protected override def newAppended[B >: A](that: Traversable[B]): Transformed[B] = new Appended[B] { val rest = that } protected override def newMapped[B](f: A => B): Transformed[B] = new Mapped[B] { val mapping = f } protected override def newFlatMapped[B](f: A => Traversable[B]): Transformed[B] = new FlatMapped[B] { val mapping = f } @@ -157,6 +174,7 @@ trait SeqViewLike[+A, protected override def newZippedAll[A1 >: A, B](that: Iterable[B], _thisElem: A1, _thatElem: B): Transformed[(A1, B)] = new ZippedAll[A1, B] { val other = that; val thisElem = _thisElem; val thatElem = _thatElem } protected def newReversed: Transformed[A] = new Reversed { } protected def newPatched[B >: A](_from: Int, _patch: Seq[B], _replaced: Int): Transformed[B] = new Patched[B] { val from = _from; val patch = _patch; val replaced = _replaced } + protected def newPrepended[B >: A](elem: B): Transformed[B] = new Prepended[B] { protected[this] val fst = elem } override def reverse: This = newReversed.asInstanceOf[This] @@ -167,14 +185,35 @@ trait SeqViewLike[+A, // else super.patch[B, That](from, patch, replaced)(bf) } - //TR TODO: updated, +: ed :+ ed - override def padTo[B >: A, That](len: Int, elem: B)(implicit bf: CanBuildFrom[This, B, That]): That = patch(length, fill(len - length)(elem), 0) override def reverseMap[B, That](f: A => B)(implicit bf: CanBuildFrom[This, B, That]): That = reverse.map(f) + override def updated[B >: A, That](index: Int, elem: B)(implicit bf: CanBuildFrom[This, B, That]): That = { + require(0 <= index && index < length) + patch(index, List(elem), 1)(bf) + } + + override def +:[B >: A, That](elem: B)(implicit bf: CanBuildFrom[This, B, That]): That = + newPrepended(elem).asInstanceOf[That] + + override def :+[B >: A, That](elem: B)(implicit bf: CanBuildFrom[This, B, That]): That = + ++(Iterator.single(elem))(bf) + + override def union[B >: A, That](that: Seq[B])(implicit bf: CanBuildFrom[This, B, That]): That = + newForced(thisSeq union that).asInstanceOf[That] + + override def diff[B >: A](that: Seq[B]): This = + newForced(thisSeq diff that).asInstanceOf[This] + + override def intersect[B >: A](that: Seq[B]): This = + newForced(thisSeq intersect that).asInstanceOf[This] + + override def sorted[B >: A](implicit ord: Ordering[B]): This = + newForced(thisSeq sorted ord).asInstanceOf[This] + override def stringPrefix = "SeqView" } |