summaryrefslogtreecommitdiff
path: root/Usage.hs
blob: 34c344b1831f78e97eb15616c2fcb3cd647b3f90 (plain)
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
{- git-annex usage messages
 -
 - Copyright 2010-2011 Joey Hess <joey@kitenet.net>
 -
 - Licensed under the GNU GPL version 3 or higher.
 -}

module Usage where

import System.Console.GetOpt

import Types.Command
import Types.Option

{- Usage message with lists of commands and options. -}
usage :: String -> [Command] -> [Option] -> String
usage header cmds commonoptions = unlines $ 
	[ header
	, ""
	, "Options:"
	] ++ optlines ++
	[ ""
	, "Commands:"
	, ""
	] ++ cmdlines
	where
		-- To get consistent indentation of options, generate the
		-- usage for all options at once. A command's options will
		-- be displayed after the command.
		alloptlines = filter (not . null) $
			lines $ usageInfo "" $
				concatMap cmdoptions cmds ++ commonoptions
		(cmdlines, optlines) = go cmds alloptlines []
		go [] os ls = (ls, os)
		go (c:cs) os ls = go cs os' (ls++(l:o))
			where
				(o, os') = splitAt (length $ cmdoptions c) os
				l = concat 
					[ cmdname c
					, namepad (cmdname c)
					, cmdparamdesc c
					, descpad (cmdparamdesc c)
					, cmddesc c
					]
		pad n s = replicate (n - length s) ' '
		namepad = pad $ longest cmdname + 1
		descpad = pad $ longest cmdparamdesc + 2
		longest f = foldl max 0 $ map (length . f) cmds

{- Descriptions of params used in usage messages. -}
paramPaths :: String
paramPaths = paramOptional $ paramRepeating paramPath -- most often used
paramPath :: String
paramPath = "PATH"
paramKey :: String
paramKey = "KEY"
paramDesc :: String
paramDesc = "DESC"
paramUrl :: String
paramUrl = "URL"
paramNumber :: String
paramNumber = "NUMBER"
paramRemote :: String
paramRemote = "REMOTE"
paramGlob :: String
paramGlob = "GLOB"
paramName :: String
paramName = "NAME"
paramValue :: String
paramValue = "VALUE"
paramUUID :: String
paramUUID = "UUID"
paramType :: String
paramType = "TYPE"
paramDate :: String
paramDate = "DATE"
paramFormat :: String
paramFormat = "FORMAT"
paramKeyValue :: String
paramKeyValue = "K=V"
paramNothing :: String
paramNothing = ""
paramRepeating :: String -> String
paramRepeating s = s ++ " ..."
paramOptional :: String -> String
paramOptional s = "[" ++ s ++ "]"
paramPair :: String -> String -> String
paramPair a b = a ++ " " ++ b