diff --git a/pandoc.cabal b/pandoc.cabal index 682d67c36..2a99fc2a2 100644 --- a/pandoc.cabal +++ b/pandoc.cabal @@ -536,8 +536,8 @@ library Text.Pandoc.Readers.Org.ParserState, Text.Pandoc.Readers.Org.Parsing, Text.Pandoc.Readers.Org.Shared, - Text.Pandoc.Readers.Groff, - Text.Pandoc.Writers.Groff, + Text.Pandoc.Readers.Roff, + Text.Pandoc.Writers.Roff, Text.Pandoc.Writers.Powerpoint.Presentation, Text.Pandoc.Writers.Powerpoint.Output, Text.Pandoc.Lua.Filter, @@ -551,7 +551,7 @@ library Text.Pandoc.Lua.Util, Text.Pandoc.CSS, Text.Pandoc.CSV, - Text.Pandoc.GroffChar, + Text.Pandoc.RoffChar, Text.Pandoc.UUID, Text.Pandoc.Translations, Text.Pandoc.Slides, diff --git a/src/Text/Pandoc/Readers/Man.hs b/src/Text/Pandoc/Readers/Man.hs index 90f266e6d..3414d8263 100644 --- a/src/Text/Pandoc/Readers/Man.hs +++ b/src/Text/Pandoc/Readers/Man.hs @@ -49,7 +49,7 @@ import Text.Pandoc.Logging (LogMessage(..)) import Text.Pandoc.Options import Text.Pandoc.Parsing import Text.Pandoc.Shared (crFilter) -import Text.Pandoc.Readers.Groff -- TODO explicit imports +import Text.Pandoc.Readers.Roff -- TODO explicit imports import Text.Parsec hiding (tokenPrim) import qualified Text.Parsec as Parsec import Text.Parsec.Pos (updatePosString) @@ -63,22 +63,22 @@ instance Default ManState where def = ManState { readerOptions = def , metadata = nullMeta } -type ManParser m = ParserT [GroffToken] ManState m +type ManParser m = ParserT [RoffToken] ManState m -- | Read man (troff) from an input string and return a Pandoc document. readMan :: PandocMonad m => ReaderOptions -> T.Text -> m Pandoc readMan opts txt = do - tokenz <- lexGroff (crFilter txt) + tokenz <- lexRoff (crFilter txt) let state = def {readerOptions = opts} :: ManState eitherdoc <- readWithMTokens parseMan state - (Foldable.toList . unGroffTokens $ tokenz) + (Foldable.toList . unRoffTokens $ tokenz) either throwError return eitherdoc readWithMTokens :: PandocMonad m - => ParserT [GroffToken] ManState m a -- ^ parser + => ParserT [RoffToken] ManState m a -- ^ parser -> ManState -- ^ initial state - -> [GroffToken] -- ^ input + -> [RoffToken] -- ^ input -> m (Either PandocError a) readWithMTokens parser state input = let leftF = PandocParsecError . intercalate "\n" $ show <$> input @@ -134,7 +134,7 @@ parseTable = do parseTableCell ts = do st <- getState - let ts' = Foldable.toList $ unGroffTokens ts + let ts' = Foldable.toList $ unRoffTokens ts let tcell = try $ do skipMany memptyLine plain . trimInlines <$> (parseInlines <* eof) @@ -147,7 +147,7 @@ parseTable = do isHrule :: TableRow -> Bool isHrule ([cellfmt], _) = columnType cellfmt `elem` ['_','-','='] - isHrule (_, [GroffTokens ss]) = + isHrule (_, [RoffTokens ss]) = case Foldable.toList ss of [MLine [RoffStr [c]]] -> c `elem` ['_','-','='] _ -> False @@ -174,10 +174,10 @@ parseNewParagraph = do return mempty -- --- Parser: [GroffToken] -> Pandoc +-- Parser: [RoffToken] -> Pandoc -- -msatisfy :: Monad m => (GroffToken -> Bool) -> ParserT [GroffToken] st m GroffToken +msatisfy :: Monad m => (RoffToken -> Bool) -> ParserT [RoffToken] st m RoffToken msatisfy predic = tokenPrim show nextPos testTok where testTok t = if predic t then Just t else Nothing @@ -186,32 +186,32 @@ msatisfy predic = tokenPrim show nextPos testTok (setSourceColumn (setSourceLine pos $ sourceLine pos + 1) 1) "" -mtoken :: PandocMonad m => ManParser m GroffToken +mtoken :: PandocMonad m => ManParser m RoffToken mtoken = msatisfy (const True) -mline :: PandocMonad m => ManParser m GroffToken +mline :: PandocMonad m => ManParser m RoffToken mline = msatisfy isMLine where isMLine (MLine _) = True isMLine _ = False -memptyLine :: PandocMonad m => ManParser m GroffToken +memptyLine :: PandocMonad m => ManParser m RoffToken memptyLine = msatisfy isMEmptyLine where isMEmptyLine MEmptyLine = True isMEmptyLine _ = False -mmacro :: PandocMonad m => MacroKind -> ManParser m GroffToken +mmacro :: PandocMonad m => MacroKind -> ManParser m RoffToken mmacro mk = msatisfy isMMacro where isMMacro (MMacro mk' _ _) | mk == mk' = True | otherwise = False isMMacro _ = False -mmacroAny :: PandocMonad m => ManParser m GroffToken +mmacroAny :: PandocMonad m => ManParser m RoffToken mmacroAny = msatisfy isMMacro where isMMacro (MMacro{}) = True isMMacro _ = False -- --- GroffToken -> Block functions +-- RoffToken -> Block functions -- parseTitle :: PandocMonad m => ManParser m Blocks @@ -340,12 +340,12 @@ lineInl = do (MLine fragments) <- mline return $ linePartsToInlines fragments -bareIP :: PandocMonad m => ManParser m GroffToken +bareIP :: PandocMonad m => ManParser m RoffToken bareIP = msatisfy isBareIP where isBareIP (MMacro "IP" [] _) = True isBareIP _ = False -endmacro :: PandocMonad m => String -> ManParser m GroffToken +endmacro :: PandocMonad m => String -> ManParser m RoffToken endmacro name = mmacro name <|> lookAhead newBlockMacro where newBlockMacro = msatisfy isNewBlockMacro @@ -363,7 +363,7 @@ parseCodeBlock = try $ do where - extractText :: GroffToken -> Maybe String + extractText :: RoffToken -> Maybe String extractText (MLine ss) | not (null ss) , all isFontToken ss = Nothing diff --git a/src/Text/Pandoc/Readers/Groff.hs b/src/Text/Pandoc/Readers/Roff.hs similarity index 84% rename from src/Text/Pandoc/Readers/Groff.hs rename to src/Text/Pandoc/Readers/Roff.hs index ed0b3a1ca..9d71c98b3 100644 --- a/src/Text/Pandoc/Readers/Groff.hs +++ b/src/Text/Pandoc/Readers/Roff.hs @@ -21,7 +21,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -} {- | - Module : Text.Pandoc.Readers.Groff + Module : Text.Pandoc.Readers.Roff Copyright : Copyright (C) 2018 Yan Pashkovsky and John MacFarlane License : GNU GPL, version 2 or above @@ -31,7 +31,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Tokenizer for groff formats (man, ms). -} -module Text.Pandoc.Readers.Groff +module Text.Pandoc.Readers.Roff ( MacroKind , FontSpec(..) , defaultFontSpec @@ -40,10 +40,10 @@ module Text.Pandoc.Readers.Groff , TableOption , CellFormat(..) , TableRow - , GroffToken(..) - , GroffTokens(..) + , RoffToken(..) + , RoffTokens(..) , linePartsToString - , lexGroff + , lexRoff ) where @@ -64,7 +64,7 @@ import Text.Pandoc.Parsing import Text.Pandoc.Shared (safeRead) import Text.Parsec hiding (tokenPrim) import qualified Text.Parsec as Parsec -import Text.Pandoc.GroffChar (characterCodes, combiningAccents) +import Text.Pandoc.RoffChar (characterCodes, combiningAccents) import qualified Data.Sequence as Seq import qualified Data.Foldable as Foldable import qualified Data.Text.Normalize as Normalize @@ -102,22 +102,22 @@ data CellFormat = , columnSuffixes :: [String] } deriving (Show, Eq, Ord) -type TableRow = ([CellFormat], [GroffTokens]) +type TableRow = ([CellFormat], [RoffTokens]) -- TODO parse tables (see man tbl) -data GroffToken = MLine [LinePart] +data RoffToken = MLine [LinePart] | MEmptyLine | MMacro MacroKind [Arg] SourcePos | MTable [TableOption] [TableRow] SourcePos deriving Show -newtype GroffTokens = GroffTokens { unGroffTokens :: Seq.Seq GroffToken } +newtype RoffTokens = RoffTokens { unRoffTokens :: Seq.Seq RoffToken } deriving (Show, Semigroup, Monoid) -singleTok :: GroffToken -> GroffTokens -singleTok t = GroffTokens (Seq.singleton t) +singleTok :: RoffToken -> RoffTokens +singleTok t = RoffTokens (Seq.singleton t) -data RoffState = RoffState { customMacros :: M.Map String GroffTokens +data RoffState = RoffState { customMacros :: M.Map String RoffTokens , prevFont :: FontSpec , currentFont :: FontSpec , tableTabChar :: Char @@ -137,10 +137,10 @@ instance Default RoffState where , tableTabChar = '\t' } -type GroffLexer m = ParserT [Char] RoffState m +type RoffLexer m = ParserT [Char] RoffState m -- --- Lexer: String -> GroffToken +-- Lexer: String -> RoffToken -- eofline :: Stream s m Char => ParsecT s u m () @@ -157,7 +157,7 @@ combiningAccentsMap :: M.Map String Char combiningAccentsMap = M.fromList $ map (\(x,y) -> (y,x)) combiningAccents -escape :: PandocMonad m => GroffLexer m [LinePart] +escape :: PandocMonad m => RoffLexer m [LinePart] escape = do char '\\' c <- anyChar @@ -239,14 +239,14 @@ escape = do Nothing -> mzero Just c -> return c - escUnknown :: PandocMonad m => String -> GroffLexer m [LinePart] + escUnknown :: PandocMonad m => String -> RoffLexer m [LinePart] escUnknown s = do pos <- getPosition report $ SkippedContent ("Unknown escape sequence " ++ s) pos return [RoffStr "\xFFFD"] -- \s-1 \s0 -escFontSize :: PandocMonad m => GroffLexer m [LinePart] +escFontSize :: PandocMonad m => RoffLexer m [LinePart] escFontSize = do let sign = option "" $ ("-" <$ char '-' <|> "" <$ char '+') let toFontSize xs = @@ -268,7 +268,7 @@ escFontSize = do toFontSize (s ++ ds) ] -escFont :: PandocMonad m => GroffLexer m [LinePart] +escFont :: PandocMonad m => RoffLexer m [LinePart] escFont = do font <- choice [ char 'S' >> return defaultFontSpec @@ -282,7 +282,7 @@ escFont = do , currentFont = font } return [Font font] -lettersFont :: PandocMonad m => GroffLexer m FontSpec +lettersFont :: PandocMonad m => RoffLexer m FontSpec lettersFont = try $ do char '[' fs <- many letterFontKind @@ -292,7 +292,7 @@ lettersFont = try $ do then prevFont <$> getState else return $ foldr ($) defaultFontSpec fs -letterFontKind :: PandocMonad m => GroffLexer m (FontSpec -> FontSpec) +letterFontKind :: PandocMonad m => RoffLexer m (FontSpec -> FontSpec) letterFontKind = choice [ oneOf ['B','b'] >> return (\fs -> fs{ fontBold = True }) , oneOf ['I','i'] >> return (\fs -> fs { fontItalic = True }) @@ -303,7 +303,7 @@ letterFontKind = choice [ -- separate function from lexMacro since real man files sometimes do not -- follow the rules -lexComment :: PandocMonad m => GroffLexer m GroffTokens +lexComment :: PandocMonad m => RoffLexer m RoffTokens lexComment = do try $ string ".\\\"" many Parsec.space @@ -311,7 +311,7 @@ lexComment = do char '\n' return mempty -lexMacro :: PandocMonad m => GroffLexer m GroffTokens +lexMacro :: PandocMonad m => RoffLexer m RoffTokens lexMacro = do pos <- getPosition char '.' <|> char '\'' @@ -338,7 +338,7 @@ lexMacro = do "so" -> lexIncludeFile args _ -> resolveMacro macroName args pos -lexTable :: PandocMonad m => SourcePos -> GroffLexer m GroffTokens +lexTable :: PandocMonad m => SourcePos -> RoffLexer m RoffTokens lexTable pos = do skipMany lexComment spaces @@ -360,7 +360,7 @@ lexTable pos = do eofline return $ singleTok $ MTable opts (rows ++ concat morerows) pos -lexTableRows :: PandocMonad m => GroffLexer m [TableRow] +lexTableRows :: PandocMonad m => RoffLexer m [TableRow] lexTableRows = do aligns <- tableFormatSpec spaces @@ -370,8 +370,8 @@ lexTableRows = do tableRow) return $ zip aligns rows -tableCell :: PandocMonad m => GroffLexer m GroffTokens -tableCell = (enclosedCell <|> simpleCell) >>= lexGroff . T.pack +tableCell :: PandocMonad m => RoffLexer m RoffTokens +tableCell = (enclosedCell <|> simpleCell) >>= lexRoff . T.pack where enclosedCell = do try (string "T{") @@ -380,7 +380,7 @@ tableCell = (enclosedCell <|> simpleCell) >>= lexGroff . T.pack tabChar <- tableTabChar <$> getState many (notFollowedBy (char tabChar <|> newline) >> anyChar) -tableRow :: PandocMonad m => GroffLexer m [GroffTokens] +tableRow :: PandocMonad m => RoffLexer m [RoffTokens] tableRow = do tabChar <- tableTabChar <$> getState c <- tableCell @@ -390,10 +390,10 @@ tableRow = do skipMany lexComment return (c:cs) -tableOptions :: PandocMonad m => GroffLexer m [TableOption] +tableOptions :: PandocMonad m => RoffLexer m [TableOption] tableOptions = try $ many1 tableOption <* spaces <* char ';' -tableOption :: PandocMonad m => GroffLexer m TableOption +tableOption :: PandocMonad m => RoffLexer m TableOption tableOption = do k <- many1 letter v <- option "" $ do @@ -404,18 +404,18 @@ tableOption = do skipMany spacetab return (k,v) -tableFormatSpec :: PandocMonad m => GroffLexer m [[CellFormat]] +tableFormatSpec :: PandocMonad m => RoffLexer m [[CellFormat]] tableFormatSpec = do speclines <- tableFormatSpecLine `sepBy1` (newline <|> char ',') skipMany spacetab char '.' return $ speclines ++ repeat (lastDef [] speclines) -- last line is default -tableFormatSpecLine :: PandocMonad m => GroffLexer m [CellFormat] +tableFormatSpecLine :: PandocMonad m => RoffLexer m [CellFormat] tableFormatSpecLine = many1 $ try $ skipMany spacetab >> tableColFormat -tableColFormat :: PandocMonad m => GroffLexer m CellFormat +tableColFormat :: PandocMonad m => RoffLexer m CellFormat tableColFormat = do pipePrefix' <- option False $ True <$ (try $ string "|" <* notFollowedBy spacetab) @@ -442,19 +442,19 @@ tableColFormat = do -- We don't fully handle the conditional. But we do -- include everything under '.ie n', which occurs commonly -- in man pages. We always skip the '.el' part. -lexConditional :: PandocMonad m => GroffLexer m GroffTokens +lexConditional :: PandocMonad m => RoffLexer m RoffTokens lexConditional = do skipMany spacetab lexNCond <|> skipConditional -- n means nroff mode -lexNCond :: PandocMonad m => GroffLexer m GroffTokens +lexNCond :: PandocMonad m => RoffLexer m RoffTokens lexNCond = do char '\n' many1 spacetab lexGroup <|> manToken -lexGroup :: PandocMonad m => GroffLexer m GroffTokens +lexGroup :: PandocMonad m => RoffLexer m RoffTokens lexGroup = do groupstart mconcat <$> manyTill manToken groupend @@ -462,14 +462,14 @@ lexGroup = do groupstart = try $ string "\\{\\" >> newline groupend = try $ string "\\}" >> eofline -skipConditional :: PandocMonad m => GroffLexer m GroffTokens +skipConditional :: PandocMonad m => RoffLexer m RoffTokens skipConditional = do rest <- anyLine when ("\\{\\" `isSuffixOf` rest) $ void $ manyTill anyChar (try (string "\\}")) return mempty -lexIncludeFile :: PandocMonad m => [Arg] -> GroffLexer m GroffTokens +lexIncludeFile :: PandocMonad m => [Arg] -> RoffLexer m RoffTokens lexIncludeFile args = do pos <- getPosition case args of @@ -484,7 +484,7 @@ lexIncludeFile args = do [] -> return mempty resolveMacro :: PandocMonad m - => String -> [Arg] -> SourcePos -> GroffLexer m GroffTokens + => String -> [Arg] -> SourcePos -> RoffLexer m RoffTokens resolveMacro macroName args pos = do macros <- customMacros <$> getState case M.lookup macroName macros of @@ -498,9 +498,9 @@ resolveMacro macroName args pos = do let fillMacroArg (MLine lineparts) = MLine (foldr fillLP [] lineparts) fillMacroArg x = x - return $ GroffTokens . fmap fillMacroArg . unGroffTokens $ ts + return $ RoffTokens . fmap fillMacroArg . unRoffTokens $ ts -lexStringDef :: PandocMonad m => [Arg] -> GroffLexer m GroffTokens +lexStringDef :: PandocMonad m => [Arg] -> RoffLexer m RoffTokens lexStringDef args = do -- string definition case args of [] -> fail "No argument to .ds" @@ -511,7 +511,7 @@ lexStringDef args = do -- string definition st{ customMacros = M.insert stringName ts (customMacros st) } return mempty -lexMacroDef :: PandocMonad m => [Arg] -> GroffLexer m GroffTokens +lexMacroDef :: PandocMonad m => [Arg] -> RoffLexer m RoffTokens lexMacroDef args = do -- macro definition (macroName, stopMacro) <- case args of @@ -530,7 +530,7 @@ lexMacroDef args = do -- macro definition st{ customMacros = M.insert macroName ts (customMacros st) } return mempty -lexArgs :: PandocMonad m => GroffLexer m [Arg] +lexArgs :: PandocMonad m => RoffLexer m [Arg] lexArgs = do args <- many $ try oneArg skipMany spacetab @@ -539,20 +539,20 @@ lexArgs = do where - oneArg :: PandocMonad m => GroffLexer m [LinePart] + oneArg :: PandocMonad m => RoffLexer m [LinePart] oneArg = do skipMany $ try $ string "\\\n" -- continuation line try quotedArg <|> plainArg -- try, because there are some erroneous files, e.g. linux/bpf.2 - plainArg :: PandocMonad m => GroffLexer m [LinePart] + plainArg :: PandocMonad m => RoffLexer m [LinePart] plainArg = do skipMany spacetab mconcat <$> many1 (macroArg <|> escape <|> regularText <|> unescapedQuote) where unescapedQuote = char '"' >> return [RoffStr "\""] - quotedArg :: PandocMonad m => GroffLexer m [LinePart] + quotedArg :: PandocMonad m => RoffLexer m [LinePart] quotedArg = do skipMany spacetab char '"' @@ -567,7 +567,7 @@ lexArgs = do char '"' return [RoffStr "\""] -escStar :: PandocMonad m => GroffLexer m [LinePart] +escStar :: PandocMonad m => RoffLexer m [LinePart] escStar = try $ do pos <- getPosition c <- anyChar @@ -586,14 +586,14 @@ escStar = try $ do -- strings and macros share namespace resolveString stringname pos = do - GroffTokens ts <- resolveMacro stringname [] pos + RoffTokens ts <- resolveMacro stringname [] pos case Foldable.toList ts of [MLine xs] -> return xs _ -> do report $ SkippedContent ("unknown string " ++ stringname) pos return mempty -lexLine :: PandocMonad m => GroffLexer m GroffTokens +lexLine :: PandocMonad m => RoffLexer m RoffTokens lexLine = do lnparts <- mconcat <$> many1 linePart eofline @@ -604,35 +604,35 @@ lexLine = do go (RoffStr "" : xs) = go xs go xs = return $ singleTok $ MLine xs -linePart :: PandocMonad m => GroffLexer m [LinePart] +linePart :: PandocMonad m => RoffLexer m [LinePart] linePart = macroArg <|> escape <|> regularText <|> quoteChar <|> spaceTabChar -macroArg :: PandocMonad m => GroffLexer m [LinePart] +macroArg :: PandocMonad m => RoffLexer m [LinePart] macroArg = try $ do string "\\\\$" x <- digit return [MacroArg $ ord x - ord '0'] -regularText :: PandocMonad m => GroffLexer m [LinePart] +regularText :: PandocMonad m => RoffLexer m [LinePart] regularText = do s <- many1 $ noneOf "\n\r\t \\\"" return [RoffStr s] -quoteChar :: PandocMonad m => GroffLexer m [LinePart] +quoteChar :: PandocMonad m => RoffLexer m [LinePart] quoteChar = do char '"' return [RoffStr "\""] -spaceTabChar :: PandocMonad m => GroffLexer m [LinePart] +spaceTabChar :: PandocMonad m => RoffLexer m [LinePart] spaceTabChar = do c <- spacetab return [RoffStr [c]] -lexEmptyLine :: PandocMonad m => GroffLexer m GroffTokens +lexEmptyLine :: PandocMonad m => RoffLexer m RoffTokens lexEmptyLine = char '\n' >> return (singleTok MEmptyLine) -manToken :: PandocMonad m => GroffLexer m GroffTokens +manToken :: PandocMonad m => RoffLexer m RoffTokens manToken = lexComment <|> lexMacro <|> lexLine <|> lexEmptyLine linePartsToString :: [LinePart] -> String @@ -642,8 +642,8 @@ linePartsToString = mconcat . map go go _ = mempty -- | Tokenize a string as a sequence of groff tokens. -lexGroff :: PandocMonad m => T.Text -> m GroffTokens -lexGroff txt = do +lexRoff :: PandocMonad m => T.Text -> m RoffTokens +lexRoff txt = do eithertokens <- readWithM (mconcat <$> many manToken) def (T.unpack txt) case eithertokens of Left e -> throwError e diff --git a/src/Text/Pandoc/GroffChar.hs b/src/Text/Pandoc/RoffChar.hs similarity index 98% rename from src/Text/Pandoc/GroffChar.hs rename to src/Text/Pandoc/RoffChar.hs index 3f78939c4..52d991d32 100644 --- a/src/Text/Pandoc/GroffChar.hs +++ b/src/Text/Pandoc/RoffChar.hs @@ -19,7 +19,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -} {- | - Module : Text.Pandoc.GroffChar + Module : Text.Pandoc.RoffChar Copyright : Copyright (C) 2007-2018 John MacFarlane License : GNU GPL, version 2 or above @@ -27,10 +27,10 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Stability : alpha Portability : portable -Groff character escaping/unescaping. +Roff character escaping/unescaping. -} -module Text.Pandoc.GroffChar ( +module Text.Pandoc.RoffChar ( standardEscapes , characterCodes , combiningAccents diff --git a/src/Text/Pandoc/Writers/Man.hs b/src/Text/Pandoc/Writers/Man.hs index c4570f761..29e4aa718 100644 --- a/src/Text/Pandoc/Writers/Man.hs +++ b/src/Text/Pandoc/Writers/Man.hs @@ -47,7 +47,7 @@ import Text.Pandoc.Shared import Text.Pandoc.Templates import Text.Pandoc.Writers.Math import Text.Pandoc.Writers.Shared -import Text.Pandoc.Writers.Groff +import Text.Pandoc.Writers.Roff import Text.Printf (printf) -- | Convert Pandoc to Man. diff --git a/src/Text/Pandoc/Writers/Ms.hs b/src/Text/Pandoc/Writers/Ms.hs index 46ddc4c59..6abc4bf93 100644 --- a/src/Text/Pandoc/Writers/Ms.hs +++ b/src/Text/Pandoc/Writers/Ms.hs @@ -60,7 +60,7 @@ import Text.Pandoc.Shared import Text.Pandoc.Templates import Text.Pandoc.Writers.Math import Text.Pandoc.Writers.Shared -import Text.Pandoc.Writers.Groff +import Text.Pandoc.Writers.Roff import Text.Printf (printf) import Text.TeXMath (writeEqn) diff --git a/src/Text/Pandoc/Writers/Groff.hs b/src/Text/Pandoc/Writers/Roff.hs similarity index 97% rename from src/Text/Pandoc/Writers/Groff.hs rename to src/Text/Pandoc/Writers/Roff.hs index 5d51314bb..7bf0c5ee9 100644 --- a/src/Text/Pandoc/Writers/Groff.hs +++ b/src/Text/Pandoc/Writers/Roff.hs @@ -18,7 +18,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -} {- | - Module : Text.Pandoc.Writers.Groff + Module : Text.Pandoc.Writers.Roff Copyright : Copyright (C) 2007-2018 John MacFarlane License : GNU GPL, version 2 or above @@ -29,7 +29,7 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Common functions for groff writers (man, ms). -} -module Text.Pandoc.Writers.Groff ( +module Text.Pandoc.Writers.Roff ( WriterState(..) , defaultWriterState , MS @@ -47,7 +47,7 @@ import Text.Pandoc.Class (PandocMonad) import Text.Pandoc.Definition import Text.Pandoc.Pretty import Text.Printf (printf) -import Text.Pandoc.GroffChar (standardEscapes, +import Text.Pandoc.RoffChar (standardEscapes, characterCodes, combiningAccents) data WriterState = WriterState { stHasInlineMath :: Bool