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
|
|
|
|
|
|
2010-01-28 00:22:42 +01:00
|
|
|
import java.lang.ref.{Reference, SoftReference}
|
2009-10-18 04:40:02 +02:00
|
|
|
import java.util.HashMap
|
|
|
|
|
|
2011-04-11 06:44:28 +02:00
|
|
|
final class Cache[K,X,V](create: (K,X) => V)
|
2009-10-18 04:40:02 +02:00
|
|
|
{
|
2010-01-28 00:22:42 +01:00
|
|
|
private[this] val delegate = new HashMap[K,Reference[V]]
|
2011-04-11 06:44:28 +02:00
|
|
|
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
|
|
|
{
|
2011-04-11 06:44:28 +02:00
|
|
|
val v = create(k, x)
|
2009-10-19 04:25:50 +02:00
|
|
|
Pre.assert(v != null, "Value for key " + k + " was null")
|
2010-01-28 00:22:42 +01:00
|
|
|
delegate.put(k, new SoftReference(v))
|
2009-10-18 04:40:02 +02:00
|
|
|
v
|
|
|
|
|
}
|
2009-10-19 04:25:50 +02:00
|
|
|
}
|