Инструмент реинжиниринга спецификаций трансляций Константин Андреевич Улитин Научный руководитель: Я.А. Кириленко Рецензент: Н.М. Тимофеев Санкт-Петербургский государственный университет Математико-Механический факультет Кафедра системного программирования 2011 Предметная область Все ПО, использующее формальные грамматики •Предметно-ориентированные языки •Анализаторы кода – Разметка – Статический анализ – Генерация документации •Преобразователи кода – – – – Препроцессоры Форматирование кода Рефакторинг Трансляция в другой язык Реинжиниринг грамматик Зачем? • Не удовлетворены выбранным генератором анализаторов – – – – Другой класс алгоритма разбора Неудобный синтаксис Проблемы с восстановлением после ошибок Скорость работы Как? • Перейти на другой инструмент Постановка задачи Инструмент, позволяющий производить реинжиниринг грамматик • Трансляция в другой формат – Для ухода от проблем выбранного инструмента – Для переиспользования разработанных грамматик • Более удобная разработка, отладка YaccConstructor YardFrontend IronyFrontend AntlrFrontend FsYaccFrontend Common Внутреннее представление ExpandMeta ExpandEbnf ExpandBrackets ReplaceLiterals AddEOF BuildAST RACC FParsecPrinter YardPrinter FsYaccPrinter YaccConstructor Common YardFrontend AntlrFrontend FsYaccFrontend LINKER IronyFrontend Внутреннее представление ExpandMeta ExpandEbnf ExpandBrackets ReplaceLiterals AddEOF BuildAST LeaveLast AddAlter RACC FParsecPrinter YardPrinter FsYaccPrinter Применение В пилотном проекте SqlMigration • Разработка на языке Yard с трансляцией в FsYacc • Не нужно писать атрибуты • Модульность грамматики YardFrontend proc.yrd YardFrontend sql_stmt.yrd YardFrontend LINKER common.yrd ExpandMeta BuildAST ExpandEbnf ExpandBrackets ReplaceLiterals AddEOF FsYaccPrinter parser.fsy Результаты • Реализован инструмент, позволяющий – Транслировать из ANTLR, FsYacc в Yard, FsYacc – Генерировать атрибуты, строящие AST – Задавать грамматику в нескольких файлах • Проведена апробация в проекте SqlMigration • Результаты представлены на конференциях «Технологии MS в теории и практике программирования» (диплом 1 степени) и «СПИСОК» 2011г.