author | Christian Urban <christian.urban@kcl.ac.uk> |
Mon, 25 Dec 2023 01:10:55 +0100 | |
changeset 482 | 769bda18a43d |
parent 288 | 65731df141a5 |
permissions | -rw-r--r-- |
288 | 1 |
import CW9c._ |
168 | 2 |
|
3 |
val EVIL_urban = SEQ(STAR(STAR(CHAR('a'))), CHAR('b')) |
|
4 |
||
5 |
||
245 | 6 |
assert(simp(Iterator.iterate(ONE:Rexp)(r => SEQ(r, ONE | ONE)).drop(50).next) == ONE) |
7 |
assert(simp(Iterator.iterate(ONE:Rexp)(r => ALT(r, r)).drop(20).next) == ONE) |
|
8 |
assert(matcher(EVIL_urban, "a" * 1000000) == false) |
|
9 |
assert(matcher(EVIL_urban, "a" * 1000000 ++ "b") == true) |