1
0
mirror of https://github.com/HybridDog/riesenpilz.git synced 2025-01-25 01:00:18 +01:00

disallow giant mushrooms to replace every node, except giant apple and fly agaric

This commit is contained in:
HybridDog 2016-01-25 19:17:43 +01:00
parent 737bbf6c00
commit bf385faa96
2 changed files with 46 additions and 23 deletions

View File

@ -16,3 +16,4 @@ TODO:
— finish supporting the mushrooms mod — finish supporting the mushrooms mod
— add lava suit — add lava suit
— use visual_scale → crop textures and change nodeboxes (maybe automatically) — use visual_scale → crop textures and change nodeboxes (maybe automatically)
— don't replace every kind of node if a mushroom becomes giant (fly agaric, apple)

View File

@ -17,7 +17,32 @@ local function r_area(manip, width, height, pos)
return VoxelArea:new({MinEdge=emerged_pos1, MaxEdge=emerged_pos2}) return VoxelArea:new({MinEdge=emerged_pos1, MaxEdge=emerged_pos2})
end end
local function set_vm_data(manip, nodes, pos, t1, name) -- contents become added later
local c
-- cache buildable_to ids
local re_al_cache = {[minetest.get_content_id("ignore")] = true}
local function replacing_allowed(id)
if re_al_cache[id] ~= nil then
return re_al_cache[id]
end
local def = minetest.registered_nodes[minetest.get_name_from_content_id(id)]
if not def
or def.buildable_to then
re_al_cache[id] = true
return true
end
re_al_cache[id] = false
return false
end
local function set_vm_data(manip, pznodes, pos, t1, name)
local nodes = manip:get_data()
for vi,id in pairs(pznodes) do
if replacing_allowed(nodes[vi]) then
nodes[vi] = id
end
end
manip:set_data(nodes) manip:set_data(nodes)
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)
@ -27,9 +52,6 @@ local function set_vm_data(manip, nodes, pos, t1, name)
end end
-- contents become added later
local c
function riesenpilz.red(pos, nodes, area, w) function riesenpilz.red(pos, nodes, area, w)
local w = w or math.random(MAX_SIZE) local w = w or math.random(MAX_SIZE)
local h = w+2 local h = w+2
@ -61,11 +83,11 @@ local function riesenpilz_hybridpilz(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, w+1, w+3, pos) local area = r_area(manip, w+1, w+3, pos)
local nodes = manip:get_data()
riesenpilz.red(pos, nodes, area, w) local pznodes = {}
riesenpilz.red(pos, pznodes, area, w)
set_vm_data(manip, nodes, pos, t1, "red") set_vm_data(manip, pznodes, pos, t1, "red")
end end
@ -96,11 +118,11 @@ local function riesenpilz_brauner_minecraftpilz(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, br+1, br+3, pos) local area = r_area(manip, br+1, br+3, pos)
local nodes = manip:get_data()
riesenpilz.brown(pos, nodes, area, br) local pznodes = {}
riesenpilz.brown(pos, pznodes, area, br)
set_vm_data(manip, nodes, pos, t1, "brown") set_vm_data(manip, pznodes, pos, t1, "brown")
end end
@ -217,11 +239,11 @@ local function riesenpilz_lavashroom(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, 4, h+6, pos) local area = r_area(manip, 4, h+6, pos)
local nodes = manip:get_data()
riesenpilz.lavashroom(pos, nodes, area, h) local pznodes = {}
riesenpilz.lavashroom(pos, pznodes, area, h)
set_vm_data(manip, nodes, pos, t1, "lavashroom") set_vm_data(manip, pznodes, pos, t1, "lavashroom")
end end
@ -266,11 +288,11 @@ local function riesenpilz_glowshroom(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, 2, h+3, pos) local area = r_area(manip, 2, h+3, pos)
local nodes = manip:get_data()
riesenpilz.glowshroom(pos, nodes, area, h) local pznodes = {}
riesenpilz.glowshroom(pos, pznodes, area, h)
set_vm_data(manip, nodes, pos, t1, "glowshroom") set_vm_data(manip, pznodes, pos, t1, "glowshroom")
end end
@ -320,11 +342,11 @@ local function riesenpilz_parasol(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, w, h, pos) local area = r_area(manip, w, h, pos)
local nodes = manip:get_data()
riesenpilz.parasol(pos, nodes, area, w, h) local pznodes = {}
riesenpilz.parasol(pos, pznodes, area, w, h)
set_vm_data(manip, nodes, pos, t1, "parasol") set_vm_data(manip, pznodes, pos, t1, "parasol")
end end
@ -400,11 +422,11 @@ local function riesenpilz_red45(pos)
local manip = minetest.get_voxel_manip() local manip = minetest.get_voxel_manip()
local area = r_area(manip, 3, h, pos) local area = r_area(manip, 3, h, pos)
local nodes = manip:get_data()
riesenpilz.red45(pos, nodes, area, h1, h2) local pznodes = {}
riesenpilz.red45(pos, pznodes, area, h1, h2)
set_vm_data(manip, nodes, pos, t1, "red45") set_vm_data(manip, pznodes, pos, t1, "red45")
end end