cli: commands list: show addons prefixed with +
This commit is contained in:
parent
b92aa4b89e
commit
a9eb84a451
@ -41,6 +41,7 @@ module Hledger.Cli.Commands (
|
||||
)
|
||||
where
|
||||
|
||||
import Data.Char (isSpace)
|
||||
import Data.Default
|
||||
import Data.List
|
||||
import Data.List.Split (splitOn)
|
||||
@ -114,30 +115,33 @@ builtinCommands = [
|
||||
]
|
||||
|
||||
-- | The commands list, showing command names, standard aliases,
|
||||
-- and short descriptions. This has some dynamic features, as follows:
|
||||
-- and short descriptions. This is modified at runtime, as follows:
|
||||
--
|
||||
-- PROGVERSION is replaced with the program name and version.
|
||||
--
|
||||
-- Each indented line represents a command. There are three kinds:
|
||||
-- Lines beginning with a space represent builtin commands, with format:
|
||||
-- COMMAND (ALIASES) DESCRIPTION
|
||||
-- These should be kept synced with builtinCommands above, and
|
||||
-- their docs (Commands/\*.md).
|
||||
--
|
||||
-- - builtin commands; these should be kept synced with the
|
||||
-- above builtinCommands and their docs (Commands/\*.md).
|
||||
-- Lines beginning with + represent known addon commands. These lines
|
||||
-- will be suppressed if hledger-CMD is not found in $PATH at runtime.
|
||||
--
|
||||
-- - known addon commands; these lines will be suppressed if the addon
|
||||
-- command is not found in $PATH at runtime.
|
||||
-- OTHER is replaced with additional command lines (without descriptions)
|
||||
-- for any unknown addon commands found in $PATH at runtime.
|
||||
--
|
||||
-- - additional command examples beginning with "hledger".
|
||||
-- TODO: generate more of this automatically.
|
||||
--
|
||||
-- OTHER is replaced with entries for any additional (unknown) addon
|
||||
-- commands found in $PATH at runtime.
|
||||
commandsList :: String
|
||||
commandsList = [here|
|
||||
-------------------------------------------------------------------------------
|
||||
PROGVERSION, commands available:
|
||||
PROGVERSION
|
||||
Usage: hledger COMMAND [OPTIONS] [-- ADDONCMDOPTIONS]
|
||||
Commands (+ addons found in $PATH):
|
||||
|
||||
Data entry:
|
||||
add add transactions using console ui
|
||||
iadd add transactions using curses ui
|
||||
+iadd add transactions using curses ui
|
||||
import add new transactions from one or more import files
|
||||
edit open a text editor on some part of the journal
|
||||
|
||||
@ -150,7 +154,6 @@ Statements:
|
||||
Basic reports:
|
||||
accounts (a) show account names
|
||||
activity show a chart of posting counts per interval
|
||||
aregister (ar, areg) show transactions in a single account
|
||||
balance (b, bal) show account balance changes or ending balances
|
||||
files show input files
|
||||
prices show market price records
|
||||
@ -160,24 +163,22 @@ Basic reports:
|
||||
tags show tag names
|
||||
|
||||
UIs:
|
||||
ui start curses ui
|
||||
web start web ui
|
||||
+ui start curses ui
|
||||
+web start web ui
|
||||
|
||||
Generating data:
|
||||
close (equity) generate balance-resetting transactions
|
||||
interest generate interest transactions
|
||||
+interest generate interest transactions
|
||||
rewrite generate automated postings on matched transactions
|
||||
|
||||
Other/experimental:
|
||||
api start web api server
|
||||
autosync download/deduplicate/convert OFX data
|
||||
budget add automated postings/txns/bucket accts
|
||||
chart generate simple balance pie charts
|
||||
check check more powerful balance assertions
|
||||
+api start web api server
|
||||
+autosync download/deduplicate/convert OFX data
|
||||
+check check more powerful balance assertions
|
||||
check-dates check transactions are ordered by date
|
||||
check-dupes check for accounts with the same leaf name
|
||||
diff compare account transactions in two journal files
|
||||
irr calculate internal rate of return of an investment
|
||||
+diff compare account transactions in two journal files
|
||||
+irr calculate internal rate of return (obsolete, see roi)
|
||||
print-unique show only transactions with unique descriptions
|
||||
register-match show best matching transaction for a description
|
||||
roi calculate return on investments
|
||||
@ -189,6 +190,7 @@ Help:
|
||||
hledger -h show general usage
|
||||
-------------------------------------------------------------------------------
|
||||
|]
|
||||
-- aregister (ar, areg) show transactions in a single account
|
||||
|
||||
|
||||
-- | All names and aliases of builtin commands.
|
||||
@ -206,19 +208,20 @@ printCommandsList :: [String] -> IO ()
|
||||
printCommandsList addonsFound =
|
||||
putStr $
|
||||
regexReplace "PROGVERSION" (prognameandversion) $
|
||||
regexReplace "OTHER" (unlines $ map (' ':) unknownCommandsFound) $
|
||||
regexReplace "OTHER" (unlines unknownCommandsFound) $
|
||||
-- regexReplace "COUNT" (show cmdcount) $
|
||||
unlines $ concatMap adjustline $ lines $
|
||||
cmdlist
|
||||
where
|
||||
cmdlist = commandsList
|
||||
-- cmdcount = length $ commandsFromCommandsList cmdlist
|
||||
commandsFound = builtinCommandNames ++ addonsFound
|
||||
unknownCommandsFound = addonsFound \\ knownCommands
|
||||
commandsFound = map (' ':) builtinCommandNames ++ map ('+':) addonsFound
|
||||
unknownCommandsFound = map ('+':) $ addonsFound \\ knownCommands
|
||||
|
||||
adjustline l | " hledger " `isPrefixOf` l = [l]
|
||||
adjustline (' ':l) | not $ w `elem` commandsFound = []
|
||||
where w = takeWhile (not . (`elem` ['|',' '])) l
|
||||
adjustline l | " hledger " `isPrefixOf` l = [l]
|
||||
adjustline l@('+':_) | not $ cmd `elem` commandsFound = []
|
||||
where
|
||||
cmd = takeWhile (not . isSpace) l
|
||||
adjustline l = [l]
|
||||
|
||||
knownCommands :: [String]
|
||||
|
||||
Loading…
Reference in New Issue
Block a user