{- | Module : Main Copyright : Copyright (C) 2006-2022 John MacFarlane License : GNU GPL, version 2 or above Maintainer : John MacFarlane Stability : alpha Portability : portable Parses command-line options and calls the appropriate readers and writers. -} module Main where import qualified Control.Exception as E import Text.Pandoc.App (convertWithOpts, defaultOpts, options, parseOptions) import Text.Pandoc.Error (handleError) import Text.Pandoc.Server (ServerOpts(..), parseServerOpts, app) import System.Environment (getProgName) import qualified Network.Wai.Handler.CGI as CGI import qualified Network.Wai.Handler.Warp as Warp import Network.Wai.Middleware.Timeout (timeout) main :: IO () main = E.handle (handleError . Left) $ do prg <- getProgName case prg of "pandoc-server.cgi" -> CGI.run (timeout 2 app) "pandoc-server" -> do sopts <- parseServerOpts Warp.run (serverPort sopts) (timeout (serverTimeout sopts) app) _ -> parseOptions options defaultOpts >>= convertWithOpts