data:image/s3,"s3://crabby-images/c98cb/c98cb69cb0a436cd4077015ca3055eff94ad845e" alt="Haskell parsec"
Type Parser a = State -> Cosumed (Reply a)
data:image/s3,"s3://crabby-images/38c2c/38c2c43987df4b5a4ed449ac2d1e9d53d30f8615" alt="haskell parsec haskell parsec"
Parsec combines two data structures to return these four values:ĭata Reply a = Ok a State Message | Error Message In many cases we know that the parser consumes input long before we know that it was successful. We still have a problem - we still need to hang on to the input string until we know that the parser succeeded or failed. Edit: Thanks to Chung-chieh Shan for sending me a copy of Partridge & Wright.
#HASKELL PARSEC HOW TO#
Partridge & Wright seem to be the first to have introduced this splitting of the return value of a parse, but I can't find a non-paywalled version of their paper "Predictive parser combinators need four values to report errors." It seems like exactly the sort of paper I should be reading, but I'm also not sure on how to get in touch with the authors. There are also advantages to error reporting to making these distinctions. This limitation on backtracking means that we can drop the beging of the token-stream sooner, allowing it to be cleaned up by the garbage collector. The idea is that once a parser consumes any input (that is, looks ahead more than one charecter) we prohibit backtracking. The parsec parser, instead of returning a list of parses returns one of four results of the parse:
data:image/s3,"s3://crabby-images/f969e/f969ebefa7f537d35120a1f2a8ad436b00f866b4" alt="haskell parsec haskell parsec"
data:image/s3,"s3://crabby-images/c98cb/c98cb69cb0a436cd4077015ca3055eff94ad845e" alt="Haskell parsec"