mirror of
https://github.com/github/semantic.git
synced 2024-12-22 14:21:31 +03:00
Abstract evaluation under binders over the evaluator type.
This commit is contained in:
parent
b25c9e6cd3
commit
4d5969a077
@ -33,11 +33,11 @@ type Evaluating t v
|
|||||||
-- | Require/import another term/file and return an Effect.
|
-- | Require/import another term/file and return an Effect.
|
||||||
--
|
--
|
||||||
-- Looks up the term's name in the cache of evaluated modules first, returns a value if found, otherwise loads/evaluates the module.
|
-- Looks up the term's name in the cache of evaluated modules first, returns a value if found, otherwise loads/evaluates the module.
|
||||||
require :: ( AbstractFunction effects term v
|
require :: ( AbstractValue v
|
||||||
, AbstractValue v
|
|
||||||
, Evaluatable (Base term)
|
, Evaluatable (Base term)
|
||||||
, FreeVariables term
|
, FreeVariables term
|
||||||
, MonadAddressable (LocationFor v) v (Evaluator effects term v)
|
, MonadAddressable (LocationFor v) v (Evaluator effects term v)
|
||||||
|
, MonadFunctionAbstraction term v (Evaluator effects term v)
|
||||||
, Recursive term
|
, Recursive term
|
||||||
, Semigroup (Cell (LocationFor v) v)
|
, Semigroup (Cell (LocationFor v) v)
|
||||||
)
|
)
|
||||||
@ -49,11 +49,11 @@ require term = getModuleTable >>= maybe (load term) pure . linkerLookup name
|
|||||||
-- | Load another term/file and return an Effect.
|
-- | Load another term/file and return an Effect.
|
||||||
--
|
--
|
||||||
-- Always loads/evaluates.
|
-- Always loads/evaluates.
|
||||||
load :: ( AbstractFunction effects term v
|
load :: ( AbstractValue v
|
||||||
, AbstractValue v
|
|
||||||
, Evaluatable (Base term)
|
, Evaluatable (Base term)
|
||||||
, FreeVariables term
|
, FreeVariables term
|
||||||
, MonadAddressable (LocationFor v) v (Evaluator effects term v)
|
, MonadAddressable (LocationFor v) v (Evaluator effects term v)
|
||||||
|
, MonadFunctionAbstraction term v (Evaluator effects term v)
|
||||||
, Recursive term
|
, Recursive term
|
||||||
, Semigroup (Cell (LocationFor v) v)
|
, Semigroup (Cell (LocationFor v) v)
|
||||||
)
|
)
|
||||||
@ -75,11 +75,11 @@ moduleName term = let [n] = toList (freeVariables term) in BC.unpack n
|
|||||||
-- | Evaluate a term to a value.
|
-- | Evaluate a term to a value.
|
||||||
evaluate :: forall v term.
|
evaluate :: forall v term.
|
||||||
( Ord (LocationFor v)
|
( Ord (LocationFor v)
|
||||||
, AbstractFunction (Evaluating term v) term v
|
|
||||||
, AbstractValue v
|
, AbstractValue v
|
||||||
, Evaluatable (Base term)
|
, Evaluatable (Base term)
|
||||||
, FreeVariables term
|
, FreeVariables term
|
||||||
, MonadAddressable (LocationFor v) v (Evaluator (Evaluating term v) term v)
|
, MonadAddressable (LocationFor v) v (Evaluator (Evaluating term v) term v)
|
||||||
|
, MonadFunctionAbstraction term v (Evaluator (Evaluating term v) term v)
|
||||||
, Recursive term
|
, Recursive term
|
||||||
, Semigroup (Cell (LocationFor v) v)
|
, Semigroup (Cell (LocationFor v) v)
|
||||||
)
|
)
|
||||||
@ -90,11 +90,11 @@ evaluate = run @(Evaluating term v) . runEvaluator . foldSubterms eval
|
|||||||
-- | Evaluate terms and an entry point to a value.
|
-- | Evaluate terms and an entry point to a value.
|
||||||
evaluates :: forall v term.
|
evaluates :: forall v term.
|
||||||
( Ord (LocationFor v)
|
( Ord (LocationFor v)
|
||||||
, AbstractFunction (Evaluating term v) term v
|
|
||||||
, AbstractValue v
|
, AbstractValue v
|
||||||
, Evaluatable (Base term)
|
, Evaluatable (Base term)
|
||||||
, FreeVariables term
|
, FreeVariables term
|
||||||
, MonadAddressable (LocationFor v) v (Evaluator (Evaluating term v) term v)
|
, MonadAddressable (LocationFor v) v (Evaluator (Evaluating term v) term v)
|
||||||
|
, MonadFunctionAbstraction term v (Evaluator (Evaluating term v) term v)
|
||||||
, Recursive term
|
, Recursive term
|
||||||
, Semigroup (Cell (LocationFor v) v)
|
, Semigroup (Cell (LocationFor v) v)
|
||||||
)
|
)
|
||||||
|
@ -6,15 +6,15 @@ module Control.Monad.Effect.Evaluatable
|
|||||||
, Recursive(..)
|
, Recursive(..)
|
||||||
, Base
|
, Base
|
||||||
, Subterm(..)
|
, Subterm(..)
|
||||||
, AbstractFunction(..)
|
, MonadFunctionAbstraction(..)
|
||||||
) where
|
) where
|
||||||
|
|
||||||
import Analysis.Abstract.Evaluator as Evaluator
|
import Analysis.Abstract.Evaluator as Evaluator
|
||||||
|
import Control.Applicative (Alternative(..))
|
||||||
import Control.Monad.Effect.Addressable
|
import Control.Monad.Effect.Addressable
|
||||||
import Control.Monad.Effect.Fail
|
import Control.Monad.Effect.Fail
|
||||||
import Control.Monad.Effect.Fresh
|
import Control.Monad.Effect.Fresh
|
||||||
import Control.Monad.Effect.Internal
|
import Control.Monad.Effect.Internal
|
||||||
import Control.Monad.Effect.NonDetEff
|
|
||||||
import Data.Abstract.Address
|
import Data.Abstract.Address
|
||||||
import Data.Abstract.Environment
|
import Data.Abstract.Environment
|
||||||
import Data.Abstract.FreeVariables
|
import Data.Abstract.FreeVariables
|
||||||
@ -33,10 +33,10 @@ import qualified Data.Union as U
|
|||||||
|
|
||||||
-- | The 'Evaluatable' class defines the necessary interface for a term to be evaluated. While a default definition of 'eval' is given, instances with computational content must implement 'eval' to perform their small-step operational semantics.
|
-- | The 'Evaluatable' class defines the necessary interface for a term to be evaluated. While a default definition of 'eval' is given, instances with computational content must implement 'eval' to perform their small-step operational semantics.
|
||||||
class Evaluatable constr where
|
class Evaluatable constr where
|
||||||
eval :: ( AbstractFunction effects term value
|
eval :: ( AbstractValue value
|
||||||
, AbstractValue value
|
|
||||||
, FreeVariables term
|
, FreeVariables term
|
||||||
, MonadAddressable (LocationFor value) value (Evaluator effects term value)
|
, MonadAddressable (LocationFor value) value (Evaluator effects term value)
|
||||||
|
, MonadFunctionAbstraction term value (Evaluator effects term value)
|
||||||
, Ord (LocationFor value)
|
, Ord (LocationFor value)
|
||||||
, Semigroup (Cell (LocationFor value) value)
|
, Semigroup (Cell (LocationFor value) value)
|
||||||
)
|
)
|
||||||
@ -74,9 +74,9 @@ instance Evaluatable [] where
|
|||||||
-- to the global environment.
|
-- to the global environment.
|
||||||
localEnv (const (bindEnv (liftFreeVariables (freeVariables . subterm) xs) env)) (eval xs)
|
localEnv (const (bindEnv (liftFreeVariables (freeVariables . subterm) xs) env)) (eval xs)
|
||||||
|
|
||||||
class AbstractFunction effects t v | v -> t where
|
class MonadEvaluator t v m => MonadFunctionAbstraction t v m where
|
||||||
abstract :: [Name] -> Subterm t (Evaluator effects t v v) -> Evaluator effects t v v
|
abstract :: [Name] -> Subterm t (m v) -> m v
|
||||||
apply :: v -> [Subterm t (Evaluator effects t v v)] -> Evaluator effects t v v
|
apply :: v -> [Subterm t (m v)] -> m v
|
||||||
|
|
||||||
instance ( Evaluatable (Base t)
|
instance ( Evaluatable (Base t)
|
||||||
, FreeVariables t
|
, FreeVariables t
|
||||||
@ -84,7 +84,7 @@ instance ( Evaluatable (Base t)
|
|||||||
, Recursive t
|
, Recursive t
|
||||||
, Semigroup (Cell location (Value location t))
|
, Semigroup (Cell location (Value location t))
|
||||||
)
|
)
|
||||||
=> AbstractFunction effects t (Value location t) where
|
=> MonadFunctionAbstraction t (Value location t) (Evaluator effects t (Value location t)) where
|
||||||
-- FIXME: Can we store the action evaluating the body in the Value instead of the body term itself
|
-- FIXME: Can we store the action evaluating the body in the Value instead of the body term itself
|
||||||
abstract names (Subterm body _) = inj . Closure names body <$> askLocalEnv
|
abstract names (Subterm body _) = inj . Closure names body <$> askLocalEnv
|
||||||
|
|
||||||
@ -97,7 +97,7 @@ instance ( Evaluatable (Base t)
|
|||||||
envInsert name a <$> rest) (pure env) (zip names params)
|
envInsert name a <$> rest) (pure env) (zip names params)
|
||||||
localEnv (mappend bindings) (foldSubterms eval body)
|
localEnv (mappend bindings) (foldSubterms eval body)
|
||||||
|
|
||||||
instance Members '[Fresh, NonDetEff] effects => AbstractFunction effects t (Type t) where
|
instance (Alternative m, MonadEvaluator t (Type.Type t) m, MonadFresh m) => MonadFunctionAbstraction t (Type t) m where
|
||||||
abstract names (Subterm _ body) = do
|
abstract names (Subterm _ body) = do
|
||||||
(env, tvars) <- foldr (\ name rest -> do
|
(env, tvars) <- foldr (\ name rest -> do
|
||||||
a <- alloc name
|
a <- alloc name
|
||||||
|
Loading…
Reference in New Issue
Block a user