Введение Основа Синтаксический анализ выражений Начало Одиночные цифры Выражения с двумя цифрами Общая форма выражения Использование стека Умножение и деление Круглые скобки Унарный минус Слово об оптимизации Снова выражения Введение Переменные Функции Подробнее об обработке ошибок Присваивание Многосимвольные токены Пробелы Интерпретаторы Введение Интерпретатор Немного философии Управляющие конструкции Введение План Немного основ Оператор IF Оператор WHILE Оператор LOOP Цикл FOR Оператор DO Оператор BREAK Заключение Булевы выражения Введение План Грамматика Операторы отношений Исправление грамматики Синтаксический анализатор Объединение с управляющими конструкциями Добавление присваиваний Лексический анализ Введение Лексический анализ Конечные автоматы и альтернативы Эксперименты по сканированию Пробел Конечные автоматы Новые строки Операторы Списки, запятые и командные строки Становится интересней Возвращение символа Распределенные сканеры против централизованных Объединение сканера и парсера Заключение Немного философии Введение Дорога домой Почему это так просто? Здесь нет ничего сложного! Заключение Вид сверху Введение Верхний уровень Структура Паскаля Расширение Объявления Структура Си Представление «TINY» Введение Подготовка Объявления Объявления и идентификаторы Инициализаторы Таблица идентификаторов Выполнимые утверждения Булева логика Управляющие структуры Лексический анализ Многосимвольные имена переменных Снова операторы отношений Ввод/Вывод Заключение Пересмотр лексического анализа Введение Предпосылка Проблема Решение Исправление компилятора Заключение Разное Введение Точки с запятой Синтаксический сахар Работа с точками с запятой Компромисс Комментарии Односимвольные разделители Многосимвольные разделители Односторонние комментарии Заключение Процедуры Введение Последнее отклонение Основы Основа для экспериментов Объявление процедуры Вызов процедуры Передача параметров Семантика параметров Передача по значению Что неправильно? Передача по ссылке Локальные переменные Заключение Типы Введение Что будет дальше? Таблица идентификаторов Добавление записей Распределение памяти Объявление типов Присваивания Трусливый выход Более приемлемое решение Литеральные аргументы Аддитивные выражения Почему так много процедур? Мультипликативные выражения Умножение Деление Завершение Приводить или не приводить Заключение Назад в будущее Введение Новое начало, старое направление Начинаем заново? Модуль INPUT Модуль OUTPUT Модуль ERROR Лексический и синтаксический анализ Модуль SCANNER Решения, решения Синтаксический анализ Ссылки Конструирование модулей Введение Совсем как классический? Расширение синтаксического анализатора Термы и выражения Присваивания Булева алгебра Булево «AND»
Почему это так просто? Перед осуществлением этой серии я всегда думал, что компиляторы были просто естественно сложными компьютерными программами... предельно вызывающими. Однако то, что мы здесь делали обычно оказывалось совершенно простым, иногда даже тривиальным.
Некоторое время я думал, что это было просто потому, что я еще не залез в глубь темы. Я только охватил простые части. Я легко признаюсь вам что даже когда я начинал эту серию я не был уверен в том, как далеко мы будем способны продвинуться прежде чем дела станут слишком сложными для работы имеющимися способами. Но сейчас я уже нахожусь достаточно близко, чтобы увидеть конец пути. Какой вывод?