我在 Parsec 中使用未完成的类似 Haskell 语言的解析器。
尽管我对错误消息不满意,但它似乎工作正常。
- 输入:
"foo (bar"
- 错误:
expecting letter or digit, operand or ")"
我怎样才能让它只打印expecting operand or ")"
?我已尝试添加<?>
但无法使其正常工作。
这是我的代码:
separator = skipMany1 space
<?> ""
identifier :: Parser String
identifier = (:) <$> letter <*> many alphaNum
<?> "identifier"
number :: Parser String
number = many1 digit
<?> "numeric literal"
primitiveExpr :: Parser String
primitiveExpr = (identifier
<|> number)
<?> "primitive expression"
expr :: Parser ()
expr = do identifier
spaces <?> ""
sepBy operand separator
return ()
parenExpr :: Parser String
parenExpr = do char '('
expr
char ')'
return "foo"
<?> "parenthesized expression"
operand = parenExpr <|> primitiveExpr
<?> "operand"