val uninterestingthings = ".".r
val parser = "(?ui)(regexvalue)".r | (uninterestingthings~>parser)
Этот рекурсивный парсер будет пытаться выполнить синтаксический анализ "(? Ui) (regexvalue)". R до конца ввода. Является ли в Scala способ запретить синтаксический анализ, когда определенное количество символов было использовано «неинтересными вещами»?
UPD: у меня есть одно плохое решение:
object NonRecursiveParser extends RegexParsers with PackratParsers{
var max = -1
val maxInput2Consume = 25
def uninteresting:Regex ={
if(max<maxInput2Consume){
max+=1
("."+"{0,"+max.toString+"}").r
}else{
throw new Exception("I am tired")
}
}
lazy val value = "itt".r
def parser:Parser[Any] = (uninteresting~>value)|parser
def parseQuery(input:String) = {
try{
parse(parser, input)
}catch{
case e:Exception =>
}
}
}
Недостатки:
- не все участники ленивы, поэтому PackratParser будет иметь некоторое время штраф
- построение регулярных выражений для каждого «неинтересного» вызова метода - штраф времени
- использование исключения для управления программой - стиль кода и штраф времени