Never mind, doesn't seem to work well

usingMegaparsec
Aadhavan Srinivasan 4 days ago
parent 160cb0edeb
commit 93548a4533

@ -157,12 +157,8 @@ parseBold = parseBoldWith asteriskBold <|> parseBoldWith underscoreBold
where where
parseBoldWith delim = do parseBoldWith delim = do
string delim string delim
inside <- parseNestedThenLineToken delim inside <- someTill parseLineToken $ string delim
return (Bold (Line inside)) return (Bold (Line inside))
parseNestedThenLineToken delim = do
first <- fallthroughParser [parseItalic, parseLineToken]
rest <- fallthroughParser [singleton <$> parseItalic, singleton <$> string delim >> return mempty, liftA2 (:) parseLineToken $ parseNestedThenLineToken delim]
return (first : rest)
-- Parse italic text -- Parse italic text
parseItalic :: Parser MdToken parseItalic :: Parser MdToken
@ -170,12 +166,8 @@ parseItalic = parseItalicWith '*' <|> parseItalicWith '_'
where where
parseItalicWith delim = do parseItalicWith delim = do
char delim char delim
inside <- parseNestedThenLineToken delim inside <- someTill parseLineToken (char delim)
return (Italic (Line inside)) return (Italic (Line inside))
parseNestedThenLineToken delim = do
first <- fallthroughParser [parseBold, parseLineToken]
rest <- fallthroughParser [singleton <$> parseBold, singleton <$> char delim >> return mempty, liftA2 (:) parseLineToken $ parseNestedThenLineToken delim]
return (first : rest)
-- Parse strikethrough text -- Parse strikethrough text
parseStrikethrough :: Parser MdToken parseStrikethrough :: Parser MdToken

Loading…
Cancel
Save