-- (c) 2007 Andy Gill
-- Main driver for Hpc
-import Trace.Hpc.Tix
import HpcFlags
import System.Environment
import System.Exit
help = ["help"]
reporting = ["report","markup"]
overlays = ["overlay","draft"]
- processing = ["combine"]
+ processing = ["sum","combine","map"]
other = [ name hook
| hook <- hooks
, name hook `notElem`
]
section :: String -> [String] -> String
-section msg [] = ""
+section _ [] = ""
section msg cmds = msg ++ ":\n"
++ unlines [ take 14 (" " ++ cmd ++ repeat ' ') ++ summary hook
| cmd <- cmds
dispatch [] = do
helpList
exitWith ExitSuccess
-dispatch (txt:args) = do
+dispatch (txt:args0) = do
case lookup txt hooks' of
- Just plugin -> parse plugin args
- _ -> parse help_plugin (txt:args)
+ Just plugin -> parse plugin args0
+ _ -> parse help_plugin (txt:args0)
where
parse plugin args =
case getOpt Permute (options plugin []) args of
$ foldr (.) id o
$ init_flags plugin
implementation plugin flags ns
+
+main :: IO ()
main = do
args <- getArgs
dispatch args
------------------------------------------------------------------------------
+hooks :: [Plugin]
hooks = [ help_plugin
, report_plugin
, markup_plugin
+ , sum_plugin
, combine_plugin
+ , map_plugin
, showtix_plugin
, overlay_plugin
, draft_plugin
, version_plugin
]
+hooks' :: [(String, Plugin)]
hooks' = [ (name hook,hook) | hook <- hooks ]
------------------------------------------------------------------------------
+help_plugin :: Plugin
help_plugin = Plugin { name = "help"
, usage = "[<HPC_COMMAND>]"
- , summary = "Display help for hpc or a single command."
+ , summary = "Display help for hpc or a single command"
, options = help_options
, implementation = help_main
, init_flags = default_flags
, final_flags = default_final_flags
}
-help_main flags [] = do
+help_main :: Flags -> [String] -> IO ()
+help_main _ [] = do
helpList
exitWith ExitSuccess
-help_main flags (sub_txt:_) = do
+help_main _ (sub_txt:_) = do
case lookup sub_txt hooks' of
Nothing -> do
putStrLn $ "no such hpc command : " ++ sub_txt
command_usage plugin'
exitWith ExitSuccess
+help_options :: FlagOptSeq
help_options = id
------------------------------------------------------------------------------
+version_plugin :: Plugin
version_plugin = Plugin { name = "version"
, usage = ""
, summary = "Display version for hpc"
, final_flags = default_final_flags
}
-version_main _ _ = putStrLn $ "hpc tools, version 0.5-dev"
+version_main :: Flags -> [String] -> IO ()
+version_main _ _ = putStrLn $ "hpc tools, version 0.6"
-------------------------------------------------------------------------------
\ No newline at end of file
+------------------------------------------------------------------------------