Парсер грамматики - Parser Grammar Engine

В Парсер грамматики (PGE, первоначально Parrot Grammar Engine) это компилятор и время выполнения за Правила Раку для Виртуальная машина Parrot.[1] PGE использует эти правила преобразовать анализ грамматики выражений в попугая байт-код. Поэтому он компилирует правила в программу, в отличие от большинства виртуальных машин и сред выполнения, которые хранят регулярные выражения во вторичном внутреннем формате, который затем интерпретируется во время выполнения механизмом регулярных выражений. Формат правил, используемый PGE, может выражать любые регулярное выражение и большинство формальные грамматики, и, как таковой, он образует первое звено в цепочке компилятора для всех интерфейсных языков Parrot.

При выполнении байт-код, сгенерированный PGE, будет анализировать текст, как описано в правилах ввода, создавая дерево синтаксического анализа. С деревом синтаксического анализа можно напрямую манипулировать или использовать его на следующем этапе Набор инструментов компилятора Parrot чтобы создать AST из которого может происходить генерация кода (если грамматика описывает язык программирования).

История

Первоначально названный P6GE и написанный на C, PGE был переведен на родной Parrot и переименован вскоре после первого выпуска в ноябре 2004 года. Его автором является Патрик Р. Мишо.[2] PGE был написан для того, чтобы уменьшить объем работы, необходимой для реализации компилятора поверх Parrot. Он также был написан, чтобы позволить Perl 6 легко самостоятельно размещаться, хотя в настоящее время Мопсов при разработке больше не используется PGE в качестве основной серверной части правил в пользу собственного движка под названием PCR.[3]

Внутренности

PGE сочетает в себе три стиля синтаксического анализа:

Основная форма - это правила Raku, поэтому правило PGE может выглядеть следующим образом для грамматики только для сложения:

 правило срок   { <номер> | (<выражение>) } правило номер { d + } правило expr   { <термин> ('+' <термин>) * }

Парсер приоритета операторов позволяет создавать таблицу операторов и использовать ее непосредственно в парсере стиля правил Perl 6 следующим образом:

 правило expr является опционально { ... } правило срок   { <номер> | (<выражение>) } правило номер { d + } прото срок: является приоритет('=')             является разбирается(&срок) {...} прото инфикс:+ является слабее('срок:') {...}

Это выполняет ту же цель определения простой грамматики, предназначенной только для добавления, но делает это с использованием комбинации регулярного выражения / правил стиля Raku для срок и номер и для всего остального можно выбрать понижающий сдвиг.

Генерация кода

Хотя PGE выводит код, который будет анализировать грамматику, описанную правилом, и может использоваться в время выполнения для обработки простых грамматик и регулярных выражений, найденных в коде, его основная цель - анализировать языки высокого уровня.

Инструментальная цепочка компилятора Parrot разбита на несколько частей, первая из которых - PGE. PGE конвертирует исходный код в разбирать деревья. В Tree Grammar Engine (TGE) затем преобразует их в абстрактные синтаксические деревья Parrot (PAST). Затем второй проход TGE преобразует ПРОШЛОЕ в Деревья синтаксиса кодов операций Parrot (POST), который можно напрямую преобразовать в исполняемый байт-код.

Pge-overview.svg

Рекомендации

  1. ^ Мишо, Патрик Р. (2004-11-22). "Parrot Grammar Engine (PGE)". Архивировано из оригинал на 2005-12-20.
  2. ^ Мишо, Патрик Р. (2004-11-08). «Первый публичный выпуск грамматического движка».
  3. ^ «Агент Чжан» (17 сентября 2006 г.). «ПЦР заменяет PGE у мопсов».

внешняя ссылка