From c2ae72aa6cee5aebb85228b5cc6fe6a620cf42f7 Mon Sep 17 00:00:00 2001 From: Yan Pas Date: Sun, 27 May 2018 14:09:34 +0300 Subject: [PATCH] custom ordered lists --- src/Text/Pandoc/Readers/Man.hs | 42 +++++++++++++++++++++------------- 1 file changed, 26 insertions(+), 16 deletions(-) diff --git a/src/Text/Pandoc/Readers/Man.hs b/src/Text/Pandoc/Readers/Man.hs index 9797d2811..adac1aca8 100644 --- a/src/Text/Pandoc/Readers/Man.hs +++ b/src/Text/Pandoc/Readers/Man.hs @@ -39,7 +39,7 @@ import Control.Monad.Except (throwError) import Data.Char (isDigit, isUpper, isLower) import Data.Default (Default) import Data.Map (insert) -import Data.Maybe (catMaybes) +import Data.Maybe (catMaybes, fromMaybe, isNothing) import Data.List (intersperse, intercalate) import qualified Data.Text as T @@ -153,7 +153,7 @@ lexMan = many (lexMacro <|> lexLine <|> lexEmptyLine) parseMan :: PandocMonad m => ManParser m Pandoc parseMan = do - let parsers = [ try parseBulletList, parseTitle, parsePara, parseSkippedContent + let parsers = [ try parseList, parseTitle, parsePara, parseSkippedContent , parseCodeBlock, parseHeader, parseSkipMacro] blocks <- many $ choice parsers parserst <- getState @@ -210,7 +210,7 @@ escapeLexer = do letterFont = choice [ char 'B' >> return Bold , char 'I' >> return Italic - , char 'P' >> return Regular + , (char 'P' <|> char 'R') >> return Regular ] currentFont :: PandocMonad m => ManLexer m FontKind @@ -248,6 +248,7 @@ lexMacro = do where + -- TODO rework args lexArgs :: PandocMonad m => ManLexer m [RoffStr] lexArgs = do args <- many oneArg @@ -478,38 +479,47 @@ parseHeader = do (MHeader lvl ss) <- mheader return $ Header lvl nullAttr $ intersperse Space $ strToInline <$> ss -parseBulletList :: PandocMonad m => ManParser m Block -parseBulletList = BulletList <$> many1 paras where +type ListBuilder = [[Block]] -> Block + +parseList :: PandocMonad m => ManParser m Block +parseList = do + xx <- many1 paras + let bls = map snd xx + let bldr = fst $ head xx + return $ bldr bls + + where macroIPInl :: [RoffStr] -> [Inline] macroIPInl (x:_:[]) = [strToInline x, Space] macroIPInl _ = [] - listKind :: [RoffStr] -> Maybe ([[Block]] -> Block) + listKind :: [RoffStr] -> Maybe ListBuilder listKind (((c:_), _):_:[]) = let params style = OrderedList (1, style, DefaultDelim) - in Just $ case c of - _ | isDigit c -> params Decimal - _ | isUpper c -> params UpperAlpha - _ | isLower c -> params LowerAlpha - _ -> BulletList + in case c of + _ | isDigit c -> Just $ params Decimal + _ | isUpper c -> Just $ params UpperAlpha + _ | isLower c -> Just $ params LowerAlpha + _ -> Nothing listKind _ = Nothing - paras :: PandocMonad m => ManParser m [Block] + paras :: PandocMonad m => ManParser m (ListBuilder, [Block]) paras = do (MMacro _ args) <- mmacro KTab - let lk = listKind args + let lbuilderOpt = listKind args + let lbuilder = fromMaybe BulletList lbuilderOpt inls <- parseInlines let macroinl = macroIPInl args - let para = Plain $ macroinl ++ inls + let parainls = if isNothing lbuilderOpt then macroinl ++ inls else inls subls <- many sublist - return $ para : subls + return $ (lbuilder, (Plain parainls) : subls) sublist :: PandocMonad m => ManParser m Block sublist = do mmacro KSubTab - bl <- parseBulletList + bl <- parseList mmacro KTabEnd return bl