From 3bd755cf51ce981b3932e587775b5bf41ea3fa89 Mon Sep 17 00:00:00 2001 From: Thomas Bleher Date: Sat, 5 Dec 2020 22:44:16 +0100 Subject: [PATCH] lint: set exit code if any lint check triggers This makes it easier to use `tttool lint` in scripts. --- src/Commands.hs | 3 ++- src/Lint.hs | 21 ++++++++++++++++----- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/src/Commands.hs b/src/Commands.hs index 1732ac9a..14e52556 100644 --- a/src/Commands.hs +++ b/src/Commands.hs @@ -133,7 +133,8 @@ dumpInfo conf file = do lint :: FilePath -> IO () lint file = do (tt,segments) <- parseTipToiFile <$> B.readFile file - lintTipToi tt segments + result <- lintTipToi tt segments + when (result == False) exitFailure play :: Conf -> FilePath -> IO () play conf file = do diff --git a/src/Lint.hs b/src/Lint.hs index 2bf5885f..3e50d26c 100644 --- a/src/Lint.hs +++ b/src/Lint.hs @@ -8,23 +8,31 @@ import qualified Data.Map as M import Types import PrettyPrint -lintTipToi :: TipToiFile -> Segments -> IO () +lintTipToi :: TipToiFile -> Segments -> IO (Bool) lintTipToi tt segments = do let hyps = [ (hyp1, "play indicies are correct") , (hyp2, "media indicies are correct") , (hyp3, "at most one jump per line, as last action") ] - forM_ hyps $ \(hyp, desc) -> do + hyp_result <- forM hyps $ \(hyp, desc) -> do let wrong = filter (not . hyp) (concat (mapMaybe snd (ttScripts tt))) if null wrong - then printf "All lines do satisfy hypothesis \"%s\"!\n" desc + then do + printf "All lines do satisfy hypothesis \"%s\"!\n" desc + return True else do printf "These lines do not satisfy hypothesis \"%s\":\n" desc forM_ wrong $ \line -> do printf " %s\n" (ppLine M.empty line) + return False - forM_ (fromMaybe [] (ttMediaFlags tt)) $ \f -> - when (f > 1) $ printf "Media flag >1: %d" f + media_result <- forM (fromMaybe [] (ttMediaFlags tt)) $ \f -> + if (f > 1) + then do + printf "Media flag >1: %d" f + return False + else do + return True let overlapping_segments = filter (\((o1,l1,_),(o2,l2,_)) -> o1+l1 > o2) $ @@ -33,6 +41,9 @@ lintTipToi tt segments = do printf "Overlapping segments: %d\n" (length overlapping_segments) mapM_ (uncurry report) overlapping_segments + + let no_failures = (all (==True)) $ (hyp_result ++ media_result ++ [null overlapping_segments]) + return no_failures where hyp1 :: Line ResReg -> Bool hyp1 (Line _ _ as mi) = all ok as