" ++ unwords (map linkify $ sort ls) ++ "
" ++ "\n" where linkify l = a $ Anchor [ Attribute "name" (sanitizeAnchor l) , Attribute "href" (gitHubAnchor l) ] (codify l) h1 :: String -> String h1 = heading 1 h2 :: String -> String h2 = heading 2 h3 :: String -> String h3 = heading 3 heading :: Int -> String -> String heading level string = replicate level '#' ++ " " ++ string ++ "\n\n" -- | Wraps a string in ``/`
` tags.
-- TODO: remember why I'm not using backticks here.
codify :: String -> String
codify s = "" ++ s ++ "
"
a :: Anchor -> String
a (Anchor attributes target) = "" ++ target ++ ""
where
attrs = if not (null attributes)
then " " ++ attributesString attributes
else ""
attributesString :: [Attribute] -> String
attributesString as = unwords (map attributeToString as)
where attributeToString (Attribute name value) = name ++ "=\"" ++ value ++ "\""
gitHubAnchor :: String -> String
gitHubAnchor n = "#user-content-" ++ sanitizeAnchor n
-- TODO: make sure symbol table knows about option targets too
option :: Node -> String
option (OptionAnnotation n t d) = targets ++ h
where targets = linkTargets [n]
h = h3 $ "`" ++ n ++ "` (" ++ t ++ ", default: " ++ def ++ ")"
def = fromMaybe "none" d
command :: Node -> String
command (CommandAnnotation name params) = target ++ content
where target = linkTargets [":" ++ name]
content = h3 $ "`:" ++ annotation ++ "`"
annotation = rstrip $ name ++ " " ++ fromMaybe "" params
mapping :: String -> String
mapping name = h3 $ "`" ++ name ++ "`"