<div dir="ltr">Marpa, Parse::RecDescent, Parse::Yapp, Parse::Eyapp.<div><br></div><div>Первый мне очень нравиться. Попрбуйте с MarpaX::Repa. "Репу" написал сам и мне очень удобно с ним писать  парсеры ибо можно написать грамматику и не определить все токены, то есть итеративно дополнять в процессе свой парсер без фатальных ошибок на этапе компиляции парсера. В новых версиях Marpa есть Scanless интерфейс - это самое близкое к Repa так как включает лексер и самое простое для начала.</div></div><div class="gmail_extra"><br><div class="gmail_quote">2015-01-14 12:34 GMT+03:00 Харпалёв Иван <span dir="ltr"><<a href="mailto:ivan.kharpalev@gmail.com" target="_blank">ivan.kharpalev@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Доброго времени, могучий MoscowPM!<div><br></div><div>Сейчас пишу небольшой язык.</div><div>То есть пишу транслятор из него в awk и С. (Сначала в awk, чтобы потренироваться, а потом в C, там типизация, там сложнее). </div><div><br></div><div>Когда язык был совсем примитивный, я его парсил регэкспами и по рабоче-крестьянски собирал код на целевом языке.</div><div>Но язык подростает. И рефакторить оказывается очень печально.</div><div><br></div><div>Как я понимаю весь процесс работы транслятора состоит из стандартных стадий, например:</div><div>токенизация</div><div>построение дерева разбора</div><div>сбор кода на целевом языке из полученного описания.</div><div><br></div><div>В общем тория у меня хромает и очень интересна. Но первым делом практика.</div><div>Скажите, чем строить дерево синтаксического разбора?</div><div>что-то вроде </div></div>
<br>--<br>
Moscow.pm mailing list<br>
<a href="mailto:moscow-pm@pm.org">moscow-pm@pm.org</a> | <a href="http://moscow.pm.org" target="_blank">http://moscow.pm.org</a><br>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature">Best regards, Ruslan.</div>
</div>