From: Matthew Wild Date: Sun, 22 May 2016 19:07:20 +0000 (+0100) Subject: Merge 0.10->trunk X-Git-Url: https://git.enpas.org/?a=commitdiff_plain;h=f6f011dfbc3d179c77c0431ffacfaaf091f18053;hp=ac789a443b0b75467305e0cb89c26d5f381236b5;p=prosody.git Merge 0.10->trunk --- diff --git a/util/cache.lua b/util/cache.lua index 54f3e10b..44bbfe30 100644 --- a/util/cache.lua +++ b/util/cache.lua @@ -116,6 +116,28 @@ function cache_methods:tail() return tail.key, tail.value; end +function cache_methods:table() + if not self.proxy_table then + self.proxy_table = setmetatable({}, { + __index = function (t, k) + return self:get(k); + end; + __newindex = function (t, k, v) + if not self:set(k, v) then + error("failed to insert key into cache - full"); + end + end; + __pairs = function (t) + return self:items(); + end; + __len = function (t) + return self:count(); + end; + }); + end + return self.proxy_table; +end + local function new(size, on_evict) size = assert(tonumber(size), "cache size must be a number"); size = math.floor(size);