37.3 PEGルールの記述

PEGルールを記述する際には、それが貪欲であることに留意する必要があります。可変量のテキストを消費し得るルールは、たとえそれを行うことによって通常であればマッチするような後続のルールが失敗することになろうとも、可能なかぎり最大の量のテキストを常に消費します。たとえば以下のルールが成功することは決してあり得ません:

(forest (+ "tree" (* [blank])) "tree" (eol))

(+ "tree" (* [blank]))というPEXは、最後にマッチさせる‘tree’を残さず、単語‘tree’の繰り返しすべてを消費します。

このような状況においては述語とguard (すなわち式notifguard)を用いて挙動を制限することによって望ましい結果を得ることができます。たとえば:

(forest (+ "tree" (* [blank])) (not (eol)) "tree" (eol))

ifおよびnotはポイントを移動せずにパース式を受け取って、ブーリアンとして解釈できる演算子です。guard演算子の内容は通常のLisp(PEXではない)として評価されてブーリアン値をリターンされるはずです。nil値の場合にはマッチは失敗です。

他の期待していない振る舞いとしては、たとえ最終的に失敗するパースであってもパースによって可能なかぎり遠くにポイントが移動してしまう可能性があることです。以下のルール:

(end-game "game" (eob))

このルールをポイント後にテキスト“game over”を含んだバッファーで実行すると、ポイントを“game”の直後に移動してからパースを中止してnilをリターンするでしょう。パースが成功した場合には常にt、あるいはパーススタックのコンテキストをリターンします。

This page has generated for branch:work/emacs-30_69b16e5c63840479270d32f58daea923fe725b90, commit:8c196e027afcda4529432b01ae733033b6ca1270 to check Japanese translation.