2018-03-18 19:45:25 +01:00
|
|
|
{-# LANGUAGE NoImplicitPrelude #-}
|
|
|
|
import Prelude
|
2016-11-18 14:03:08 +01:00
|
|
|
import Weigh
|
|
|
|
import Text.Pandoc
|
2017-06-10 23:39:49 +02:00
|
|
|
import Data.Text (Text)
|
2016-11-18 14:03:08 +01:00
|
|
|
|
|
|
|
main :: IO ()
|
|
|
|
main = do
|
2017-02-25 10:31:40 +01:00
|
|
|
doc <- read <$> readFile "test/testsuite.native"
|
2016-11-18 14:03:08 +01:00
|
|
|
mainWith $ do
|
|
|
|
func "Pandoc document" id doc
|
|
|
|
mapM_
|
2017-03-15 15:00:17 +01:00
|
|
|
(\(n,r) -> weighReader doc n (either (error . show) id . runPure . r def{readerExtensions = pandocExtensions}))
|
2016-11-18 14:03:08 +01:00
|
|
|
[("markdown", readMarkdown)
|
|
|
|
,("html", readHtml)
|
|
|
|
,("docbook", readDocBook)
|
|
|
|
,("latex", readLaTeX)
|
|
|
|
,("commonmark", readCommonMark)
|
|
|
|
]
|
|
|
|
mapM_
|
2016-12-10 23:42:28 +01:00
|
|
|
(\(n,w) -> weighWriter doc n (either (error . show) id . runPure . w def))
|
2016-11-18 14:03:08 +01:00
|
|
|
[("markdown", writeMarkdown)
|
2017-03-15 15:00:17 +01:00
|
|
|
,("html", writeHtml5String)
|
|
|
|
,("docbook", writeDocbook5)
|
2016-11-18 14:03:08 +01:00
|
|
|
,("latex", writeLaTeX)
|
|
|
|
,("commonmark", writeCommonMark)
|
|
|
|
]
|
|
|
|
|
2017-06-10 23:39:49 +02:00
|
|
|
weighWriter :: Pandoc -> String -> (Pandoc -> Text) -> Weigh ()
|
2016-11-18 14:03:08 +01:00
|
|
|
weighWriter doc name writer = func (name ++ " writer") writer doc
|
|
|
|
|
2017-06-10 21:10:52 +02:00
|
|
|
weighReader :: Pandoc -> String -> (Text -> Pandoc) -> Weigh ()
|
2016-11-18 14:03:08 +01:00
|
|
|
weighReader doc name reader = do
|
|
|
|
case lookup name writers of
|
2017-06-10 23:39:49 +02:00
|
|
|
Just (TextWriter writer) ->
|
|
|
|
let inp = either (error . show) id $ runPure $ writer def{ writerWrapText = WrapAuto} doc
|
2016-11-18 14:03:08 +01:00
|
|
|
in func (name ++ " reader") reader inp
|
|
|
|
_ -> return () -- no writer for reader
|
|
|
|
|
|
|
|
|