mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2025-01-25 16:31:08 +01:00
Make corals dead when not near water
This commit is contained in:
parent
8b3ecb9321
commit
cf1df56b79
1 changed files with 86 additions and 10 deletions
|
@ -20,7 +20,7 @@ local function coral_on_place(itemstack, placer, pointed_thing)
|
||||||
local def_under = minetest.registered_nodes[node_under.name]
|
local def_under = minetest.registered_nodes[node_under.name]
|
||||||
|
|
||||||
if def_under and def_under.on_rightclick and not placer:get_player_control().sneak then
|
if def_under and def_under.on_rightclick and not placer:get_player_control().sneak then
|
||||||
return def_under.on_rightclick(pos_under, node_under.name,
|
return def_under.on_rightclick(pos_under, node_under,
|
||||||
placer, itemstack, pointed_thing) or itemstack
|
placer, itemstack, pointed_thing) or itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -31,11 +31,7 @@ local function coral_on_place(itemstack, placer, pointed_thing)
|
||||||
|
|
||||||
-- Placement rules:
|
-- Placement rules:
|
||||||
-- Coral plant can only be placed on top of a matching coral block.
|
-- Coral plant can only be placed on top of a matching coral block.
|
||||||
-- If alive, it must also be inside a water source.
|
if g_block == 0 or (g_coral ~= g_block) or (g_species_block ~= g_species_plant) then
|
||||||
-- Note: It's intentional that it works only for normal water (not river water). Corals are
|
|
||||||
-- for the ocean, after all.
|
|
||||||
if g_block == 0 or (g_coral ~= g_block) or (g_species_block ~= g_species_plant) or
|
|
||||||
(g_coral == 1 and minetest.get_node(pos_above).name ~= "mcl_core:water_source") then
|
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -111,7 +107,10 @@ for c=1, #corals do
|
||||||
node_dig_prediction = "mcl_ocean:"..id.."_coral_block",
|
node_dig_prediction = "mcl_ocean:"..id.."_coral_block",
|
||||||
on_place = coral_on_place,
|
on_place = coral_on_place,
|
||||||
after_destruct = function(pos)
|
after_destruct = function(pos)
|
||||||
minetest.set_node(pos, {name="mcl_ocean:"..id.."_coral_block"})
|
local node = minetest.get_node(pos)
|
||||||
|
if minetest.get_item_group(node.name, "coral") == 0 then
|
||||||
|
minetest.set_node(pos, {name="mcl_ocean:"..id.."_coral_block"})
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
_mcl_hardness = 0,
|
_mcl_hardness = 0,
|
||||||
_mcl_blast_resistance = 0,
|
_mcl_blast_resistance = 0,
|
||||||
|
@ -138,7 +137,10 @@ for c=1, #corals do
|
||||||
node_dig_prediction = "mcl_ocean:dead_"..id.."_coral_block",
|
node_dig_prediction = "mcl_ocean:dead_"..id.."_coral_block",
|
||||||
on_place = coral_on_place,
|
on_place = coral_on_place,
|
||||||
after_destruct = function(pos)
|
after_destruct = function(pos)
|
||||||
minetest.set_node(pos, {name="mcl_ocean:dead_"..id.."_coral_block"})
|
local node = minetest.get_node(pos)
|
||||||
|
if minetest.get_item_group(node.name, "coral") == 0 then
|
||||||
|
minetest.set_node(pos, {name="mcl_ocean:dead_"..id.."_coral_block"})
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
_mcl_hardness = 0,
|
_mcl_hardness = 0,
|
||||||
_mcl_blast_resistance = 0,
|
_mcl_blast_resistance = 0,
|
||||||
|
@ -168,7 +170,10 @@ for c=1, #corals do
|
||||||
node_dig_prediction = "mcl_ocean:"..id.."_coral_block",
|
node_dig_prediction = "mcl_ocean:"..id.."_coral_block",
|
||||||
on_place = coral_on_place,
|
on_place = coral_on_place,
|
||||||
after_destruct = function(pos)
|
after_destruct = function(pos)
|
||||||
minetest.set_node(pos, {name="mcl_ocean:"..id.."_coral_block"})
|
local node = minetest.get_node(pos)
|
||||||
|
if minetest.get_item_group(node.name, "coral") == 0 then
|
||||||
|
minetest.set_node(pos, {name="mcl_ocean:"..id.."_coral_block"})
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
_mcl_hardness = 0,
|
_mcl_hardness = 0,
|
||||||
_mcl_blast_resistance = 0,
|
_mcl_blast_resistance = 0,
|
||||||
|
@ -195,9 +200,80 @@ for c=1, #corals do
|
||||||
node_dig_prediction = "mcl_ocean:dead_"..id.."_coral_block",
|
node_dig_prediction = "mcl_ocean:dead_"..id.."_coral_block",
|
||||||
on_place = coral_on_place,
|
on_place = coral_on_place,
|
||||||
after_destruct = function(pos)
|
after_destruct = function(pos)
|
||||||
minetest.set_node(pos, {name="mcl_ocean:dead_"..id.."_coral_block"})
|
local node = minetest.get_node(pos)
|
||||||
|
if minetest.get_item_group(node.name, "coral") == 0 then
|
||||||
|
minetest.set_node(pos, {name="mcl_ocean:dead_"..id.."_coral_block"})
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
_mcl_hardness = 0,
|
_mcl_hardness = 0,
|
||||||
_mcl_blast_resistance = 0,
|
_mcl_blast_resistance = 0,
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Turn corals and coral fans to dead corals if not inside a water source
|
||||||
|
minetest.register_abm({
|
||||||
|
label = "Coral plant / coral fan death",
|
||||||
|
nodenames = { "group:coral_plant", "group_coral_fan" },
|
||||||
|
interval = 17,
|
||||||
|
chance = 5,
|
||||||
|
catch_up = false,
|
||||||
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
|
-- Check if coral's alive
|
||||||
|
local coral_state = minetest.get_item_group(node.name, "coral")
|
||||||
|
if coral_state == 1 then
|
||||||
|
-- Check node above, here lives the actual plant (it's plantlike_rooted)
|
||||||
|
if minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z}).name ~= "mcl_core:water_source" then
|
||||||
|
-- Find dead form (it's the same as the node's drop)
|
||||||
|
local def = minetest.registered_nodes[node.name]
|
||||||
|
local dead
|
||||||
|
if def then
|
||||||
|
node.name = def.drop
|
||||||
|
else
|
||||||
|
return
|
||||||
|
end
|
||||||
|
-- Set node to dead form.
|
||||||
|
minetest.set_node(pos, node)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Turn corals blocks to dead coral blocks if not next to a water source
|
||||||
|
minetest.register_abm({
|
||||||
|
label = "Coral block death",
|
||||||
|
nodenames = { "group:coral_block" },
|
||||||
|
interval = 17,
|
||||||
|
chance = 5,
|
||||||
|
catch_up = false,
|
||||||
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
|
-- Check if coral's alive
|
||||||
|
local coral_state = minetest.get_item_group(node.name, "coral")
|
||||||
|
if coral_state == 1 then
|
||||||
|
local posses = {
|
||||||
|
{ x=0,y=1,z=0 },
|
||||||
|
{ x=-1,y=0,z=0 },
|
||||||
|
{ x=1,y=0,z=0 },
|
||||||
|
{ x=0,y=0,z=-1 },
|
||||||
|
{ x=0,y=0,z=1 },
|
||||||
|
{ x=0,y=-1,z=0 },
|
||||||
|
}
|
||||||
|
-- Check all 6 neighbors for water
|
||||||
|
for p=1, #posses do
|
||||||
|
local checknode = minetest.get_node(vector.add(pos, posses[p]))
|
||||||
|
if checknode.name == "mcl_core:water_source" then
|
||||||
|
-- Water found! Don't die.
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- Find dead form (it's the same as the node's drop)
|
||||||
|
local def = minetest.registered_nodes[node.name]
|
||||||
|
if def then
|
||||||
|
node.name = def.drop
|
||||||
|
else
|
||||||
|
return
|
||||||
|
end
|
||||||
|
-- Set node to dead form
|
||||||
|
minetest.set_node(pos, node)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
Loading…
Reference in a new issue