From 6fc812485e26f169bfe560b5f78c572378cbc53a Mon Sep 17 00:00:00 2001 From: Alexander Krotov Date: Wed, 17 Oct 2018 15:42:57 +0300 Subject: [PATCH] Muse reader: allow examples to be indented with tabs --- src/Text/Pandoc/Readers/Muse.hs | 13 +++++-------- test/Tests/Readers/Muse.hs | 8 ++++++++ 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/src/Text/Pandoc/Readers/Muse.hs b/src/Text/Pandoc/Readers/Muse.hs index 5d417e717..3b64fe5ef 100644 --- a/src/Text/Pandoc/Readers/Muse.hs +++ b/src/Text/Pandoc/Readers/Muse.hs @@ -45,7 +45,7 @@ import Control.Monad.Reader import Control.Monad.Except (throwError) import Data.Bifunctor import Data.Default -import Data.List (intercalate) +import Data.List (intercalate, transpose) import Data.List.Split (splitOn) import qualified Data.Map as M import qualified Data.Set as Set @@ -135,9 +135,6 @@ parseMuse = do -- * Utility functions -commonPrefix :: String -> String -> String -commonPrefix xs ys = map fst $ takeWhile (uncurry (==)) $ zip xs ys - -- | Trim up to one newline from the beginning of the string. lchop :: String -> String lchop ('\n':xs) = xs @@ -151,10 +148,10 @@ unindent :: String -> String unindent = rchop . intercalate "\n" . dropSpacePrefix . splitOn "\n" . lchop dropSpacePrefix :: [String] -> [String] -dropSpacePrefix lns = - map (drop maxIndent) lns - where flns = filter (not . all (== ' ')) lns - maxIndent = if null flns then maximum (map length lns) else length $ takeWhile (== ' ') $ foldl1 commonPrefix flns +dropSpacePrefix lns = drop maxIndent <$> lns + where isSpaceChar c = c == ' ' || c == '\t' + maxIndent = length $ takeWhile (isSpaceChar . head) $ takeWhile same $ transpose lns + same = and . (zipWith (==) <*> drop 1) atStart :: PandocMonad m => MuseParser m () atStart = do diff --git a/test/Tests/Readers/Muse.hs b/test/Tests/Readers/Muse.hs index cda486daa..75dd4e7da 100644 --- a/test/Tests/Readers/Muse.hs +++ b/test/Tests/Readers/Muse.hs @@ -465,6 +465,14 @@ tests = , " }}}" ] =?> bulletList [ codeBlock "Example line" ] + , "Tabs" =: + T.unlines [ "{{{" + , "\t foo" + , "\t\t" + , "\t bar" + , "}}}" + ] =?> + codeBlock " foo\n\t\n bar" -- Amusewiki requires braces to be on separate line, -- this is an extension. , "One line" =: