1
1
mirror of https://github.com/github/semantic.git synced 2025-01-09 00:56:32 +03:00

Evaluate a list of terms with MonadLinker avail

This commit is contained in:
Timothy Clem 2018-02-12 14:29:33 -08:00
parent 32c2e92660
commit 01a0bdc236

View File

@ -1,19 +1,22 @@
{-# LANGUAGE ConstraintKinds, DataKinds, ScopedTypeVariables, TypeApplications #-}
{-# LANGUAGE ConstraintKinds, DataKinds, ScopedTypeVariables, TypeApplications, TypeFamilies #-}
module Analysis.Abstract.Evaluating where
import Control.Effect
import Control.Monad.Effect hiding (run)
import Control.Monad.Effect.Address
import Control.Monad.Effect.Linker
import Control.Monad.Effect.Fail
import Control.Monad.Effect.Reader
import Control.Monad.Effect.State
import Data.Abstract.Address
import Data.Abstract.Environment
import Data.Abstract.Linker
import Data.Abstract.Eval
import Data.Abstract.Store
import Data.Abstract.Value
import Data.Abstract.Live
import Data.Function (fix)
import Data.Functor.Foldable (Base, Recursive(..))
import Data.Functor.Foldable (Base, Recursive(..), ListF(..))
import Data.Semigroup
-- | The effects necessary for concrete interpretation.
@ -21,6 +24,7 @@ type Evaluating v
= '[ Fail -- For 'MonadFail'.
, State (Store (LocationFor v) v) -- For 'MonadStore'.
, Reader (Environment (LocationFor v) v) -- For 'MonadEnv'.
, Reader (Linker v) -- For 'MonadLinker'.
, Reader (Live (LocationFor v) v) -- For 'MonadGC'.
]
@ -32,9 +36,31 @@ evaluate :: forall v term
, Functor (Base term)
, Recursive term
, MonadAddress (LocationFor v) (Eff (Evaluating v))
-- , MonadLinker v (Eff (Evaluating v))
, Eval term v (Eff (Evaluating v)) (Base term)
)
=> term
-> Final (Evaluating v) v
evaluate = run @(Evaluating v) . fix go pure
where go recur yield = eval recur yield . project
evaluates :: forall v term
. ( Ord v
, Ord (Cell (LocationFor v) v)
, Semigroup (Cell (LocationFor v) v)
, Functor (Base term)
, Recursive term
, AbstractValue v
, MonadAddress (LocationFor v) (Eff (Evaluating v))
, MonadLinker v (Eff (Evaluating v))
, Eval term v (Eff (Evaluating v)) (Base term)
)
=> [term]
-> Final (Evaluating v) v
evaluates = run @(Evaluating v) . fix go pure
where
go recur yield [] = yield unit
go recur yield [a] = eval (\x y -> recur x [y]) pure (project a) >>= yield
go recur yield (a:as) = do
linker <- askLinker :: (Eff (Evaluating v)) (Linker v)
eval (const (const (go recur pure as))) pure (project a) >>= yield