add a setting to completely disallow growing a mushroom if some node intersects

This commit is contained in:
HybridDog 2016-01-26 15:51:34 +01:00
parent c26e59d432
commit 84941ca103
2 changed files with 33 additions and 8 deletions

View File

@ -36,7 +36,21 @@ local function replacing_allowed(id)
return false return false
end end
local function set_vm_nodes(manip, pznodes) local set_vm_nodes
if riesenpilz.giant_restrict_area then
function set_vm_nodes(manip, pznodes)
local nodes = manip:get_data()
for vi,id in pairs(pznodes) do
if not replacing_allowed(nodes[vi]) then
return false
end
nodes[vi] = id
end
manip:set_data(nodes)
return true
end
else
function set_vm_nodes(manip, pznodes)
local nodes = manip:get_data() local nodes = manip:get_data()
for vi,id in pairs(pznodes) do for vi,id in pairs(pznodes) do
if replacing_allowed(nodes[vi]) then if replacing_allowed(nodes[vi]) then
@ -44,10 +58,14 @@ local function set_vm_nodes(manip, pznodes)
end end
end end
manip:set_data(nodes) manip:set_data(nodes)
return true
end
end end
local function set_vm_data(manip, pznodes, pos, t1, name) local function set_vm_data(manip, pznodes, pos, t1, name)
set_vm_nodes(manip, pznodes) if not set_vm_nodes(manip, pznodes) then
return
end
manip:write_to_map() manip:write_to_map()
riesenpilz.inform("a giant "..name.." mushroom grew at "..vector.pos_to_string(pos), 3, t1) riesenpilz.inform("a giant "..name.." mushroom grew at "..vector.pos_to_string(pos), 3, t1)
local t1 = os.clock() local t1 = os.clock()
@ -167,7 +185,9 @@ local function riesenpilz_minecraft_fliegenpilz(pos)
local pznodes = {} local pznodes = {}
riesenpilz.fly_agaric(pos, pznodes, area, param2s) riesenpilz.fly_agaric(pos, pznodes, area, param2s)
set_vm_nodes(manip, pznodes) if not set_vm_nodes(manip, pznodes) then
return
end
manip:set_param2_data(param2s) manip:set_param2_data(param2s)
manip:write_to_map() manip:write_to_map()
manip:update_map() manip:update_map()
@ -477,7 +497,9 @@ local function riesenpilz_apple(pos)
local pznodes = {} local pznodes = {}
riesenpilz.apple(pos, pznodes, area) riesenpilz.apple(pos, pznodes, area)
set_vm_nodes(manip, pznodes) if not set_vm_nodes(manip, pznodes) then
return
end
manip:write_to_map() manip:write_to_map()
riesenpilz.inform("an apple grew at "..vector.pos_to_string(pos), 3, t1) riesenpilz.inform("an apple grew at "..vector.pos_to_string(pos), 3, t1)
manip:update_map() manip:update_map()

View File

@ -28,3 +28,6 @@ riesenpilz.max_spam = 2
--3d apple --3d apple
riesenpilz.change_apple = true riesenpilz.change_apple = true
--disallows growing a mushroom if it not every node would have a free place
riesenpilz.giant_restrict_area = false