forked from ndmitchell/hlint
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMain.hs
61 lines (50 loc) · 1.97 KB
/
Main.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
{-# LANGUAGE RecordWildCards #-}
module Main where
import Control.Arrow
import Control.Monad
import Data.List
import Data.Maybe
import System.Directory
import System.Exit
import Data.Generics.PlateData
import CmdLine
import Settings
import Report
import Type
import Test
import Util
import Parallel
import HSE.All
import Hint.All
import Paths_hlint
main = do
Cmd{..} <- getCmd
if cmdTest then test else do
settings <- readSettings cmdHintFiles
let extra = [Classify ("","") Ignore x | x <- cmdIgnore]
let apply = map (classify $ settings ++ extra) . applyHint (allHints settings)
let apply' x = do y <- x ; let res = apply y in length res `seq` return res
ideas <- liftM concat $ parallel $ map (apply' . parseFile) cmdFiles
showItem <- if cmdColor then showANSI else return show
mapM_ putStrLn [showItem i | i <- ideas, cmdShowAll || rank i /= Ignore]
-- figure out statistics
let counts = map (head &&& length) $ group $ sort $ map rank ideas
let [ignore,warn,err] = map (fromMaybe 0 . flip lookup counts) [Ignore,Warning,Error]
let total = ignore + warn + err
let shown = if cmdShowAll then total else total - ignore
let ignored = [show i ++ " ignored" | let i = total - shown, i /= 0]
let errors = [show err ++ " error" ++ ['s'|err/=1] | err /= 0]
if shown == 0 then do
when (cmdReports /= []) $ putStrLn "Skipping writing reports"
printMsg "No relevant suggestions" ignored
else do
forM_ cmdReports $ \x -> do
putStrLn $ "Writing report to " ++ x ++ " ..."
writeReport x ideas
printMsg ("Found " ++ show shown ++ " suggestion" ++ ['s'|shown/=1]) (errors++ignored)
when (err > 0) $
exitWith $ ExitFailure 1
printMsg :: String -> [String] -> IO ()
printMsg msg xs =
putStrLn $ msg ++ if null xs then "" else
" (" ++ intercalate ", " xs ++ ")"