1
1
mirror of https://github.com/github/semantic.git synced 2025-01-04 05:27:08 +03:00

Move the basic effect handlers out of runType.

This commit is contained in:
Rob Rix 2018-05-24 10:22:25 -04:00
parent 589ef3534f
commit 218c283d18

View File

@ -111,21 +111,23 @@ data EmbedAny effect effects return where
type Embed effect effects = Eff (effect effects ': effects) type Embed effect effects = Eff (effect effects ': effects)
runType :: ( effects ~ (Function Type opaque ': Unit Type ': Boolean Type ': Variable Type ': State (Map Name (Set Type)) ': Reader (Map Name Name) ': Fail ': NonDet ': Fresh ': rest) runType :: ( effects ~ (Function Type opaque ': Unit Type ': Boolean Type ': Variable Type ': rest)
, (Function Type opaque \\ effects) effects' , (Function Type opaque \\ effects) effects'
, effects' ~ (Unit Type ': Boolean Type ': Variable Type ': State (Map Name (Set Type)) ': Reader (Map Name Name) ': Fail ': NonDet ': Fresh ': rest) , effects' ~ (Unit Type ': Boolean Type ': Variable Type ': rest)
, (Unit Type \\ effects') effects'' , (Unit Type \\ effects') effects''
, effects'' ~ (Boolean Type ': Variable Type ': State (Map Name (Set Type)) ': Reader (Map Name Name) ': Fail ': NonDet ': Fresh ': rest) , effects'' ~ (Boolean Type ': Variable Type ': rest)
, (Boolean Type \\ effects'') effects''' , (Boolean Type \\ effects'') effects'''
, effects''' ~ (Variable Type ': State (Map Name (Set Type)) ': Reader (Map Name Name) ': Fail ': NonDet ': Fresh ': rest) , effects''' ~ (Variable Type ': rest)
, (Variable Type \\ effects''') (State (Map Name (Set Type)) ': Reader (Map Name Name) ': Fail ': NonDet ': Fresh ': rest) , (Variable Type \\ effects''') (rest)
) )
=> Eval Name Type opaque effects a => Eval Name Type opaque effects a
-> Eval Name Type opaque rest [Either String (a, Map Name (Set Type))] -> Eval Name Type opaque rest a
runType = runFresh 0 . runNonDetA . runFail . runEnv . runHeapType . runVariable derefType . runBooleanType . runUnitType . runFunctionType runType = runVariable derefType . runBooleanType . runUnitType . runFunctionType
runRest = runFresh 0 . runNonDetA . runFail . runEnv . runHeapType
resultType :: [Either String (Type, Map Name (Set Type))] resultType :: [Either String (Type, Map Name (Set Type))]
resultType = run (runType (prog BoolT)) resultType = run (runRest (runType (prog BoolT)))
data Function value opaque return where data Function value opaque return where