VM, 6 курс, 3 семестр, 2016/17 — различия между версиями
N.igotti (обсуждение | вклад) |
Golovanov (обсуждение | вклад) |
||
Строка 24: | Строка 24: | ||
Реализовать интерпретатор байткода полученного транслятором в Задании 2, позволяющий исполгнять программы на MathVM. | Реализовать интерпретатор байткода полученного транслятором в Задании 2, позволяющий исполгнять программы на MathVM. | ||
Для тестирования в каталоге tests есть expect файлы, описывающие ожидаемый вывод. | Для тестирования в каталоге tests есть expect файлы, описывающие ожидаемый вывод. | ||
+ | |||
+ | |||
+ | == Вопросы к экзамену == | ||
+ | [https://docs.google.com/document/d/19g4I1IWDZkErxL--C_toNz0tmSypLOUEfm-3RO1xfTA/edit Ссылка] |
Версия 08:15, 11 января 2017
Преподаватель: Иготти Н.
Лекции
Преподаватель: Николай Иготти (igotti (at) gmail.com)
Освещаемые вопросы: здесь
Практика
Репозиторий на гитхабе. Присылайте запросы на почту для добавления в коллабораторы.
Задание 1
Реализовать код для трансформации AST назад в исходный код, автоформаттер. Ваша программа должна получив на вход программу на языке MathVM (см. гитхаб) вывести эквивалентный исходный код. Основная цель задания - освоится с окружением и кодовой базой.
Задание 2
Реализовать код для трансформации AST в байткод, который описан в заголовке mathvm.h. Ваша программа должна получив на вход программу на языке MathVM и напечатать получившийся байткод. Для целей отладки, можно параллельно делать Задание 3, интерпретатор.
Задание 3
Реализовать интерпретатор байткода полученного транслятором в Задании 2, позволяющий исполгнять программы на MathVM. Для тестирования в каталоге tests есть expect файлы, описывающие ожидаемый вывод.