В настоящее время я пытаюсь реализовать генератор парсера LALR, как описано в «Методах и инструментах принципов компиляторов» (также называемом «книга драконов»).Проблема реализации генератора PAL-LALR
Много уже работает. Генератор синтаксического анализатора в настоящее время способен генерировать полный goto-graph.
Example Grammar:
S' --> S
S --> C C
C --> c C
C --> d
Nonterminals: S', S, C
Terminals: c, d
Start: S'
Гото-граф:
I[0]---------------+ I[1]-------------+
| S' --> . S , $ |--S-->| S' --> S . , $ |
| S --> . C C , $ | +----------------+
| C --> . c C , c |
| C --> . c C , d | I[2]--------------+
| C --> . d , c | | S --> C . C , $ | I[3]--------------+
| C --> . d , d |--C-->| C --> . c C , $ |--C-->| S --> C C . , $ |
+------------------+ | C --> . d , $ | +-----------------+
| | +-----------------+
| | +--c--+ | |
| | | | c |
| | | v v |
| | I[4]--------------+ |
| c | C --> c . C , c | |
| | | C --> c . C , d | |
| | | C --> c . C , $ | d
| | | C --> . c C , c | |
| +---->| C --> . c C , d | |
| | C --> . c C , $ | |
d | C --> . d , c |--+ |
| +-----| C --> . d , d | | |
| | | C --> . d , $ | | |
| | +-----------------+ | |
| C | |
| | I[6]--------------+ | |
| | | C --> c C . , c | d |
| +---->| C --> c C . , d | | |
| | C --> c C . , $ | | |
| +-----------------+ | |
| | |
| I[5]------------+ | |
| | C --> d . , c |<---+ |
+------->| C --> d . , d | |
| C --> d . , $ |<-----+
+---------------+
У меня есть trubbles с реализацией алгоритма для создания действия стола! Мой алгоритм вычисляет следующий вывод:
state | action
| c | d | $
------------------------
0 | s4 | s5 |
------------------------
1 | | | acc
------------------------
2 | s4 | s5 |
------------------------
3 | | | r?
------------------------
4 | s4 | s5 |
------------------------
5 | r? | r? | r?
------------------------
6 | r? | r? | r?
... SX переложить в состояние х
гх ... уменьшить до состояния х
В Г? означает, что я не знаю, как получить состояние (?), которое должен уменьшить парсер. Кто-нибудь знает алгоритм? используя goto-graph выше?
Если что-либо описывается недостаточно ясно, спросите, и я постараюсь объяснить это лучше! Спасибо за помощь!
спасибо очень полезно !!! – raisyn