![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Грамматика языка Си хитро устроена: её невозможно однозначно распознать, не строя таблицу имён. Объясню на примере. Рассмотрим конструкцию:
То есть парсер во время разбора входного потока должен строить таблицу имён. Достаточно различать три категории: тайпдефы, именованные константы enum и всё остальное. Но надо отслеживать область действия. При выходе из блока имена, определённые в нём, следует забывать.
Я уже почти добил самопальный парсер Си, осталось добавить тайпдефы.
Как её должен интерпретировать парсер? Выглядит полной бессмыслицей. Однако же представим, что перед этим имелось:foo bar : qux;
Тогда конструкция превращается в:typedef int foo; enum { qux = 1 };
Честное определение поля структуры размером один бит.int bar : 1;
То есть парсер во время разбора входного потока должен строить таблицу имён. Достаточно различать три категории: тайпдефы, именованные константы enum и всё остальное. Но надо отслеживать область действия. При выходе из блока имена, определённые в нём, следует забывать.
Я уже почти добил самопальный парсер Си, осталось добавить тайпдефы.
no subject
Date: 2025-05-20 03:38 (UTC)no subject
Date: 2025-05-20 04:42 (UTC)В следующий раз надо будет заняться парсером Rust. Возможно, он проще.