From e8260c27e18577b9af3d293b7cb9565b6dc9af6b Mon Sep 17 00:00:00 2001 From: John MacFarlane Date: Sun, 30 Sep 2012 20:28:50 -0700 Subject: [PATCH] RST reader: Consolidate super/subscript, math into interpretedRole. --- src/Text/Pandoc/Readers/RST.hs | 61 +++++++++++++++------------------- tests/rst-reader.native | 2 +- 2 files changed, 27 insertions(+), 36 deletions(-) diff --git a/src/Text/Pandoc/Readers/RST.hs b/src/Text/Pandoc/Readers/RST.hs index 4ab60c77e..f30eb6ef3 100644 --- a/src/Text/Pandoc/Readers/RST.hs +++ b/src/Text/Pandoc/Readers/RST.hs @@ -854,9 +854,6 @@ inline = choice [ whitespace , emph , code , subst - , superscript - , subscript - , math , interpretedRole , note , smart @@ -907,42 +904,36 @@ strong :: RSTParser Inlines strong = B.strong . trimInlines . mconcat <$> enclosed (atStart $ string "**") (try $ string "**") inline --- Parses inline interpreted text which is required to have the given role. --- This decision is based on the role marker (if present), --- and the current default interpreted text role. -interpreted :: [Char] -> RSTParser [Char] -interpreted role = try $ do - state <- getState - if role == stateRstDefaultRole state - then try markedInterpretedText <|> unmarkedInterpretedText - else markedInterpretedText - where - markedInterpretedText = try (roleMarker *> unmarkedInterpretedText) - <|> (unmarkedInterpretedText <* roleMarker) - roleMarker = string $ ":" ++ role ++ ":" - -- Note, this doesn't precisely implement the complex rule in - -- http://docutils.sourceforge.net/docs/ref/rst/restructuredtext.html#inline-markup-recognition-rules - -- but it should be good enough for most purposes +-- Note, this doesn't precisely implement the complex rule in +-- http://docutils.sourceforge.net/docs/ref/rst/restructuredtext.html#inline-markup-recognition-rules +-- but it should be good enough for most purposes +interpretedRole :: RSTParser Inlines +interpretedRole = try $ do + (role, contents) <- roleBefore <|> roleAfter + case role of + "sup" -> return $ B.superscript $ B.str contents + "sub" -> return $ B.subscript $ B.str contents + "math" -> return $ B.math contents + _ -> return $ B.str contents --unknown + +roleMarker :: RSTParser String +roleMarker = char ':' *> many1Till (letter <|> char '-') (char ':') + +roleBefore :: RSTParser (String,String) +roleBefore = try $ do + role <- roleMarker + contents <- unmarkedInterpretedText + return (role,contents) + +roleAfter :: RSTParser (String,String) +roleAfter = try $ do + contents <- unmarkedInterpretedText + role <- roleMarker <|> (stateRstDefaultRole <$> getState) + return (role,contents) unmarkedInterpretedText :: RSTParser [Char] unmarkedInterpretedText = enclosed (atStart $ char '`') (char '`') anyChar --- For unknown interpreted roles, we just ignore the role. -interpretedRole :: RSTParser Inlines -interpretedRole = try $ B.str <$> - ( (roleMarker *> unmarkedInterpretedText) - <|> (unmarkedInterpretedText <* roleMarker) ) - where roleMarker = char ':' *> many1Till (letter <|> char '-') (char ':') - -superscript :: RSTParser Inlines -superscript = B.superscript . B.str <$> interpreted "sup" - -subscript :: RSTParser Inlines -subscript = B.subscript . B.str <$> interpreted "sub" - -math :: RSTParser Inlines -math = B.math <$> interpreted "math" - whitespace :: RSTParser Inlines whitespace = B.space <$ skipMany1 spaceChar "whitespace" diff --git a/tests/rst-reader.native b/tests/rst-reader.native index d41274621..447c719eb 100644 --- a/tests/rst-reader.native +++ b/tests/rst-reader.native @@ -321,6 +321,6 @@ Pandoc (Meta {docTitle = [Str "Pandoc",Space,Str "Test",Space,Str "Suite",Str ": ,Para [Math DisplayMath "\\alpha = beta",Math DisplayMath "E = mc^2"] ,Para [Str "Some",Space,Superscript [Str "of"],Space,Str "these",Space,Superscript [Str "words"],Space,Str "are",Space,Str "in",Space,Superscript [Str "superscript"],Str "."] ,Para [Str "Reset",Space,Str "default-role",Space,Str "to",Space,Str "the",Space,Str "default",Space,Str "default."] -,Para [Str "And",Space,Str "now",Space,Str "`some-invalid-string-3231231`",Space,Str "is",Space,Str "nonsense."] +,Para [Str "And",Space,Str "now",Space,Str "some-invalid-string-3231231",Space,Str "is",Space,Str "nonsense."] ,Header 2 [Str "Literal",Space,Str "symbols"] ,Para [Str "2*2",Space,Str "=",Space,Str "4*1"]]