VM, 6 курс, 3 семестр, 2016/17 — различия между версиями

Материал из SEWiki
Перейти к: навигация, поиск
Строка 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 файлы, описывающие ожидаемый вывод.


Вопросы к экзамену

Ссылка