Skip to content

Commit

Permalink
Extract CLI interface to own package (#8)
Browse files Browse the repository at this point in the history
  • Loading branch information
passy committed Jul 20, 2015
1 parent f481eb2 commit 6f260a4
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 62 deletions.
64 changes: 2 additions & 62 deletions Main.hs
@@ -1,68 +1,8 @@
{-# LANGUAGE NoImplicitPrelude #-}
{-# LANGUAGE OverloadedStrings #-}

module Main where

import BasicPrelude hiding (fromString)

import AndroidLintSummary
import Options.Applicative
import Rainbow

import Control.Monad.Reader (runReader)
import Data.Default (def)
import Data.Stringable (Stringable (fromString, toString))
import Data.Version (showVersion)
import Paths_android_lint_summary (version)
import System.Directory (getCurrentDirectory)

import qualified System.Console.Terminal.Size as Terminal
import qualified System.FilePath.Find as Find

appOpts :: Parser AppOpts
appOpts = AppOpts
<$> optional ( some $ argument str (metavar "FILES") )
<*> strOption ( long "glob"
<> short 'g'
<> help "Glob pattern to select result files"
<> value (pattern def)
<> showDefault )
<*> ( fromString <$>
strOption ( long "formatter"
<> short 'f'
<> help "Specify a formatter to use [simple|null]"
<> value (toString . formatter $ def)
<> showDefault ) )
<*> flag Normal Verbose ( long "verbose"
<> short 'v'
<> help "Enable verbose mode" )

findFilesFromArgs :: AppOpts -> IO [FilePath]
findFilesFromArgs args' = go $ targets args'
where
go (Just names) = return names
go Nothing = do
dir <- getCurrentDirectory
Find.find Find.always (Find.filePath Find.~~? pattern args') dir
import AndroidLintSummary.CLI (runCLI)

main :: IO ()
main = execParser opts' >>= run
where
opts' = info (helper <*> appOpts <**> versionInfo)
( fullDesc
<> progDesc "Format Android Lint XML output nicely"
<> header "android-lint-summary - a lint-results.xml pretty printer" )

versionInfo = infoOption ("android-lint-summary " ++ showVersion version)
( short 'V'
<> long "version"
<> hidden
<> help "Show version information" )

run :: AppOpts -> IO ()
run args' = do
size <- Terminal.size
let env = AppEnv args' size
files <- findFilesFromArgs args'
lintIssues <- concat <$> forM files (openXMLFile >=> readLintIssues)
mapM_ putChunk $ runReader (formatLintIssues (formatter args') lintIssues) env
main = runCLI
69 changes: 69 additions & 0 deletions src/AndroidLintSummary/CLI.hs
@@ -0,0 +1,69 @@
{-# LANGUAGE NoImplicitPrelude #-}
{-# LANGUAGE OverloadedStrings #-}

module AndroidLintSummary.CLI where

import BasicPrelude hiding (fromString)

import AndroidLintSummary
import Options.Applicative
import Rainbow

import Control.Monad.Reader (runReader)
import Data.Default (def)
import Data.Stringable (Stringable (fromString, toString))
import Data.Version (showVersion)
import Paths_android_lint_summary (version)
import System.Directory (getCurrentDirectory)

import qualified System.Console.Terminal.Size as Terminal
import qualified System.FilePath.Find as Find

findFilesFromArgs :: AppOpts -> IO [FilePath]
findFilesFromArgs args' = go $ targets args'
where
go (Just names) = return names
go Nothing = do
dir <- getCurrentDirectory
Find.find Find.always (Find.filePath Find.~~? pattern args') dir

lintSummaryParser :: ParserInfo AppOpts
lintSummaryParser =
info (helper <*> appOpts <**> versionInfo)
( fullDesc
<> progDesc "Format Android Lint XML output nicely"
<> header "android-lint-summary - a lint-results.xml pretty printer" )
where
appOpts = AppOpts
<$> optional ( some $ argument str (metavar "FILES") )
<*> strOption ( long "glob"
<> short 'g'
<> help "Glob pattern to select result files"
<> value (pattern def)
<> showDefault )
<*> ( fromString <$>
strOption ( long "formatter"
<> short 'f'
<> help "Specify a formatter to use [simple|null]"
<> value (toString . formatter $ def)
<> showDefault ) )
<*> flag Normal Verbose ( long "verbose"
<> short 'v'
<> help "Enable verbose mode" )

versionInfo = infoOption ("android-lint-summary " ++ showVersion version)
( short 'V'
<> long "version"
<> hidden
<> help "Show version information" )

runCLI :: IO ()
runCLI = execParser lintSummaryParser >>= run
where
run :: AppOpts -> IO ()
run args' = do
size <- Terminal.size
let env = AppEnv args' size
files <- findFilesFromArgs args'
lintIssues <- concat <$> forM files (openXMLFile >=> readLintIssues)
mapM_ putChunk $ runReader (formatLintIssues (formatter args') lintIssues) env

0 comments on commit 6f260a4

Please sign in to comment.