diff options
author | schinz <schinz@epfl.ch> | 2003-07-08 08:35:16 +0000 |
---|---|---|
committer | schinz <schinz@epfl.ch> | 2003-07-08 08:35:16 +0000 |
commit | d2df7c9c9a02cd91d2dabaf4709ab77235df13c2 (patch) | |
tree | ace55450cd241dc937f599078b7daad9eca33f0e /sources/scala/collection/mutable/Queue.scala | |
parent | 1d24dc9093b581573f5b544f9a555c2a7a16d914 (diff) | |
download | scala-d2df7c9c9a02cd91d2dabaf4709ab77235df13c2.tar.gz scala-d2df7c9c9a02cd91d2dabaf4709ab77235df13c2.tar.bz2 scala-d2df7c9c9a02cd91d2dabaf4709ab77235df13c2.zip |
*** empty log message ***
Diffstat (limited to 'sources/scala/collection/mutable/Queue.scala')
-rw-r--r-- | sources/scala/collection/mutable/Queue.scala | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/sources/scala/collection/mutable/Queue.scala b/sources/scala/collection/mutable/Queue.scala new file mode 100644 index 0000000000..7ab2011bea --- /dev/null +++ b/sources/scala/collection/mutable/Queue.scala @@ -0,0 +1,32 @@ +/* __ *\ +** ________ ___ / / ___ Scala API ** +** / __/ __// _ | / / / _ | (c) 2003, LAMP/EPFL ** +** __\ \/ /__/ __ |/ /__/ __ | ** +** /____/\___/_/ |_/____/_/ | | ** +** |/ ** +** $Id$ +\* */ + +package scala; + + +class Queue[A] with MutableList[A] { + + def +=(elem: A) = appendElem(elem); + + def +=(iter: Iterable[A]) = iter.elements.foreach(e => appendElem(e)); + + def enqueue(elems: A*): Unit = (this += elems); + + def dequeue: A = { + if (first == null) + error("queue empty"); + else { + val res = first.elem; + first = first.next; + res; + } + } + + def clear: Unit = reset; +} |