Software /
code /
prosody
Comparison
util/queue.lua @ 6678:343ca80ceb36
util.queue: Small fast FIFO/ringbuffer/queue library
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Wed, 13 May 2015 16:57:27 +0100 |
child | 6731:d4a6c9ee4bc5 |
comparison
equal
deleted
inserted
replaced
6677:1089f45c5e67 | 6678:343ca80ceb36 |
---|---|
1 -- Prosody IM | |
2 -- Copyright (C) 2008-2015 Matthew Wild | |
3 -- Copyright (C) 2008-2015 Waqas Hussain | |
4 -- | |
5 -- This project is MIT/X11 licensed. Please see the | |
6 -- COPYING file in the source package for more information. | |
7 -- | |
8 | |
9 -- Small ringbuffer library (i.e. an efficient FIFO queue with a size limit) | |
10 -- (because unbounded dynamically-growing queues are a bad thing...) | |
11 | |
12 local have_utable, utable = pcall(require, "util.table"); -- For pre-allocation of table | |
13 | |
14 local function new(size) | |
15 -- Head is next insert, tail is next read | |
16 local head, tail = 1, 1; | |
17 local items = 0; -- Number of stored items | |
18 local t = have_utable and utable.create(size, 0) or {}; -- Table to hold items | |
19 | |
20 return { | |
21 size = size; | |
22 count = function (self) return items; end; | |
23 push = function (self, item) | |
24 if items >= size then | |
25 return nil, "queue full"; | |
26 end | |
27 t[head] = item; | |
28 items = items + 1; | |
29 head = (head%size)+1; | |
30 return true; | |
31 end; | |
32 pop = function (self) | |
33 if items == 0 then | |
34 return nil; | |
35 end | |
36 local item; | |
37 item, t[tail] = t[tail], 0; | |
38 tail = (tail%size)+1; | |
39 items = items - 1; | |
40 return item; | |
41 end; | |
42 peek = function (self) | |
43 if items == 0 then | |
44 return nil; | |
45 end | |
46 return t[tail]; | |
47 end; | |
48 }; | |
49 end | |
50 | |
51 return { | |
52 new = new; | |
53 }; | |
54 |