diff options
| -rw-r--r-- | src/Text/Pandoc/Readers/Markdown.hs | 19 | ||||
| -rw-r--r-- | test/command/5271.md | 12 | 
2 files changed, 22 insertions, 9 deletions
| diff --git a/src/Text/Pandoc/Readers/Markdown.hs b/src/Text/Pandoc/Readers/Markdown.hs index 8d28abb2f..a602a5b4c 100644 --- a/src/Text/Pandoc/Readers/Markdown.hs +++ b/src/Text/Pandoc/Readers/Markdown.hs @@ -284,21 +284,22 @@ nodeToKey _                                 = fail "Non-string key in YAML mappi  toMetaValue :: PandocMonad m              => Text -> MarkdownParser m (F MetaValue)  toMetaValue x = -  parseFromString' parser' (T.unpack x) -  where parser' = (asInlines <$> ((trimInlinesF . mconcat) -                       <$> try (guard (not endsWithNewline) -                                *> manyTill inline eof))) -                  <|> (asBlocks <$> parseBlocks) +   -- Note: a standard quoted or unquoted YAML value will +   -- not end in a newline, but a "block" set off with +   -- `|` or `>` will. +   if (T.pack "\n") `T.isSuffixOf` x +      then parseFromString' (asBlocks <$> parseBlocks) (xstring <> "\n") +      else parseFromString' +             ((asInlines <$> try pInlines) <|> (asBlocks <$> parseBlocks)) +             xstring +  where pInlines = trimInlinesF . mconcat <$> manyTill inline eof          asBlocks p = do            p' <- p            return $ MetaBlocks (B.toList p')          asInlines p = do            p' <- p            return $ MetaInlines (B.toList p') -        endsWithNewline = T.pack "\n" `T.isSuffixOf` x -        -- Note: a standard quoted or unquoted YAML value will -        -- not end in a newline, but a "block" set off with -        -- `|` or `>` will. +        xstring = T.unpack x  checkBoolean :: Text -> Maybe Bool  checkBoolean t = diff --git a/test/command/5271.md b/test/command/5271.md new file mode 100644 index 000000000..910ea5888 --- /dev/null +++ b/test/command/5271.md @@ -0,0 +1,12 @@ +``` +% pandoc -f markdown -t native -s +--- +abstract: | +  This is the abstract. + +  It consists of two paragraphs. +... +^D +Pandoc (Meta {unMeta = fromList [("abstract",MetaBlocks [Para [Str "This",Space,Str "is",Space,Str "the",Space,Str "abstract."],Para [Str "It",Space,Str "consists",Space,Str "of",Space,Str "two",Space,Str "paragraphs."]])]}) +[] +``` | 
