util.iterators: Add tail() iterator, to return the last n items

Mon, 10 Aug 2009 15:46:34 +0100

author
Matthew Wild <mwild1@gmail.com>
date
Mon, 10 Aug 2009 15:46:34 +0100
changeset 1660
ae2f60a20428
parent 1659
6092fc9b078b
child 1661
33b1aee4b77f

util.iterators: Add tail() iterator, to return the last n items

util/iterators.lua file | annotate | diff | comparison | revisions
--- a/util/iterators.lua	Mon Aug 10 15:07:32 2009 +0100
+++ b/util/iterators.lua	Mon Aug 10 15:46:34 2009 +0100
@@ -90,6 +90,27 @@
 	end, s;
 end
 
+function tail(n, f, s, var)
+	local results, count = {}, 0;
+	while true do
+		local ret = { f(s, var) };
+		var = ret[1];
+	        if var == nil then break; end
+		results[(count%n)+1] = ret;
+		count = count + 1;
+	end
+
+	if n > count then n = count; end
+
+	local pos = 0;
+	return function ()
+		pos = pos + 1;
+		if pos > n then return nil; end
+		return unpack(results[((count-1+pos)%n)+1]);
+	end
+	--return reverse(head(n, reverse(f, s, var)));
+end
+
 -- Convert the values returned by an iterator to an array
 function it2array(f, s, var)
 	local t, var = {};

mercurial