-- Support for @darcs help markdown@
module Darcs.UI.Options.Markdown ( optionsMarkdown ) where
import Darcs.Prelude
import Data.Functor.Compose ( Compose(..) )
import System.Console.GetOpt ( OptDescr(..), ArgDescr(..) )
import Darcs.UI.Options.Util ( DarcsOptDescr )
optionsMarkdown :: [DarcsOptDescr f] -> String
optionsMarkdown opts = unlines
[ "
", unlines (map optionMarkdown opts), "
" ]
optionMarkdown :: DarcsOptDescr f -> String
optionMarkdown (Compose (Option a b (NoArg _) h)) = unlines
[ "", "", showShortOptionsMd a, " | "
, "", showLongOptionsMd b , " | "
, "", h, " | "
, "
" ]
optionMarkdown (Compose (Option a b (ReqArg _ arg) h)) = unlines
[ "", "", showShortOptionsMd a, " | "
, "", showLongOptionsMd (map (++(' ' : arg)) b), " | "
, "", h, " | ", "
" ]
optionMarkdown (Compose (Option a b (OptArg _ arg) h)) = unlines
[ "", "", showShortOptionsMd a, " | "
, "", showLongOptionsMd (map (++("[="++arg++"]")) b), " | "
, "", h, " | ", "
" ]
showShortOptionsMd :: [Char] -> String
showShortOptionsMd [] = ""
showShortOptionsMd [c] = "`-"++[c]++"` "
showShortOptionsMd (c:cs) = "`-"++[c]++"`,"++showShortOptionsMd cs
showLongOptionsMd :: [String] -> String
showLongOptionsMd [] = " "
showLongOptionsMd [s] = "`--" ++ s ++ "` "
showLongOptionsMd (s:ss) = "`--" ++ s ++ "`,"++ showLongOptionsMd ss