2015-03-28 22:51:50 +01:00
|
|
|
// Infinite iterator demonstrating that Sequence.map is not eager
|
|
|
|
|
class FibIterator {
|
2015-07-21 07:24:53 -07:00
|
|
|
construct new() {
|
2015-03-28 22:51:50 +01:00
|
|
|
_current = 0
|
|
|
|
|
_next = 1
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
iterate {
|
|
|
|
|
var sum = _current + _next
|
|
|
|
|
_current = _next
|
|
|
|
|
_next = sum
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
value { _current }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class Fib is Sequence {
|
2015-09-01 08:16:04 -07:00
|
|
|
construct new() {}
|
|
|
|
|
|
2015-03-28 22:51:50 +01:00
|
|
|
iterate(iterator) {
|
2015-07-10 09:18:22 -07:00
|
|
|
if (iterator == null) return FibIterator.new()
|
2015-03-28 22:51:50 +01:00
|
|
|
iterator.iterate
|
|
|
|
|
return iterator
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
iteratorValue(iterator) { iterator.value }
|
|
|
|
|
}
|
|
|
|
|
|
2015-07-10 09:18:22 -07:00
|
|
|
var squareFib = Fib.new().map {|fib| fib * fib }
|
2015-03-28 22:51:50 +01:00
|
|
|
var iterator = null
|
|
|
|
|
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib is Sequence) // expect: true
|
|
|
|
|
System.print(squareFib) // expect: instance of MapSequence
|
2015-03-28 22:51:50 +01:00
|
|
|
|
|
|
|
|
iterator = squareFib.iterate(iterator)
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib.iteratorValue(iterator)) // expect: 0
|
2015-03-28 22:51:50 +01:00
|
|
|
|
|
|
|
|
iterator = squareFib.iterate(iterator)
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib.iteratorValue(iterator)) // expect: 1
|
2015-03-28 22:51:50 +01:00
|
|
|
|
|
|
|
|
iterator = squareFib.iterate(iterator)
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib.iteratorValue(iterator)) // expect: 1
|
2015-03-28 22:51:50 +01:00
|
|
|
|
|
|
|
|
iterator = squareFib.iterate(iterator)
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib.iteratorValue(iterator)) // expect: 4
|
2015-03-28 22:51:50 +01:00
|
|
|
|
|
|
|
|
iterator = squareFib.iterate(iterator)
|
2015-09-15 07:46:09 -07:00
|
|
|
System.print(squareFib.iteratorValue(iterator)) // expect: 9
|