コンテンツにスキップ

パーサジェネレータ

出典: フリー百科事典『ウィキペディア(Wikipedia)』

これはこのページの過去の版です。2404:7a82:7380:f00:a027:bf6a:80ab:d08e (会話) による 2021年7月31日 (土) 07:23個人設定で未設定ならUTC)時点の版であり、現在の版とは大きく異なる場合があります。

パーサジェネレータ: parser generator)は、構文解析器(解釈)を作成するプログラムである。

概要

プログラミング言語コンパイラの開発には技術と手間とを要する。それを支援するために、言語の構文などの定義から、コンパイラを生成するコンパイラジェネレータ(コンパイラコンパイラとも)が研究された。その過程で、入力を処理する構文解析器を自動生成するプログラムが開発され、広く実用に供されるようになった。これがパーサジェネレータである。

歴史

伝統的には1970年代から開発されている yacc が有名である。名前は「Yet Another コンパイラコンパイラ」の略だが、実際はパーサジェネレータである。yaccの上位互換のものとしてGNUプロジェクトbisonがある。

近年の発展

パーサコンビネータ

パーサは入力を引数に取って解析結果を返す関数とみなすことができる。プログラミング言語に関数を組み合わせたりする能力(高階関数)があれば、演算子(コンビネータ)によりパーサを組み上げることができる。Parsecなどのパーサコンビネータライブラリが実装・公開され、使われている。

Packrat Parser

曖昧性の無い文法の解析のために、文脈自由文法の代わりとして使えるものとして、Parsing Expression Grammarの研究がすすんでいる。PEGの実用的なパーサとして提案されているものにPackrat Parserがあり、Packrat Parserを生成するパーサジェネレータが実装・公開され、使われている。

実装

参照

参考文献

  • P.レッヒェンベルク、H.メッセンベック共著、玉井浩 訳『マイクロコンピュータのための「コンパイラ・コンパイラ」―コンパイラ自動生成にむけて』〈Information & Computing 52〉サイエンス社1991年 ISBN 978-4-7819-0607-2