diff options
author | Antonio Cunei <antonio.cunei@epfl.ch> | 2011-07-22 16:41:44 +0000 |
---|---|---|
committer | Antonio Cunei <antonio.cunei@epfl.ch> | 2011-07-22 16:41:44 +0000 |
commit | 7cd05e62accece28b5d3adba261c87fc60f6e351 (patch) | |
tree | 0dada940fd9b481932f7f2c99f68d102dcb918d1 | |
parent | 3307c3771777cf17d5b4d059726a1b484923d042 (diff) | |
download | scala-7cd05e62accece28b5d3adba261c87fc60f6e351.tar.gz scala-7cd05e62accece28b5d3adba261c87fc60f6e351.tar.bz2 scala-7cd05e62accece28b5d3adba261c87fc60f6e351.zip |
Removal of one leftover file.
-rw-r--r-- | src/compiler/scala/tools/nsc/symtab/Caches.scala | 103 |
1 files changed, 0 insertions, 103 deletions
diff --git a/src/compiler/scala/tools/nsc/symtab/Caches.scala b/src/compiler/scala/tools/nsc/symtab/Caches.scala deleted file mode 100644 index 10d7500f09..0000000000 --- a/src/compiler/scala/tools/nsc/symtab/Caches.scala +++ /dev/null @@ -1,103 +0,0 @@ -/* NSC -- new scala compiler - * Copyright 2005-2011 LAMP/EPFL - * @author Paul Phillips - */ - -package scala.tools.nsc -package symtab - -import scala.collection.{ mutable, immutable } - -/** A cache for some entity whose validity depends on a monotonically - * increasing sequence number. - */ -abstract class SequencedCache[T >: Null] { - def zero: Int - def sequenceId: Int - def calculate(): T - - /** If sequence numbers differ, this condition is consulted before - * updating the cached value. - */ - def isCacheValid: Boolean - - /** Public so accesses can be inlined. */ - @inline var cachedId: Int = 0 - @inline var cachedValue: T = _ - - /** Puts cache back in uninitialized state. */ - @inline final def clear() = { - cachedId = zero - cachedValue = null - } - /** Resets the sequence id without touching the cached value. */ - @inline final def reset() = { - cachedId = zero - } - - final def get(): T = { - if (cachedValue == null) { - cachedValue = calculate() - cachedId = sequenceId - } - else if (cachedId != sequenceId) { - if (!isCacheValid) - cachedValue = calculate() - - cachedId = sequenceId - } - cachedValue - } -} - -trait Caches { - self: SymbolTable => - - final def isValid(period: Period): Boolean = - period != 0 && runId(period) == currentRunId && { - val pid = phaseId(period) - if (phase.id > pid) infoTransformers.nextFrom(pid).pid >= phase.id - else infoTransformers.nextFrom(phase.id).pid >= pid - } - - final def isValidForBaseClasses(period: Period): Boolean = { - def noChangeInBaseClasses(it: InfoTransformer, limit: Phase#Id): Boolean = ( - it.pid >= limit || - !it.changesBaseClasses && noChangeInBaseClasses(it.next, limit) - ); - period != 0 && runId(period) == currentRunId && { - val pid = phaseId(period) - if (phase.id > pid) noChangeInBaseClasses(infoTransformers.nextFrom(pid), phase.id) - else noChangeInBaseClasses(infoTransformers.nextFrom(phase.id), pid) - } - } - - abstract class PeriodCache[T >: Null] extends SequencedCache[T] { - final val zero = NoPeriod - @inline final def sequenceId = currentPeriod - } - - abstract class ListOfTypesCache extends PeriodCache[List[Type]] { - @inline final def isCacheValid = isValidForBaseClasses(cachedId) - } - abstract class ListOfSymbolsCache extends PeriodCache[List[Symbol]] { - @inline final def isCacheValid = isValidForBaseClasses(cachedId) - } - abstract class BaseTypeSeqCache extends PeriodCache[BaseTypeSeq] { - @inline final def isCacheValid = isValidForBaseClasses(cachedId) - } - abstract class TypeCache extends PeriodCache[Type] { - @inline final def isCacheValid = isValid(cachedId) - } - abstract class TypeCacheForRunId extends SequencedCache[Type] { - final val zero = NoRunId - @inline final def sequenceId = currentRunId - @inline final override def isCacheValid = false - } - object TypeCache { - def apply(body: => Type): TypeCache = new TypeCache { - @inline final def calculate() = body - } - } -} - |