Files
wren/test/benchmark/method_call.wren

69 lines
1.2 KiB
Plaintext
Raw Normal View History

class Toggle {
new(startState) {
_state = startState
}
value { _state }
activate {
_state = !_state
return this
}
}
class NthToggle is Toggle {
new(startState, maxCounter) {
super(startState)
_countMax = maxCounter
_count = 0
}
activate {
_count = _count + 1
if (_count >= _countMax) {
super.activate
_count = 0
}
return this
}
}
2014-02-04 08:49:16 -08:00
var start = IO.clock
var n = 100000
var val = true
var toggle = new Toggle(val)
for (i in 0...n) {
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
val = toggle.activate.value
}
IO.print(toggle.value)
val = true
var ntoggle = new NthToggle(val, 3)
for (i in 0...n) {
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
val = ntoggle.activate.value
}
IO.print(ntoggle.value)
IO.print("elapsed: ", IO.clock - start)