summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/Text/Pandoc/Readers/Markdown.hs22
1 files changed, 6 insertions, 16 deletions
diff --git a/src/Text/Pandoc/Readers/Markdown.hs b/src/Text/Pandoc/Readers/Markdown.hs
index 4eb17c16b..0708690d4 100644
--- a/src/Text/Pandoc/Readers/Markdown.hs
+++ b/src/Text/Pandoc/Readers/Markdown.hs
@@ -355,7 +355,6 @@ parseBlocks = mconcat <$> manyTill block eof
block :: MarkdownParser (F Blocks)
block = choice [ codeBlockFenced
- , codeBlockBackticks
, guardEnabled Ext_latex_macros *> (mempty <$ macro)
, header
, lhsCodeBlock
@@ -520,27 +519,18 @@ keyValAttr = try $ do
codeBlockFenced :: MarkdownParser (F Blocks)
codeBlockFenced = try $ do
- guardEnabled Ext_fenced_code_blocks
- size <- blockDelimiter (=='~') Nothing
+ c <- try (guardEnabled Ext_fenced_code_blocks >> lookAhead (char '~'))
+ <|> (guardEnabled Ext_backtick_code_blocks >> lookAhead (char '`'))
+ size <- blockDelimiter (== c) Nothing
skipMany spaceChar
attr <- option ([],[],[]) $
- guardEnabled Ext_fenced_code_attributes >> attributes
+ try (guardEnabled Ext_fenced_code_attributes >> attributes)
+ <|> ((\x -> ("",[x],[])) <$> identifier)
blankline
- contents <- manyTill anyLine (blockDelimiter (=='~') (Just size))
+ contents <- manyTill anyLine (blockDelimiter (== c) (Just size))
blanklines
return $ return $ B.codeBlockWith attr $ intercalate "\n" contents
-codeBlockBackticks :: MarkdownParser (F Blocks)
-codeBlockBackticks = try $ do
- guardEnabled Ext_backtick_code_blocks
- blockDelimiter (=='`') (Just 3)
- skipMany spaceChar
- cls <- many1 alphaNum
- blankline
- contents <- manyTill anyLine $ blockDelimiter (=='`') (Just 3)
- blanklines
- return $ return $ B.codeBlockWith ("",[cls],[]) $ intercalate "\n" contents
-
codeBlockIndented :: MarkdownParser (F Blocks)
codeBlockIndented = do
contents <- many1 (indentedLine <|>