forked from jgm/pandoc
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Lua: add function
pandoc.utils.run_lua_filter
- Loading branch information
Showing
5 changed files
with
94 additions
and
61 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
{-# LANGUAGE OverloadedStrings #-} | ||
{-# LANGUAGE TypeApplications #-} | ||
{- | | ||
Module : Text.Pandoc.Lua.Engine | ||
Copyright : Copyright © 2017-2024 Albert Krewinkel | ||
License : GPL-2.0-or-later | ||
Maintainer : Albert Krewinkel <tarleb+pandoc@zeitkraut.de> | ||
Running pandoc Lua filters. | ||
-} | ||
module Text.Pandoc.Lua.Engine | ||
( getEngine | ||
, applyFilter | ||
) where | ||
|
||
import Control.Exception (throw) | ||
import Control.Monad ((>=>)) | ||
import Control.Monad.IO.Class (MonadIO (liftIO)) | ||
import HsLua.Core (getglobal, openlibs, run, top, tostring) | ||
import Text.Pandoc.Class (PandocMonad) | ||
import Text.Pandoc.Definition (Pandoc) | ||
import Text.Pandoc.Filter (Environment (..)) | ||
import Text.Pandoc.Error (PandocError (PandocFilterError, PandocLuaError)) | ||
import Text.Pandoc.Lua.Filter (runFilterFile) | ||
import Text.Pandoc.Lua.Global (Global (..), setGlobals) | ||
import Text.Pandoc.Lua.Init (runLua) | ||
import Text.Pandoc.Lua.Custom (loadCustom) | ||
import Text.Pandoc.Lua.Orphans () | ||
import Text.Pandoc.Scripting (ScriptingEngine (..)) | ||
import qualified Text.Pandoc.UTF8 as UTF8 | ||
import qualified Data.Text as T | ||
|
||
-- | Constructs the Lua scripting engine. | ||
getEngine :: MonadIO m => m ScriptingEngine | ||
getEngine = do | ||
versionName <- liftIO . run @PandocError $ do | ||
openlibs | ||
getglobal "_VERSION" | ||
tostring top | ||
pure $ ScriptingEngine | ||
{ engineName = maybe "Lua (unknown version)" UTF8.toText versionName | ||
, engineApplyFilter = applyFilter | ||
, engineLoadCustom = loadCustom | ||
} | ||
|
||
-- | Run the Lua filter in @filterPath@ for a transformation to the | ||
-- target format (first element in args). Pandoc uses Lua init files to | ||
-- setup the Lua interpreter. | ||
applyFilter :: (PandocMonad m, MonadIO m) | ||
=> Environment | ||
-> [String] | ||
-> FilePath | ||
-> Pandoc | ||
-> m Pandoc | ||
applyFilter fenv args fp doc = do | ||
let globals = [ FORMAT $ case args of | ||
x:_ -> T.pack x | ||
_ -> "" | ||
, PANDOC_READER_OPTIONS (envReaderOptions fenv) | ||
, PANDOC_WRITER_OPTIONS (envWriterOptions fenv) | ||
, PANDOC_SCRIPT_FILE fp | ||
] | ||
runLua >=> forceResult fp $ do | ||
setGlobals globals | ||
runFilterFile fp doc | ||
|
||
forceResult :: (PandocMonad m, MonadIO m) | ||
=> FilePath -> Either PandocError Pandoc -> m Pandoc | ||
forceResult fp eitherResult = case eitherResult of | ||
Right x -> return x | ||
Left err -> throw . PandocFilterError (T.pack fp) $ case err of | ||
PandocLuaError msg -> msg | ||
_ -> T.pack $ show err |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters