Ulitin Konstantin - slides

advertisement
Инструмент реинжиниринга спецификаций
трансляций
Константин Андреевич Улитин
Научный руководитель: Я.А. Кириленко
Рецензент: Н.М. Тимофеев
Санкт-Петербургский государственный университет
Математико-Механический факультет
Кафедра системного программирования
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г.
Download