mirror of
https://github.com/minetest-mods/areas.git
synced 2025-01-03 01:57:28 +01:00
Stop reusing holes in areas IDs
This eliminates the need of iterating the whole list for every protection operations. Note that the highest index isn't cached, i.e. the first or few (if there are many holes) operations would still suffer from the lag.
This commit is contained in:
parent
d2b227eca6
commit
ec77a57f42
16
internal.lua
16
internal.lua
@ -83,19 +83,19 @@ function areas:populateStore()
|
|||||||
self.store_ids = store_ids
|
self.store_ids = store_ids
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Finds the first usable index in a table
|
-- Guarentees returning an unused index in areas.areas
|
||||||
-- Eg: {[1]=false,[4]=true} -> 2
|
local index_cache = 0
|
||||||
local function findFirstUnusedIndex(t)
|
local function findFirstUnusedIndex()
|
||||||
local i = 0
|
local t = areas.areas
|
||||||
repeat i = i + 1
|
repeat index_cache = index_cache + 1
|
||||||
until t[i] == nil
|
until t[index_cache] == nil
|
||||||
return i
|
return index_cache
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Add an area.
|
--- Add an area.
|
||||||
-- @return The new area's ID.
|
-- @return The new area's ID.
|
||||||
function areas:add(owner, name, pos1, pos2, parent)
|
function areas:add(owner, name, pos1, pos2, parent)
|
||||||
local id = findFirstUnusedIndex(self.areas)
|
local id = findFirstUnusedIndex()
|
||||||
self.areas[id] = {
|
self.areas[id] = {
|
||||||
name = name,
|
name = name,
|
||||||
pos1 = pos1,
|
pos1 = pos1,
|
||||||
|
Loading…
Reference in New Issue
Block a user