From 85136b064fa014a33960b4b34af6de80804db2dc Mon Sep 17 00:00:00 2001 From: John MacFarlane Date: Sun, 13 Feb 2022 13:06:49 -0800 Subject: [PATCH] Markdown reader: allow one-column pipe tables with pipe on right. See #7919. We still need to implement this for gfm (commonmark). This must be done via changes in commonmark-hs. --- src/Text/Pandoc/Readers/Markdown.hs | 13 ++++--- test/command/7919.md | 59 +++++++++++++++++++++++++++++ 2 files changed, 66 insertions(+), 6 deletions(-) create mode 100644 test/command/7919.md diff --git a/src/Text/Pandoc/Readers/Markdown.hs b/src/Text/Pandoc/Readers/Markdown.hs index ac6be7729..25318f0f4 100644 --- a/src/Text/Pandoc/Readers/Markdown.hs +++ b/src/Text/Pandoc/Readers/Markdown.hs @@ -1364,9 +1364,9 @@ pipeBreak = try $ do openPipe <- (True <$ char '|') <|> return False first <- pipeTableHeaderPart rest <- many $ sepPipe *> pipeTableHeaderPart - -- surrounding pipes needed for a one-column table: - guard $ not (null rest && not openPipe) - optional (char '|') + closePipe <- (True <$ char '|') <|> return False + -- at least one pipe needed for a one-column table: + guard $ not (null rest && not (openPipe || closePipe)) blankline return $ unzip (first:rest) @@ -1406,9 +1406,10 @@ pipeTableRow = try $ do -- split into cells let chunk = void (code <|> math <|> rawHtmlInline <|> escapedChar <|> rawLaTeXInline') <|> void (noneOf "|\n\r") - cells <- (snd <$> withRaw (many chunk)) `sepEndBy1` char '|' - -- surrounding pipes needed for a one-column table: - guard $ not (length cells == 1 && not openPipe) + cells <- (snd <$> withRaw (many chunk)) `sepBy1` char '|' + closePipe <- (True <$ char '|') <|> return False + -- at least one pipe needed for a one-column table: + guard $ not (length cells == 1 && not (openPipe || closePipe)) blankline return cells diff --git a/test/command/7919.md b/test/command/7919.md new file mode 100644 index 000000000..f7ff9853b --- /dev/null +++ b/test/command/7919.md @@ -0,0 +1,59 @@ +``` +% pandoc -f markdown +single column table | +------------------- | +item 1 | +item 2 | +^D + + + + + + + + + + + + + + +
single column table
item 1
item 2
+``` + +``` +% pandoc -f markdown +| single column table +| ------------------- +| item 1 +| item 2 +^D + + + + + + + + + + + + + + +
single column table
item 1
item 2
+``` + +``` +% pandoc -f markdown +single column table +------------------- +item 1 +item 2 +^D +

single column table

+

item 1 item 2

+``` +