| 153 |      1 | 
 | 
|  |      2 | import scala.concurrent._
 | 
|  |      3 | import scala.concurrent.duration._
 | 
|  |      4 | import ExecutionContext.Implicits.global
 | 
|  |      5 | import scala.language.postfixOps 
 | 
|  |      6 | import scala.language.reflectiveCalls
 | 
|  |      7 | 
 | 
|  |      8 | 
 | 
|  |      9 | lazy val f = Future {
 | 
|  |     10 |   import CW8a._
 | 
|  |     11 | 
 | 
|  |     12 |   assert(simp(ZERO | ONE) == ONE)
 | 
|  |     13 |   assert(simp(STAR(ZERO | ONE)) == STAR(ZERO | ONE))
 | 
|  |     14 |   assert(simp(ONE ~ (ONE ~ (ONE ~ CHAR('a')))) == CHAR('a'))
 | 
|  |     15 |   assert(simp(ONE ~ (ONE ~ (ONE ~ ZERO))) == ZERO)
 | 
|  |     16 |   assert(simp(ALT(ONE ~ (ONE ~ (ONE ~ ZERO)), CHAR('a'))) == CHAR('a'))
 | 
|  |     17 |   assert(simp(CHAR('a') | CHAR('a')) == CHAR('a'))
 | 
|  |     18 |   assert(simp(ONE | CHAR('a')) == (ONE | CHAR('a')))
 | 
|  |     19 | }
 | 
|  |     20 | 
 | 
|  |     21 | Await.result(f, 30 second)
 |