Формализм определения синтаксиса - Syntax Definition Formalism

В Формализм определения синтаксиса (SDF) это метасинтаксис используется для определения контекстно-свободные грамматики: то есть формальный способ описания формальных языков. Он может выражать весь спектр контекстно-свободные грамматики. Текущая версия - SDF3.[1] А парсер и генератор парсеров для SDF спецификации предоставляются как часть бесплатного Мета-среда ASF + SDF. Они работают с использованием SGLR (Без сканера Парсер GLR ). Анализатор SDF выводит разбирать деревья или, в случае двусмысленность Разбираем леса.

Обзор

Особенности SDF:

  • Поддерживает весь спектр контекстно-свободных языков
  • Позволяет модульное определение синтаксиса (грамматики могут импортировать подграмматики), что позволяет повторно использовать
  • Поддерживает аннотации

Примеры

В следующем примере определяется простой синтаксис логического выражения в SDF2:

модуль basic / Booleansexports сортирует логические контекстные начальные символы Booleancontext-free синтаксис "true" -> Boolean "false" -> Boolean lhs: Boolean "|" rhs: Boolean -> Boolean {left} lhs: Boolean "&" rhs: Boolean -> Boolean {left} "not" "(" Boolean ")" -> Boolean "(" Boolean ")" -> Boolean context-free приоритеты Boolean "&" Boolean -> Boolean> Boolean "|" Boolean -> Boolean

Системы анализа и преобразования программ с использованием SDF

Смотрите также

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

дальнейшее чтение

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