假设有一个数据结构表示内部带有注释的文本。
data TWC
= T Text TWC -- text
| C Text TWC -- comment
| E -- end
deriving Show
因此像字符串一样
"Text, {-comment-}, and something else"
可以编码为
T "Text, " (C "comment" (T ", and something else" E))
注释块和 forE
的解析器非常简单:
twcP :: Parser TWC
twcP = eP <|> cP <|> tP
cP :: Parser TWC
cP = do
_ <- string "{-"
c <- manyTill anyChar (string "-}")
rest <- cP <|> tP <|> eP
return (C (pack c) rest)
eP :: Parser TWC
eP = do
endOfInput
return E
以如此简单的方式实现文本块的解析器
tP :: Parser TWC
tP = do
t <- many1 anyChar
rest <- cP <|> eP
return (T (pack t) rest)
由于其贪婪的性质,使其将评论部分作为文本使用
> parseOnly twcP "text{-comment-}"
Right (T "text{-comment-}" E)
it ∷ Either String TWC
那么,问题是如何表达直到输入结束或直到评论部分的解析逻辑?换句话说,如何实现条件前瞻解析器?