48 lines
1.5 KiB
Haskell
48 lines
1.5 KiB
Haskell
{-# LANGUAGE OverloadedStrings #-}
|
|
{- |
|
|
Module : Main
|
|
Copyright : © 2016-2021 John MacFarlane <jgm@berkeley.edu>
|
|
License : GNU GPL, version 2 or above
|
|
|
|
Maintainer : John MacFarlane <jgm@berkeley.edu>
|
|
Stability : alpha
|
|
Portability : portable
|
|
|
|
Benchmarks to determine resource use of readers and writers.
|
|
-}
|
|
import Weigh
|
|
import Text.Pandoc
|
|
import Data.Text (Text, unpack)
|
|
|
|
main :: IO ()
|
|
main = do
|
|
doc <- read <$> readFile "test/testsuite.native"
|
|
mainWith $ do
|
|
func "Pandoc document" id doc
|
|
mapM_
|
|
(\(n,r) -> weighReader doc n (either (error . show) id . runPure . r def{readerExtensions = pandocExtensions}))
|
|
[("markdown", readMarkdown)
|
|
,("html", readHtml)
|
|
,("docbook", readDocBook)
|
|
,("latex", readLaTeX)
|
|
,("commonmark", readCommonMark)
|
|
]
|
|
mapM_
|
|
(\(n,w) -> weighWriter doc n (either (error . show) id . runPure . w def))
|
|
[("markdown", writeMarkdown)
|
|
,("html", writeHtml5String)
|
|
,("docbook", writeDocbook5)
|
|
,("latex", writeLaTeX)
|
|
,("commonmark", writeCommonMark)
|
|
]
|
|
|
|
weighWriter :: Pandoc -> String -> (Pandoc -> Text) -> Weigh ()
|
|
weighWriter doc name writer = func (name ++ " writer") writer doc
|
|
|
|
weighReader :: Pandoc -> Text -> (Text -> Pandoc) -> Weigh ()
|
|
weighReader doc name reader =
|
|
case lookup name writers of
|
|
Just (TextWriter writer) ->
|
|
let inp = either (error . show) id $ runPure $ writer def{ writerWrapText = WrapAuto} doc
|
|
in func (unpack $ name <> " reader") reader inp
|
|
_ -> return () -- no writer for reader
|