HAL will be down for maintenance from Friday, June 10 at 4pm through Monday, June 13 at 9am. More information
Skip to Main content Skip to Navigation

Parser in ML

Michel Mauny 1 Daniel de Rauglaudre 1
INRIA Rocquencourt
Abstract : We present the operational semantics of stream matching as discussed. Streams are data structures such as lists, but with different primitive operations. Streams not only provide an interface to usual input/ output channels, but may used as a data structure per se, holding any kind of element. A special pattern matching construct is dedicated to streams and the actual matching process will be called parsing. The primary parsing semantics that we propose here is predictive parsing, i.e. recursive descent semantics with a one token look-ahead: although this choice seems to restrict us to the recognition of LL(1) languages, we show by examples that full functionality and parameter passing allow us to write parsers for complex languages. The operational semantics of parsers is given by transforming parsers into regular functions. We introduce a non)strict semantics of streams by translating stream expressions into more classical data structures ; we also investigate different sharing mechanisms for some of the stream operations.
Document type :
Complete list of metadata

Contributor : Rapport de Recherche Inria Connect in order to contact the contributor
Submitted on : Wednesday, May 24, 2006 - 4:49:55 PM
Last modification on : Friday, February 4, 2022 - 3:22:53 AM
Long-term archiving on: : Tuesday, April 12, 2011 - 7:59:27 PM


  • HAL Id : inria-00074898, version 1



Michel Mauny, Daniel de Rauglaudre. Parser in ML. [Research Report] RR-1659, INRIA. 1992. ⟨inria-00074898⟩



Record views


Files downloads