VOOZH about

URL: https://ru.wikipedia.org/wiki/Yacc

⇱ yacc — Википедия


Перейти к содержанию
Материал из Википедии — свободной энциклопедии
Yacc
Тип Команда
Автор Стивен Джонсон[англ.]
Разработчик Стивен Джонсон[вд][1]
Написана на Си
Операционные системы Unix, Unix-подобные, Plan 9, Inferno
Дата выпуска 1970
Аппаратная платформа Кроссплатформенный
Последняя версия
  • неизвестно[1]
Репозиторий tuhs.org/cgi-bin/utree.p…
Лицензия Plan 9: Лицензия MIT

yacc — компьютерная программа, служащая стандартным генератором синтаксических анализаторов (парсеров) в Unix-системах. Название является акронимом «Yet Another Compiler Compiler» («ещё один компилятор компиляторов»). Yacc генерирует парсер на основе аналитической грамматики, описанной в нотации BNF (форма Бэкуса-Наура) или контекстно-свободной грамматики. На выходе yacc выдаётся код парсера на языке программирования Си.

Yacc был разработан Стивеном Джонсоном (Stephen C. Johnson) в AT&T для операционной системы Unix. Позже были написаны совместимые версии программы, такие как Berkeley Yacc, GNU bison, MKS yacc и Abraxas yacc (обновлённый вариант AT&T-версии с открытым исходным кодом также вошёл в проект OpenSolaris от Sun). Каждый вариант предлагал незначительные улучшения и дополнительные возможности по сравнению с оригиналом, но концепция осталась той же. Yacc также был переписан на других языках, включая Java, C#, Pascal, Ada, Ratfor, EFL, ML, Limbo, Erlang, Go и т. д.

Поскольку парсер, генерируемый с помощью yacc, требует использования лексического анализатора, то часто он используется совместно с генератором лексических анализаторов, в большинстве случаев это lex либо flex. Стандарт IEEE POSIX P1003.2 определяет как функциональность, так и требования для lex и yacc.

  • lex — лексический анализатор, часто использующийся с yacc.
  • GNU bison — GNU-версия yacc.
  • Форма Бэкуса — Наура — синтаксис, используемый для описания контекстно-свободных грамматик, то есть формальный способ описания языков.
  • Создание анализаторов текста при помощи yacc и lex
  • Lex и YACC в примерах
  • Gardens Point Parser Generator (gppg) — yacc, генерирующий код на языке C#
Это заготовка статьи о программном обеспечении. Помогите Википедии, дополнив её.
  1. 1 2 https://www.tuhs.org/cgi-bin/utree.pl?file=V6/usr/source/yacc