1
1
mirror of https://github.com/github/semantic.git synced 2025-01-01 11:46:14 +03:00

Cache the environment at each program state.

This commit is contained in:
Rob Rix 2018-05-15 22:02:18 -04:00
parent 164c2d0feb
commit 6f1c57086b
2 changed files with 18 additions and 6 deletions

View File

@ -35,14 +35,19 @@ lookupCache :: (Cacheable term location (Cell location) value, Member (OutCache
lookupCache configuration = cacheLookup configuration <$> get
-- | Run an action, caching its result and 'Heap' under the given configuration.
cachingConfiguration :: (Cacheable term location (Cell location) value, Members '[OutCache term location value, State (Heap location (Cell location) value)] effects)
cachingConfiguration :: ( Cacheable term location (Cell location) value
, Members '[ OutCache term location value
, State (Environment location value)
, State (Heap location (Cell location) value)
] effects
)
=> Configuration term location (Cell location) value
-> Set (Cached location (Cell location) value)
-> TermEvaluator term location value effects value
-> TermEvaluator term location value effects value
cachingConfiguration configuration values action = do
modify' (cacheSet configuration values)
result <- Cached <$> action <*> TermEvaluator getHeap
result <- Cached <$> action <*> TermEvaluator getEnv <*> TermEvaluator getHeap
cachedValue result <$ modify' (cacheInsert configuration result)
putCache :: Member (OutCache term location value) effects
@ -125,8 +130,13 @@ converge seed f = loop seed
loop x'
-- | Nondeterministically write each of a collection of stores & return their associated results.
scatter :: (Foldable t, Members '[NonDet, State (Heap location (Cell location) value)] effects) => t (Cached location (Cell location) value) -> TermEvaluator term location value effects value
scatter = foldMapA (\ (Cached value heap') -> TermEvaluator (putHeap heap') $> value)
scatter :: ( Foldable t
, Members '[ NonDet
, State (Environment location value)
, State (Heap location (Cell location) value)
] effects
) => t (Cached location (Cell location) value) -> TermEvaluator term location value effects value
scatter = foldMapA (\ Cached{..} -> TermEvaluator (putHeap cachedHeap) *> TermEvaluator (putEnv cachedEnvironment) $> cachedValue)
caching :: Alternative f => TermEvaluator term location value (NonDet ': InCache term location value ': OutCache term location value ': effects) a -> TermEvaluator term location value effects (f a, Cache term location (Cell location) value)

View File

@ -2,6 +2,7 @@
module Data.Abstract.Cache where
import Data.Abstract.Configuration
import Data.Abstract.Environment
import Data.Abstract.Heap
import Data.Map.Monoidal as Monoidal
import Data.Semilattice.Lower
@ -12,8 +13,9 @@ newtype Cache term location cell value = Cache { unCache :: Monoidal.Map (Config
deriving (Eq, Lower, Monoid, Ord, Reducer (Configuration term location cell value, Cached location cell value), Semigroup)
data Cached location cell value = Cached
{ cachedValue :: value
, cachedHeap :: Heap location cell value
{ cachedValue :: value
, cachedEnvironment :: Environment location value
, cachedHeap :: Heap location cell value
}
deriving (Eq, Ord, Show)