module Development.Hake.FunSetIO ( file , task , rule , ruleV , ruleSS , orDie ) where import System.Exit (ExitCode) import Data.List (isSuffixOf) import Data.Function.Tools (const2) import Control.Monad.Reader (lift) import Development.Hake.Types (Rule, getSrcs) import Development.Hake.Tools (orDie, changeSuffix) file :: [String] -> [String] -> (String -> [String] -> IO ExitCode) -> Rule file trgts srcs cmd = ( \f -> or $ map (==f) trgts, const srcs, \t s -> lift $ (flip orDie show) $ cmd t s ) task :: String -> IO ExitCode -> Rule task trgts cmd = ( (==trgts), const [], const2 $ lift cmd `orDie` show) rule :: String -> String -> (String -> [String] -> IO ExitCode) -> Rule rule trgt src cmd = ( isSuffixOf trgt, \dst -> [changeSuffix trgt src dst ], (.) (flip orDie show) . (.) lift . cmd ) ruleV :: String -> [String] -> [String] -> (String -> [String] -> IO ExitCode) -> Rule ruleV trgt srcs cmmns cmd = ( isSuffixOf trgt, \dst -> map (flip (changeSuffix trgt) dst) srcs ++ cmmns, (.) (flip orDie show) . (.) lift . cmd ) ruleSS :: String -> String -> (String -> [String] -> [ (String, IO ExitCode) ]) -> Rule ruleSS trgt src cmds = ( isSuffixOf trgt, \dst -> [ changeSuffix trgt src dst ], \t s -> do (srcSrc:_) <- getSrcs $ head s lift $ flip orDie show $ snd $ head $ filter ( flip isSuffixOf srcSrc . fst ) $ cmds t s)