1
1
mirror of https://github.com/srid/rib.git synced 2024-11-30 03:45:00 +03:00

Remove PandocFormat; directly use pandoc readers (#75)

Just have the user pass around one of the pandoc reader
functions (re-exported in Rib.Parser.Pandoc) directly instead of having
to know to use a custom wrapper type.
This commit is contained in:
Sridhar Ratnakumar 2020-01-01 17:26:50 -05:00 committed by GitHub
parent 0a2ec4c34d
commit 054e360372
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -9,7 +9,6 @@
-- | Helpers for working with Pandoc documents
module Rib.Parser.Pandoc
( -- * Parsing
PandocFormat (..),
parse,
parsePure,
@ -24,6 +23,7 @@ module Rib.Parser.Pandoc
-- * Re-exports
Pandoc,
module Text.Pandoc.Readers,
)
where
@ -35,36 +35,27 @@ import Path
import Rib.Source (SourceReader)
import Text.Pandoc
import Text.Pandoc.Filter.IncludeCode (includeCode)
import qualified Text.Pandoc.Readers
import Text.Pandoc.Walk (query, walkM)
-- | List of formats supported by Pandoc
--
-- TODO: Complete this list.
data PandocFormat
= PandocFormat_Markdown
| PandocFormat_RST
readPandocFormat :: PandocMonad m => PandocFormat -> ReaderOptions -> Text -> m Pandoc
readPandocFormat = \case
PandocFormat_Markdown -> readMarkdown
PandocFormat_RST -> readRST
-- | Pure version of `parse`
parsePure :: PandocFormat -> Text -> Either Text Pandoc
parsePure fmt s =
parsePure ::
(ReaderOptions -> Text -> PandocPure Pandoc) ->
Text ->
Either Text Pandoc
parsePure textReader s =
first show $ runExcept $ do
runPure'
$ readPandocFormat fmt readerSettings s
runPure' $ textReader readerSettings s
-- | `SourceReader` for parsing a lightweight markup language using Pandoc
-- `SourceReader` for parsing a lightweight markup language using Pandoc
parse ::
-- | The markup format to use when parsing the source. Eg: `PandocFormat_Markdown`
PandocFormat ->
-- | The pandoc text reader function to use, eg: `readMarkdown`
(ReaderOptions -> Text -> PandocIO Pandoc) ->
SourceReader Pandoc
parse fmt (toFilePath -> f) = do
parse textReader (toFilePath -> f) = do
content <- toText <$> readFile' f
fmap (first show) $ runExceptT $ do
v' <- runIO' $ readPandocFormat fmt readerSettings content
v' <- runIO' $ textReader readerSettings content
liftIO $ walkM includeSources v'
where
includeSources = includeCode $ Just $ Format "html5"