Merge branch 'deferred_execution' of git://github.com/bjorn/wren into bjorn-deferred_execution

Conflicts:
	builtin/core.wren
	src/vm/wren_core.c
This commit is contained in:
Bob Nystrom
2015-04-01 07:22:02 -07:00
9 changed files with 160 additions and 44 deletions

View File

@ -46,21 +46,9 @@ class Sequence {
}
}
map(f) {
var result = new List
for (element in this) {
result.add(f.call(element))
}
return result
}
map(transformation) { new MapSequence(this, transformation) }
where(f) {
var result = new List
for (element in this) {
if (f.call(element)) result.add(element)
}
return result
}
where(predicate) { new WhereSequence(this, predicate) }
reduce(acc, f) {
for (element in this) {
@ -106,6 +94,32 @@ class Sequence {
}
}
class MapSequence is Sequence {
new(seq, f) {
_seq = seq
_f = f
}
iterate(n) { _seq.iterate(n) }
iteratorValue(iterator) { _f.call(_seq.iteratorValue(iterator)) }
}
class WhereSequence is Sequence {
new(seq, f) {
_seq = seq
_f = f
}
iterate(n) {
while (n = _seq.iterate(n)) {
if (_f.call(_seq.iteratorValue(n))) break
}
return n
}
iteratorValue(iterator) { _seq.iteratorValue(iterator) }
}
class String is Sequence {
bytes { new StringByteSequence(this) }
}