mirror of
https://github.com/joe7575/techpack.git
synced 2025-02-18 10:43:46 +01:00
forceload bugfix
This commit is contained in:
@ -17,9 +17,20 @@ local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
|||||||
local P = minetest.string_to_pos
|
local P = minetest.string_to_pos
|
||||||
local M = minetest.get_meta
|
local M = minetest.get_meta
|
||||||
|
|
||||||
|
local function calc_area(pos)
|
||||||
|
local xpos = (math.floor(pos.x / 16) * 16)
|
||||||
|
local ypos = (math.floor(pos.y / 16) * 16)
|
||||||
|
local zpos = (math.floor(pos.z / 16) * 16)
|
||||||
|
local pos1 = {x=xpos, y=ypos, z=zpos}
|
||||||
|
local pos2 = {x=xpos+15, y=ypos+15, z=zpos+15}
|
||||||
|
return pos1, pos2
|
||||||
|
end
|
||||||
|
|
||||||
local function in_list(list, x)
|
local function in_list(list, x)
|
||||||
|
local pos1 = calc_area(x)
|
||||||
for _,v in ipairs(list) do
|
for _,v in ipairs(list) do
|
||||||
if vector.equals(v, x) then return true end
|
local pos2 = calc_area(v)
|
||||||
|
if vector.equals(pos1, pos2) then return true end
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
@ -60,20 +71,10 @@ local function get_node_lvm(pos)
|
|||||||
return node
|
return node
|
||||||
end
|
end
|
||||||
|
|
||||||
local function calc_area(pos)
|
|
||||||
local xpos = (math.floor(pos.x / 16) * 16)
|
|
||||||
local ypos = (math.floor(pos.y / 16) * 16)
|
|
||||||
local zpos = (math.floor(pos.z / 16) * 16)
|
|
||||||
local pos1 = {x=xpos, y=ypos, z=zpos}
|
|
||||||
local pos2 = {x=xpos+15, y=ypos+15, z=zpos+15}
|
|
||||||
return pos1, pos2
|
|
||||||
end
|
|
||||||
|
|
||||||
local function add_pos(pos, player)
|
local function add_pos(pos, player)
|
||||||
local pos1 = calc_area(pos)
|
|
||||||
local lPos = minetest.deserialize(player:get_attribute("tubelib_forceload_blocks")) or {}
|
local lPos = minetest.deserialize(player:get_attribute("tubelib_forceload_blocks")) or {}
|
||||||
if not in_list(lPos, pos1) and #lPos < tubelib.max_num_forceload_blocks then
|
if not in_list(lPos, pos) and #lPos < tubelib.max_num_forceload_blocks then
|
||||||
lPos[#lPos+1] = pos1
|
lPos[#lPos+1] = pos
|
||||||
player:set_attribute("tubelib_forceload_blocks", minetest.serialize(lPos))
|
player:set_attribute("tubelib_forceload_blocks", minetest.serialize(lPos))
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@ -81,9 +82,8 @@ local function add_pos(pos, player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function del_pos(pos, player)
|
local function del_pos(pos, player)
|
||||||
local pos1 = calc_area(pos)
|
|
||||||
local lPos = minetest.deserialize(player:get_attribute("tubelib_forceload_blocks")) or {}
|
local lPos = minetest.deserialize(player:get_attribute("tubelib_forceload_blocks")) or {}
|
||||||
lPos = remove_list_elem(lPos, pos1)
|
lPos = remove_list_elem(lPos, pos)
|
||||||
player:set_attribute("tubelib_forceload_blocks", minetest.serialize(lPos))
|
player:set_attribute("tubelib_forceload_blocks", minetest.serialize(lPos))
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -201,6 +201,7 @@ minetest.register_on_joinplayer(function(player)
|
|||||||
local lPos = {}
|
local lPos = {}
|
||||||
for _,pos in ipairs(get_pos_list(player)) do
|
for _,pos in ipairs(get_pos_list(player)) do
|
||||||
local node = get_node_lvm(pos)
|
local node = get_node_lvm(pos)
|
||||||
|
print("pos", S(pos), "name", node.name)
|
||||||
if node.name == "tubelib:forceload" then
|
if node.name == "tubelib:forceload" then
|
||||||
minetest.forceload_block(pos, true)
|
minetest.forceload_block(pos, true)
|
||||||
lPos[#lPos+1] = pos
|
lPos[#lPos+1] = pos
|
||||||
|
Reference in New Issue
Block a user