mad/byg/src/DependencyGenerator.hs

132 lines
3.9 KiB
Haskell
Raw Normal View History

2024-09-23 22:11:54 +02:00
module DependencyGenerator
( DepGenM
2024-09-24 23:01:07 +02:00
, DepGenM'
2024-09-23 22:11:54 +02:00
, evalDepGenM
, inject
, runFunction
, runFunctionIO
, mapDepGenM
, mapDepGenM_
, filterDepGenM
2024-09-24 23:01:07 +02:00
, joinPaths
2024-09-23 22:11:54 +02:00
, isImageFilename
, convertedImageFilename
2024-09-24 23:01:07 +02:00
, applyTemplate
2024-09-23 22:11:54 +02:00
, listDirectory
, readTemplate
, convertImage
, saveFile
2024-09-24 22:38:52 +02:00
, makeDir
2024-09-23 22:11:54 +02:00
, runPandoc
) where
import Types.Token (Token(..))
import Types.Values
import Types.Value (Valuable(..))
import Types.Function (Function(..))
import Types.FunctionIO (FunctionIO(..))
2024-09-24 21:21:49 +02:00
import Types.Dependency (Action(..), Dependency, makeDependency)
2024-09-23 22:11:54 +02:00
import Control.Monad.State (MonadState, State, runState, put, get)
import Control.Monad.Writer (MonadWriter, WriterT, execWriterT, tell)
2024-09-24 23:09:35 +02:00
newtype DepGenM a = DepGenM { unDepGenM :: WriterT [Dependency] (State Int) a }
2024-09-23 22:11:54 +02:00
deriving (Functor, Applicative, Monad, MonadState Int, MonadWriter [Dependency])
2024-09-24 23:09:35 +02:00
type DepGenM' a = DepGenM (Token a)
2024-09-23 22:11:54 +02:00
2024-09-24 23:09:35 +02:00
evalDepGenM' :: Int -> DepGenM () -> ([Dependency], Int)
2024-09-23 22:11:54 +02:00
evalDepGenM' top m = runState (execWriterT (unDepGenM m)) top
2024-09-24 23:09:35 +02:00
evalDepGenM :: DepGenM () -> [Dependency]
2024-09-23 22:11:54 +02:00
evalDepGenM m = fst (evalDepGenM' 0 m)
2024-09-24 23:09:35 +02:00
tellDep :: Dependency -> DepGenM ()
2024-09-23 22:11:54 +02:00
tellDep dep = tell [dep]
2024-09-24 23:09:35 +02:00
genDependencyM :: (Token a -> DepGenM Dependency) -> DepGenM' a
2024-09-23 22:11:54 +02:00
genDependencyM f = do
top <- get
let top' = top + 1
target = Token top'
put top'
result <- f target
tellDep result
pure target
2024-09-24 23:09:35 +02:00
genDependency :: (Token a -> Dependency) -> DepGenM' a
2024-09-23 22:11:54 +02:00
genDependency f = genDependencyM (pure . f)
2024-09-24 23:09:35 +02:00
inject :: Valuable a => a -> DepGenM' a
2024-09-23 22:11:54 +02:00
inject x = genDependency (makeDependency NoToken (Inject (toValue x)))
2024-09-24 23:09:35 +02:00
getListElem :: Token [a] -> DepGenM' a
2024-09-23 22:11:54 +02:00
getListElem outer = genDependency (makeDependency outer GetListElem)
2024-09-24 23:09:35 +02:00
setListElem :: Token a -> Token [a] -> DepGenM ()
2024-09-23 22:11:54 +02:00
setListElem a outer = do
tellDep (makeDependency a SetListElem outer)
2024-09-24 23:09:35 +02:00
runFunction :: Function -> Token a -> DepGenM' b
2024-09-23 22:11:54 +02:00
runFunction f input = genDependency (makeDependency input (Function f))
2024-09-24 23:09:35 +02:00
runFunctionIO :: FunctionIO -> Token a -> DepGenM' b
2024-09-23 22:11:54 +02:00
runFunctionIO f input = genDependency (makeDependency input (FunctionIO f))
2024-09-25 19:45:10 +02:00
runFunctionIO' :: FunctionIO -> Token a -> DepGenM ()
runFunctionIO' f input = do
_ <- runFunctionIO f input
pure ()
2024-09-24 23:09:35 +02:00
mapDepGenM :: (Token a -> DepGenM' b) -> Token [a] -> DepGenM' [b]
2024-09-23 22:11:54 +02:00
mapDepGenM f input = genDependencyM $ \target -> do
top <- get
let (res, top') = evalDepGenM' top $ do
inp <- getListElem input
outp <- f inp
setListElem outp target
put top'
pure (makeDependency input (MapComp res) target)
2024-09-24 23:09:35 +02:00
mapDepGenM_ :: (Token a -> DepGenM ()) -> Token [a] -> DepGenM ()
2024-09-23 22:11:54 +02:00
mapDepGenM_ f input = do
2024-09-24 23:01:07 +02:00
_ <- mapDepGenM (\x -> f x >> pure NoToken) input
2024-09-24 22:23:43 +02:00
pure ()
2024-09-23 22:11:54 +02:00
2024-09-24 23:09:35 +02:00
filterDepGenM :: (Token a -> DepGenM' Bool) -> Token [a] -> DepGenM' [a]
2024-09-23 22:11:54 +02:00
filterDepGenM f input = do
conds <- mapDepGenM f input
2024-09-25 19:42:15 +02:00
genDependency (makeDependency (TupleToken (input, conds)) FilterComp)
2024-09-23 22:11:54 +02:00
2024-09-25 19:48:45 +02:00
joinPaths :: (Token FilePath, Token FilePath) -> DepGenM' FilePath
joinPaths = runFunction JoinPaths . TupleToken
2024-09-24 23:01:07 +02:00
2024-09-24 23:09:35 +02:00
isImageFilename :: Token FilePath -> DepGenM' Bool
2024-09-23 22:11:54 +02:00
isImageFilename = runFunction IsImageFilename
2024-09-24 23:09:35 +02:00
convertedImageFilename :: Token FilePath -> DepGenM' FilePath
2024-09-23 22:11:54 +02:00
convertedImageFilename = runFunction ConvertedImageFilename
2024-09-25 19:48:45 +02:00
applyTemplate :: (Token Template, Token String) -> DepGenM' String
applyTemplate = runFunction ApplyTemplate . TupleToken
2024-09-24 23:01:07 +02:00
2024-09-24 23:09:35 +02:00
listDirectory :: Token FilePath -> DepGenM' [FilePath]
2024-09-23 22:11:54 +02:00
listDirectory = runFunctionIO ListDirectory
2024-09-24 23:09:35 +02:00
readTemplate :: Token FilePath -> DepGenM' Template
2024-09-23 22:11:54 +02:00
readTemplate = runFunctionIO ReadTemplate
2024-09-25 19:48:45 +02:00
convertImage :: (Token (FilePath, FilePath), Token ImageConversionSettings) -> DepGenM ()
convertImage = runFunctionIO' ConvertImage . TupleToken
2024-09-23 22:11:54 +02:00
2024-09-25 19:48:45 +02:00
saveFile :: (Token String, Token FilePath) -> DepGenM ()
saveFile = runFunctionIO' SaveFile . TupleToken
2024-09-23 22:11:54 +02:00
2024-09-24 23:09:35 +02:00
makeDir :: Token FilePath -> DepGenM ()
2024-09-25 19:45:10 +02:00
makeDir = runFunctionIO' MakeDir
2024-09-24 22:38:52 +02:00
2024-09-24 23:09:35 +02:00
runPandoc :: Token FilePath -> DepGenM' String
2024-09-23 22:11:54 +02:00
runPandoc = runFunctionIO RunPandoc