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