1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2006, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
// $Id$
package scala.collection.mutable
/** This class is used internally. It implements the mutable <code>Map</code>
* class in terms of three functions: <code>findEntry</code>,
* <code>addEntry</code>, and <code>entries</code>.
*
* @author Matthias Zenger
* @version 1.0, 08/07/2003
*/
trait DefaultMapModel[A, B] extends Map[A, B] {
type Entry = DefaultEntry[A, B]
protected def findEntry(key: A): Entry
protected def addEntry(e: Entry)
protected def entries: Iterator[Entry]
def get(key: A): Option[B] = {
val e = findEntry(key)
if (e == null) None
else Some(e.value);
}
def update(key: A, value: B) {
val e = findEntry(key)
if (e == null) addEntry(new Entry(key, value))
else e.value = value
}
def elements = entries map (e => Pair(e.key, e.value))
}
[serializable]
final class DefaultEntry[A, B](val key: A, var value: B)
extends HashEntry[A, DefaultEntry[A, B]]
|