util.queue: Allow optional wrap-around when pushing, overwriting oldest unread item

This commit is contained in:
Matthew Wild 2015-06-03 15:51:07 +01:00
parent bfba36b194
commit a67c2d33e5

View file

@ -11,7 +11,7 @@
local have_utable, utable = pcall(require, "util.table"); -- For pre-allocation of table
local function new(size)
local function new(size, allow_wrapping)
-- Head is next insert, tail is next read
local head, tail = 1, 1;
local items = 0; -- Number of stored items
@ -22,7 +22,12 @@ local function new(size)
count = function (self) return items; end;
push = function (self, item)
if items >= size then
return nil, "queue full";
if allow_wrapping then
tail = (tail%size)+1; -- Advance to next oldest item
items = items - 1;
else
return nil, "queue full";
end
end
t[head] = item;
items = items + 1;