? timer # value: ? def t := timer.now(); t =~ tt :int ? (t == tt) # value: true ? t > 1117718697755 # value: true ? timer.now() >= t # value: true ? def r1 := timer.whenPast(def expected := timer.now() + 1000, fn { > def delta := timer.now() - expected > println(`thunk 1 (${if (delta > 500) {delta}})`) > 11 > }) # value: ? interp.waitAtTop(r1); r1 # value: # stdout: thunk 1 (null) # ? timer.now() > (t + 1000) # value: true ? r1 # value: 11 ? def r2 := timer.whenPast((def base := timer.now()) + 2000, fn {println("timing test 1")}) # value: ? def r3 := timer.whenPast(base + 1000, fn {println("timing test 2")}) # value: ? interp.waitAtTop(r2) # stdout: timing test 2 # timing test 1 #