2010-12-07 21:10:07 +01:00
|
|
|
-- Create pandoc.1 man page from README
|
|
|
|
import Text.Pandoc
|
|
|
|
import Data.ByteString.UTF8 (toString, fromString)
|
|
|
|
import Data.Char (toUpper)
|
|
|
|
import qualified Data.ByteString as B
|
|
|
|
import Control.Monad
|
|
|
|
import System.FilePath
|
|
|
|
|
|
|
|
main = do
|
|
|
|
rmContents <- liftM toString $ B.readFile "README"
|
|
|
|
let (Pandoc meta blocks) = readMarkdown defaultParserState rmContents
|
|
|
|
let newBlocks = removeWrapperSect blocks
|
|
|
|
manTemplate <- liftM toString $ B.readFile "manpage.template"
|
|
|
|
let opts = defaultWriterOptions{ writerStandalone = True
|
|
|
|
, writerTemplate = manTemplate }
|
|
|
|
let manPage = writeMan opts $
|
2010-12-24 22:39:27 +01:00
|
|
|
bottomUp (concatMap removeLinks) $
|
|
|
|
bottomUp capitalizeHeaders $
|
2010-12-07 21:10:07 +01:00
|
|
|
Pandoc meta newBlocks
|
|
|
|
B.writeFile ("man" </> "man1" </> "pandoc.1") $ fromString manPage
|
|
|
|
|
|
|
|
removeLinks :: Inline -> [Inline]
|
|
|
|
removeLinks (Link l _) = l
|
|
|
|
removeLinks x = [x]
|
|
|
|
|
|
|
|
capitalizeHeaders :: Block -> Block
|
2010-12-24 22:39:27 +01:00
|
|
|
capitalizeHeaders (Header 1 xs) = Header 1 $ bottomUp capitalize xs
|
2010-12-07 21:10:07 +01:00
|
|
|
capitalizeHeaders x = x
|
|
|
|
|
|
|
|
capitalize :: Inline -> Inline
|
|
|
|
capitalize (Str xs) = Str $ map toUpper xs
|
|
|
|
capitalize x = x
|
|
|
|
|
|
|
|
removeWrapperSect :: [Block] -> [Block]
|
|
|
|
removeWrapperSect (Header 1 [Str "Wrappers"]:xs) =
|
|
|
|
dropWhile notLevelOneHeader xs
|
|
|
|
where notLevelOneHeader (Header 1 _) = False
|
|
|
|
notLevelOneHeader _ = True
|
|
|
|
removeWrapperSect (x:xs) = x : removeWrapperSect xs
|
|
|
|
removeWrapperSect [] = []
|