summaryrefslogtreecommitdiff
path: root/src/library/scala/collection/IterableProxyLike.scala
diff options
context:
space:
mode:
authorMartin Odersky <odersky@gmail.com>2009-09-25 16:20:13 +0000
committerMartin Odersky <odersky@gmail.com>2009-09-25 16:20:13 +0000
commit4a727f3b01d0fa27ef51f7dba472116e021e3445 (patch)
treec9ab55ea7fe6051455271b23e9fbfc2f313015c0 /src/library/scala/collection/IterableProxyLike.scala
parente31f18094dfba97c80871869a037172ff2c9c1c2 (diff)
downloadscala-4a727f3b01d0fa27ef51f7dba472116e021e3445.tar.gz
scala-4a727f3b01d0fa27ef51f7dba472116e021e3445.tar.bz2
scala-4a727f3b01d0fa27ef51f7dba472116e021e3445.zip
Collections refactoring.
Diffstat (limited to 'src/library/scala/collection/IterableProxyLike.scala')
-rw-r--r--src/library/scala/collection/IterableProxyLike.scala46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/library/scala/collection/IterableProxyLike.scala b/src/library/scala/collection/IterableProxyLike.scala
new file mode 100644
index 0000000000..79ed050a8a
--- /dev/null
+++ b/src/library/scala/collection/IterableProxyLike.scala
@@ -0,0 +1,46 @@
+/* __ *\
+** ________ ___ / / ___ Scala API **
+** / __/ __// _ | / / / _ | (c) 2003-2009, LAMP/EPFL **
+** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
+** /____/\___/_/ |_/____/_/ | | **
+** |/ **
+\* */
+
+// $Id$
+
+
+package scala.collection
+
+import generic._
+import mutable.Buffer
+
+// Methods could be printed by cat IterableLike.scala | egrep '^ (override )?def'
+
+
+/** This trait implements a proxy for iterable objects. It forwards
+ * all calls to a different iterable object
+ *
+ * @author Martin Odersky
+ * @version 2.8
+ */
+trait IterableProxyLike[+A, +This <: IterableLike[A, This] with Iterable[A]]
+ extends IterableLike[A, This]
+ with TraversableProxyLike[A, This]
+{
+ override def iterator: Iterator[A] = self.iterator
+ override def foreach[U](f: A => U): Unit = self.foreach(f)
+ override def isEmpty: Boolean = self.isEmpty
+ override def foldRight[B](z: B)(op: (A, B) => B): B = self.foldRight(z)(op)
+ override def reduceRight[B >: A](op: (A, B) => B): B = self.reduceRight(op)
+ override def toIterable: Iterable[A] = self.toIterable
+ override def zip[A1 >: A, B, That](that: Iterable[B])(implicit bf: BuilderFactory[(A1, B), That, This]): That = self.zip[A1, B, That](that)(bf)
+ override def zipAll[B, A1 >: A, That](that: Iterable[B], thisElem: A1, thatElem: B)(implicit bf: BuilderFactory[(A1, B), That, This]): That = self.zipAll(that, thisElem, thatElem)(bf)
+ override def zipWithIndex[A1 >: A, That](implicit bf: BuilderFactory[(A1, Int), That, This]): That = self.zipWithIndex(bf)
+ override def head: A = self.head
+ override def takeRight(n: Int): This = self.takeRight(n)
+ override def dropRight(n: Int): This = self.dropRight(n)
+ override def sameElements[B >: A](that: Iterable[B]): Boolean = self.sameElements(that)
+ override def toStream: Stream[A] = self.toStream
+ override def view = self.view
+ override def view(from: Int, until: Int) = self.view(from, until)
+}