mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2024-12-01 23:11:11 +01:00
Move eternal fire ignition code to the actual node
This commit is contained in:
parent
c6a471e5a7
commit
b4f1d2c521
4 changed files with 52 additions and 47 deletions
|
@ -563,6 +563,26 @@ minetest.register_node("mcl_core:bedrock", {
|
||||||
drop = '',
|
drop = '',
|
||||||
_mcl_blast_resistance = 18000000,
|
_mcl_blast_resistance = 18000000,
|
||||||
_mcl_hardness = -1,
|
_mcl_hardness = -1,
|
||||||
|
|
||||||
|
-- Eternal fire on top of bedrock, if in the End dimension
|
||||||
|
after_destruct = function(pos)
|
||||||
|
pos.y = pos.y + 1
|
||||||
|
if minetest.get_node(pos).name == "mcl_fire:eternal_fire" then
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
_on_ignite = function(player, pointed_thing)
|
||||||
|
local pos = pointed_thing.under
|
||||||
|
local _, dim = mcl_util.y_to_layer(pos.y)
|
||||||
|
local flame_pos = {x = pos.x, y = pos.y + 1, z = pos.z}
|
||||||
|
local fn = minetest.get_node(flame_pos)
|
||||||
|
if dim == "end" and fn.name == "air" and not minetest.is_protected(flame_pos, "fire") and pointed_thing.under.y < pointed_thing.above.y then
|
||||||
|
minetest.set_node(flame_pos, {name = "mcl_fire:eternal_fire"})
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("mcl_core:cobble", {
|
minetest.register_node("mcl_core:cobble", {
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
mcl_core
|
mcl_core
|
||||||
mcl_util
|
mcl_util
|
||||||
mcl_sounds
|
mcl_sounds
|
||||||
mcl_nether?
|
|
||||||
mcl_portals?
|
mcl_portals?
|
||||||
|
|
|
@ -74,9 +74,11 @@ minetest.register_node("mcl_fire:fire", {
|
||||||
sounds = {},
|
sounds = {},
|
||||||
-- Turn into eternal fire on special blocks, light Nether portal (if possible), start burning timer
|
-- Turn into eternal fire on special blocks, light Nether portal (if possible), start burning timer
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
local under = minetest.get_node({x=pos.x, y=pos.y-1, z=pos.z}).name
|
local bpos = {x=pos.x, y=pos.y-1, z=pos.z}
|
||||||
|
local under = minetest.get_node(bpos).name
|
||||||
|
|
||||||
if under == "mcl_nether:magma" or under == "mcl_nether:netherrack" then
|
local _, dim = mcl_util.y_to_layer(bpos.y)
|
||||||
|
if under == "mcl_nether:magma" or under == "mcl_nether:netherrack" or (under == "mcl_core:bedrock" and dim == "end") then
|
||||||
minetest.swap_node(pos, {name = "mcl_fire:eternal_fire"})
|
minetest.swap_node(pos, {name = "mcl_fire:eternal_fire"})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -391,50 +393,6 @@ else -- Fire enabled
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Spawn eternal fire when fire starts on netherrack or magma block.
|
|
||||||
-- Also on bedrock when it's in the end.
|
|
||||||
|
|
||||||
local eternal_override = {
|
|
||||||
after_destruct = function(pos, oldnode)
|
|
||||||
pos.y = pos.y + 1
|
|
||||||
if minetest.get_node(pos).name == "mcl_fire:eternal_fire" then
|
|
||||||
minetest.remove_node(pos)
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
_on_ignite = function(player, pointed_thing)
|
|
||||||
local pos = pointed_thing.under
|
|
||||||
local flame_pos = {x = pos.x, y = pos.y + 1, z = pos.z}
|
|
||||||
local fn = minetest.get_node(flame_pos)
|
|
||||||
if fn.name == "air" and not minetest.is_protected(flame_pos, "fire") and pointed_thing.under.y < pointed_thing.above.y then
|
|
||||||
minetest.set_node(flame_pos, {name = "mcl_fire:eternal_fire"})
|
|
||||||
return true
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
}
|
|
||||||
local eternal_override_end = {
|
|
||||||
after_destruct = eternal_override.after_destruct,
|
|
||||||
_on_ignite = function(player, pointed_thing)
|
|
||||||
local pos = pointed_thing.under
|
|
||||||
local _, dim = mcl_util.y_to_layer(pos.y)
|
|
||||||
local flame_pos = {x = pos.x, y = pos.y + 1, z = pos.z}
|
|
||||||
local fn = minetest.get_node(flame_pos)
|
|
||||||
if dim == "end" and fn.name == "air" and not minetest.is_protected(flame_pos, "fire") and pointed_thing.under.y < pointed_thing.above.y then
|
|
||||||
minetest.set_node(flame_pos, {name = "mcl_fire:eternal_fire"})
|
|
||||||
return true
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
}
|
|
||||||
|
|
||||||
minetest.override_item("mcl_core:bedrock", eternal_override_end)
|
|
||||||
if minetest.get_modpath("mcl_nether") then
|
|
||||||
minetest.override_item("mcl_nether:netherrack", eternal_override)
|
|
||||||
minetest.override_item("mcl_nether:magma", eternal_override)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Set pointed_thing on (normal) fire
|
-- Set pointed_thing on (normal) fire
|
||||||
mcl_fire.set_fire = function(pointed_thing)
|
mcl_fire.set_fire = function(pointed_thing)
|
||||||
local n = minetest.get_node(pointed_thing.above)
|
local n = minetest.get_node(pointed_thing.above)
|
||||||
|
|
|
@ -35,6 +35,26 @@ minetest.register_node("mcl_nether:quartz_ore", {
|
||||||
_mcl_hardness = 3,
|
_mcl_hardness = 3,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- For eternal fire on top of netherrack and magma blocks
|
||||||
|
-- (this code does not require a dependency on mcl_fire)
|
||||||
|
local eternal_after_destruct = function(pos, oldnode)
|
||||||
|
pos.y = pos.y + 1
|
||||||
|
if minetest.get_node(pos).name == "mcl_fire:eternal_fire" then
|
||||||
|
minetest.remove_node(pos)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local eternal_on_ignite = function(player, pointed_thing)
|
||||||
|
local pos = pointed_thing.under
|
||||||
|
local flame_pos = {x = pos.x, y = pos.y + 1, z = pos.z}
|
||||||
|
local fn = minetest.get_node(flame_pos)
|
||||||
|
if fn.name == "air" and not minetest.is_protected(flame_pos, "fire") and pointed_thing.under.y < pointed_thing.above.y then
|
||||||
|
minetest.set_node(flame_pos, {name = "mcl_fire:eternal_fire"})
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_node("mcl_nether:netherrack", {
|
minetest.register_node("mcl_nether:netherrack", {
|
||||||
description = "Netherrack",
|
description = "Netherrack",
|
||||||
_doc_items_longdesc = "Netherrack is a stone-like block home to the Nether. Starting a fire on this block will create an eternal fire.",
|
_doc_items_longdesc = "Netherrack is a stone-like block home to the Nether. Starting a fire on this block will create an eternal fire.",
|
||||||
|
@ -45,6 +65,10 @@ minetest.register_node("mcl_nether:netherrack", {
|
||||||
sounds = mcl_sounds.node_sound_stone_defaults(),
|
sounds = mcl_sounds.node_sound_stone_defaults(),
|
||||||
_mcl_blast_resistance = 2,
|
_mcl_blast_resistance = 2,
|
||||||
_mcl_hardness = 0.4,
|
_mcl_hardness = 0.4,
|
||||||
|
|
||||||
|
-- Eternal fire on top
|
||||||
|
after_destruct = eternal_after_destruct,
|
||||||
|
_on_ignite = eternal_on_ignite,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("mcl_nether:magma", {
|
minetest.register_node("mcl_nether:magma", {
|
||||||
|
@ -67,6 +91,10 @@ minetest.register_node("mcl_nether:magma", {
|
||||||
end,
|
end,
|
||||||
_mcl_blast_resistance = 2.5,
|
_mcl_blast_resistance = 2.5,
|
||||||
_mcl_hardness = 0.5,
|
_mcl_hardness = 0.5,
|
||||||
|
|
||||||
|
-- Eternal fire on top
|
||||||
|
after_destruct = eternal_after_destruct,
|
||||||
|
_on_ignite = eternal_on_ignite,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("mcl_nether:soul_sand", {
|
minetest.register_node("mcl_nether:soul_sand", {
|
||||||
|
|
Loading…
Reference in a new issue