mad/byg/src/DependencyRunner.hs

115 lines
2.7 KiB
Haskell
Raw Normal View History

2024-09-27 20:39:27 +02:00
module DependencyRunner
2024-09-27 21:13:16 +02:00
( DepRunM
, runDeps
, runDepRunMIO
2024-09-27 20:39:27 +02:00
) where
2024-09-28 13:57:53 +02:00
import Types (Value(..), fromValue)
2024-09-27 20:39:27 +02:00
import Types.Dependency
import Evaluation.Function
import Evaluation.FunctionIO
import Data.Map (Map)
import qualified Data.Map as M
2024-09-27 21:13:16 +02:00
import Control.Monad.State (MonadState, MonadIO, StateT, evalStateT, get, modify, liftIO)
2024-09-27 20:39:27 +02:00
newtype DepRunM a = DepRunM { unDepRunM :: StateT (Map Int Value) IO a }
deriving (Functor, Applicative, Monad, MonadIO, MonadState (Map Int Value))
runDeps :: [Dependency] -> DepRunM ()
runDeps = mapM_ runDep
runDepRunMIO :: DepRunM a -> IO a
runDepRunMIO m = evalStateT (unDepRunM m) M.empty
2024-09-27 21:13:16 +02:00
2024-09-27 20:39:27 +02:00
runDep :: Dependency -> DepRunM ()
runDep (Dependency a action b) = do
input <- getTokenValue a
result <- runAction action input
putTokenValue b result
2024-09-30 23:31:01 +02:00
liftIO $ do
putStrLn ("input: " ++ show input)
putStrLn ("action: " ++ show action)
putStrLn ("output: " ++ show result)
putStrLn "----------"
2024-09-27 20:39:27 +02:00
getTokenValue :: UToken -> DepRunM Value
getTokenValue = \case
UToken i -> do
m <- get
pure (m M.! i)
2024-10-05 19:44:28 +02:00
UTupleToken a b -> do
2024-09-27 20:39:27 +02:00
va <- getTokenValue a
vb <- getTokenValue b
pure $ Tuple (va, vb)
2024-10-05 19:44:28 +02:00
UZipToken a b -> do
2024-09-27 20:39:27 +02:00
va <- getTokenValue a
vb <- getTokenValue b
case (va, vb) of
(List as, List bs) ->
pure $ List $ zipWith (curry Tuple) as bs
_ ->
error "unexpected"
UListToken ts -> do
vs <- mapM getTokenValue ts
pure $ List vs
2024-09-27 20:39:27 +02:00
UNoToken ->
pure Empty
putTokenValue :: UToken -> Value -> DepRunM ()
putTokenValue t v = case t of
UToken i ->
modify $ M.insert i v
UNoToken ->
pure ()
_ ->
error "unexpected"
runAction :: Action -> Value -> DepRunM Value
runAction action input = case action of
Function f ->
pure $ evalFunction f input
FunctionIO f ->
liftIO $ evalFunctionIO f input
Inject v ->
pure v
FilterComp ->
case input of
Tuple (List vs, List mask) ->
pure $ List $ map fst $ filter (fromValue . snd) $ zip vs mask
_ ->
error "unexpected"
UntupleFst ->
case input of
Tuple (v, _) ->
pure v
_ ->
error "unexpected"
UntupleSnd ->
case input of
Tuple (_, v) ->
pure v
_ ->
error "unexpected"
UnzipFst ->
case input of
List vs ->
List <$> mapM (runAction UntupleFst) vs
_ ->
error "unexpected"
UnzipSnd ->
case input of
List vs ->
List <$> mapM (runAction UntupleSnd) vs
_ ->
error "unexpected"
MapComp subDeps innerInput innerOutput ->
2024-09-27 21:13:16 +02:00
case input of
List vs ->
(List <$>) $ flip mapM vs $ \v -> do
putTokenValue innerInput v
runDeps subDeps
getTokenValue innerOutput
_ ->
error "unexpected"