forked from CopilotC-Nvim/CopilotChat.nvim
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathorderedmap.lua
More file actions
52 lines (46 loc) · 1.14 KB
/
orderedmap.lua
File metadata and controls
52 lines (46 loc) · 1.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
---@class OrderedMap<K, V>
---@field set fun(self:OrderedMap, key:any, value:any)
---@field get fun(self:OrderedMap, key:any):any
---@field remove fun(self:OrderedMap, key:any)
---@field keys fun(self:OrderedMap):table
---@field values fun(self:OrderedMap):table
--- Create ordered map
---@generic K, V
---@return OrderedMap<K, V>
local function orderedmap()
return {
_keys = {},
_data = {},
set = function(self, key, value)
if not self._data[key] then
table.insert(self._keys, key)
end
self._data[key] = value
end,
get = function(self, key)
return self._data[key]
end,
remove = function(self, key)
if self._data[key] then
self._data[key] = nil
for i, k in ipairs(self._keys) do
if k == key then
table.remove(self._keys, i)
break
end
end
end
end,
keys = function(self)
return self._keys
end,
values = function(self)
local result = {}
for _, key in ipairs(self._keys) do
table.insert(result, self._data[key])
end
return result
end,
}
end
return orderedmap