author | Christian Urban <urbanc@in.tum.de> |
Fri, 05 Oct 2012 16:26:04 +0100 | |
changeset 21 | 4e5092ab450a |
parent 7 | 73cf4406b773 |
child 66 | 9215b9fb8852 |
permissions | -rw-r--r-- |
def matches(r: Rexp, s: String) : Boolean = nullable(derivs(r, s.toList)) /* Examples */ println(matches(SEQ(SEQ(CHAR('c'), CHAR('a')), CHAR('b')),"cab")) println(matches(STAR(CHAR('a')),"aaa")) /* Convenience using implicits */ implicit def string2rexp(s : String) : Rexp = { s.foldRight (EMPTY: Rexp) ( (c, r) => SEQ(CHAR(c), r) ) } println(matches("cab" ,"cab")) println(matches(STAR("a"),"aaa")) println(matches(STAR("a"),"aaab"))