sbt/launch/Cache.scala

23 lines
763 B
Scala
Raw Normal View History

2010-02-08 05:45:19 +01:00
/* sbt -- Simple Build Tool
* Copyright 2009, 2010 Mark Harrah
*/
2009-10-18 04:40:02 +02:00
package xsbt.boot
import java.lang.ref.{Reference, SoftReference}
2009-10-18 04:40:02 +02:00
import java.util.HashMap
final class Cache[K,X,V](create: (K,X) => V)
2009-10-18 04:40:02 +02:00
{
private[this] val delegate = new HashMap[K,Reference[V]]
def apply(k: K, x: X): V = getFromReference(k, x, delegate.get(k))
private[this] def getFromReference(k: K, x: X, existingRef: Reference[V]) = if(existingRef eq null) newEntry(k, x) else get(k, x, existingRef.get)
private[this] def get(k: K, x: X, existing: V) = if(existing == null) newEntry(k, x) else existing
private[this] def newEntry(k: K, x: X): V =
2009-10-18 04:40:02 +02:00
{
val v = create(k, x)
Pre.assert(v != null, "Value for key " + k + " was null")
delegate.put(k, new SoftReference(v))
2009-10-18 04:40:02 +02:00
v
}
}