diff options
Diffstat (limited to 'app/Main.hs')
-rw-r--r-- | app/Main.hs | 36 |
1 files changed, 16 insertions, 20 deletions
diff --git a/app/Main.hs b/app/Main.hs index fe802ad..da4ea6a 100644 --- a/app/Main.hs +++ b/app/Main.hs @@ -448,18 +448,14 @@ data Command filters :: [I.Filter], sort :: [I.Sort], group :: Maybe T.Text, - closed :: Bool + closed :: Bool, + detailed :: Bool } | Log { patch :: Bool } | Show - { -- TODO Replace `anissue show` with `anissue list --detailed` - -- - -- The `Show` command has recently been changed to allow showing multiple issues. However, filtering, soring, grouping, etc. is still lacking and would be useful for this mode. - -- - -- Instead of copying over that functionality, and somehow explain that they are only sensible when omitting the optional `id` parameter, I would like to revert that change and add `--detailed` to `anissue list` which would show issues in the `Detailed` reporting style. - id :: Maybe String, + { id :: String, edit :: Bool } | Tags @@ -486,6 +482,7 @@ listCmd = <*> I.sortArg <*> I.groupArg <*> closedArg + <*> detailedArg logCmd :: O.Parser Command logCmd = @@ -495,7 +492,7 @@ logCmd = showCmd :: O.Parser Command showCmd = Show - <$> O.optional idArg + <$> idArg <*> editFlag tagsCmd :: O.Parser Command @@ -512,6 +509,13 @@ closedArg = <> O.help "Show closed issues." ) +detailedArg :: O.Parser Bool +detailedArg = + O.switch + ( O.long "detailed" + <> O.help "Show issues detailed (as in show)." + ) + idArg :: O.Parser String idArg = O.strArgument @@ -557,7 +561,7 @@ main = do <$> getHistory let groupedIssues = I.groupIssuesByTag group ungroupedIssues putDoc colorize noPager width (group, groupedIssues) - Options {colorize, noPager, width, command = List {sort, filters, files, group = Nothing, closed}} -> do + Options {colorize, noPager, width, command = List {sort, filters, files, group = Nothing, closed, detailed}} -> do issues <- I.applySorts sort . I.applyFilters filters @@ -566,22 +570,14 @@ main = do . (.issues) <$> getHistory putDoc colorize noPager width . (P.vsep . intersperse "") $ - map (P.render . P.Summarized) issues + map (if detailed then (P.render . P.Detailed) else (P.render . P.Summarized)) issues Options {colorize, noPager, width, command = Log {patch}} -> do es <- reverse . (.issueEvents) <$> getHistory putDoc colorize noPager width . P.vsep $ if patch then map (P.render . P.Detailed) es else map (P.render . P.Summarized) es - Options {colorize, noPager, width, command = Show {id = Nothing}} -> do - issues <- - I.applySorts [] - . I.applyFilters [] - . I.applyClosed False - . (.issues) - <$> getHistory - putDoc colorize noPager width . P.vsep $ map (showIssue issues) issues - Options {colorize, noPager, width, command = Show {id = Just id, edit}} -> do + Options {colorize, noPager, width, command = Show {id, edit}} -> do issues <- (.issues) <$> getHistory issue <- case find ((==) id . T.unpack . I.id) issues of @@ -590,7 +586,7 @@ main = do if edit then do withSystemTempFile (printf "%s.md" id) $ \fp h -> do - LT.hPutStr h (LT.fromStrict issue.rawText) + T.hPutStr h (issue.rawText) hFlush h hClose h sh_ (proc "${EDITOR-vi} -- %" fp) |