2015-05-14 5 views
2

Я пишу хроны анализатор, но компилятор жалуется на незаконный состав правил,parboiled2 Нелегального правило композиция

Что случилось с моим парсер?

import org.parboiled2._ 

sealed trait Part 
case class Fixed(points: Seq[Int]) extends Part 
case class Range(start: Int, end: Int) extends Part 
case class Every(start: Int, interval: Int) extends Part 
case object Full extends Part 
case object Ignore extends Part 

class CronParser(val input: ParserInput) extends Parser { 

    def number = rule { capture(digits) ~> (_.toInt) } 

    def digits = rule { oneOrMore(CharPredicate.Digit) } 

    def fixed = rule { oneOrMore(number).separatedBy(",") ~> Fixed } 

    def range = rule { digits ~ '-' ~ digits ~> Range } 

    def every= rule { digits ~ '/' ~ digits ~> Every } 

    def full= rule { '*' ~ push(Full) } 

    def ignore = rule { '?' ~ push(Ignore) } 

    def part = rule { fixed | range | every | full | ignore } 

    def expr = rule { part ~ part ~ part ~ part ~ part} 
} 

ответ

2

Вы используете digits, где я думаю, что вы хотите использовать number. Следующие должны работать нормально:

class CronParser(val input: ParserInput) extends Parser { 
    def number = rule { capture(digits) ~> (_.toInt) } 
    def digits = rule { oneOrMore(CharPredicate.Digit) } 
    def fixed = rule { oneOrMore(number).separatedBy(",") ~> Fixed } 
    def range = rule { number ~ '-' ~ number ~> Range } 
    def every = rule { number ~ '/' ~ number ~> Every } 
    def full = rule { '*' ~ push(Full) } 
    def ignore = rule { '?' ~ push(Ignore) } 
    def part = rule { fixed | range | every | full | ignore } 
    def expr = rule { part ~ part ~ part ~ part ~ part } 
} 

Проблема заключалась в том, что digits не выталкивает значение, что означало, что range и т.д. были правила, которые хотели выскочить значения из стека, и они были не в состоянии составляется с ~.