marking4/re_test4.scala
author Christian Urban <christian.urban@kcl.ac.uk>
Fri, 23 Feb 2024 11:31:36 +0000
changeset 483 1a51207780e6
parent 288 65731df141a5
permissions -rw-r--r--
updated

import CW9c._

val EVIL_urban = SEQ(STAR(STAR(CHAR('a'))), CHAR('b'))

assert(ders(("a" * 5).toList, EVIL_urban) == SEQ(SEQ(STAR(CHAR('a')),STAR(STAR(CHAR('a')))),CHAR('b')))
assert(ders(List('b'), EVIL_urban) == ONE)
assert(ders(List('b','b'), EVIL_urban) == ZERO)
assert(matcher(EVIL_urban, "a" * 5 ++ "b") == true)
assert(matcher(EVIL_urban, "a" * 50 ++ "b") == true)
assert(matcher(EVIL_urban, "a" * 50) == false)
assert(matcher(EVIL_urban, "b") == true)
assert(matcher(EVIL_urban, "bb") == false)
assert(matcher("abc", "abc") == true)
assert(matcher("abc", "ab") == false)
assert(matcher(("ab" | "a") ~ (ONE | "bc"), "abc") == true)
assert(matcher(ONE, "") == true)
assert(matcher(ZERO, "") == false)
assert(matcher(ONE | CHAR('a'), "") == true)
assert(matcher(ONE | CHAR('a'), "a") == true)