Рекурсивные(?) регулярные выражения в tcl?

Есть следующая программа на tcl:

#!/usr/bin/tclsh

set p {}

while {[gets stdin c] >= 0} {

set r $p$c

#puts [execute r]

set p {}

regexp {^([^\}]*\{)(?:[^{}]*(?:\{[^{}]*\})?)?$} $r -> p

puts -nonewline $p

flush stdout

}

Видно, что можно открывать сразу несколько скобочек в одной команде(здесь "([^\}]*\{)"). Можно ли сделать такое же и для закрывающих, причем чтобы каждая закрывающая закрывала ровно одну открывающую, не изменяя сильно код(в идеале только регулярное выражение)?
  • Вопрос задан
  • 3217 просмотров
Пригласить эксперта
Ответы на вопрос 1
@MikhailEdoshin
Я не совсем понял вопрос, может быть, но если вам нужно проверять соответствие скобок регулярным выражением, то это в принципе невозможно. Регулярные выражения могут описывать только регулярные грамматики, это третий тип грамматик, их можно разбирать автоматом без памяти, а соответствие скобок — это грамматики второго типа, более мощные, для них нужен парсер. Вы можете проверять соответствие скобок, если у вас, допустим, не более пяти пар в строке (то есть ограниченное число), но в общем случае нет.

Хотя современные регулярки довольно мощные с кучей всяких дополнительных возможностей, но не думаю, что туда что-то подобное добавят — там существенно отличающиеся алгоритмы.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы