forked from nalc/homedecor_modpack
Clean-up
This commit is contained in:
parent
db703e555d
commit
dca81b1648
@ -1,37 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
The 'Fake-Fire' mod was originally created by Semmett9.
|
|
||||||
|
|
||||||
URL to the 'Fake-Fire' thread on Minetest.net:
|
|
||||||
http://forum.minetest.net/viewtopic.php?id=6145
|
|
||||||
|
|
||||||
I've customized it a bit. Please see the changelog.txt file for more details.
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_15
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/nodes.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/nodes.lua")
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/crafts.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/crafts.lua")
|
||||||
dofile(minetest.get_modpath("fake_fire").."/modfiles/abms.lua")
|
dofile(minetest.get_modpath("fake_fire").."/modfiles/abms.lua")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
The lines below, at the end, are from the original author, Semmett9.
|
|
||||||
|
|
||||||
Thanks for a nice mod, Semmett9. ;)
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_14
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Thanks-
|
|
||||||
|
|
||||||
-- Many thanks for addi for his help in coding. --
|
|
||||||
|
|
||||||
-- Many thanks for the players on the King Arthur's land server for giving --
|
|
||||||
-- me support, ideas and allowing me to add the mod to the server itself. --
|
|
||||||
|
@ -1,52 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
I commented out this part because:
|
|
||||||
1. water and lava buckets are disabled on some servers,
|
|
||||||
2. putting out fire with water and especially lava would only make
|
|
||||||
a big mess, and...
|
|
||||||
|
|
||||||
As for 'realism':
|
|
||||||
* C'mon... This is *fake* fire.
|
|
||||||
* Torches have long been impervious to water.
|
|
||||||
* Minetest creates surreal worlds so it's OK if some things aren't
|
|
||||||
perfectly realistic.
|
|
||||||
|
|
||||||
Besides, the fake-fire can be put out by punching it - simple and effective.
|
|
||||||
~ LazyJ, 2014_03_14
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- water and lava puts out fake fire --
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"fake_fire:fake_fire"},
|
|
||||||
interval = 1,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node)
|
|
||||||
if minetest.env:find_node_near(pos, 1, {"default:water_source",
|
|
||||||
"default:water_flowing","default:lava_source",
|
|
||||||
"default:lava_flowing"}) then
|
|
||||||
minetest.sound_play("fire_extinguish",
|
|
||||||
{gain = 1.0, max_hear_distance = 20,})
|
|
||||||
node.name = "air"
|
|
||||||
minetest.env:set_node(pos, node)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- ADVISING ABOUT SMOKE PARTICLES SETTINGS
|
|
||||||
|
|
||||||
-- For the best visual result...
|
|
||||||
-- If you increase the particles size,
|
|
||||||
-- you should decrease the particles amount and/or increase the smoke column lenght.
|
|
||||||
-- If you increase the particle time duration and/or particle course,
|
|
||||||
-- you should decrease the particles amount or increase the smoke column lenght.
|
|
||||||
-- Or conversely...
|
|
||||||
-- ~ JP
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {
|
nodenames = {
|
||||||
"fake_fire:fake_fire",
|
"fake_fire:fake_fire",
|
||||||
@ -57,13 +8,11 @@ minetest.register_abm({
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 2,
|
chance = 2,
|
||||||
action = function(pos, node)
|
action = function(pos, node)
|
||||||
if
|
if minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z}).name == "air"
|
||||||
minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z}).name == "air" and
|
and minetest.get_node({x=pos.x, y=pos.y+2.0, z=pos.z}).name == "air" then
|
||||||
minetest.get_node({x=pos.x, y=pos.y+2.0, z=pos.z}).name == "air"
|
|
||||||
then
|
|
||||||
local image_number = math.random(4)
|
local image_number = math.random(4)
|
||||||
minetest.add_particlespawner({
|
minetest.add_particlespawner({
|
||||||
amount = 8,
|
amount = 6,
|
||||||
time = 1,
|
time = 1,
|
||||||
minpos = {x=pos.x-0.25, y=pos.y+0.4, z=pos.z-0.25},
|
minpos = {x=pos.x-0.25, y=pos.y+0.4, z=pos.z-0.25},
|
||||||
maxpos = {x=pos.x+0.25, y=pos.y+8, z=pos.z+0.25},
|
maxpos = {x=pos.x+0.25, y=pos.y+8, z=pos.z+0.25},
|
||||||
@ -78,7 +27,6 @@ minetest.register_abm({
|
|||||||
collisiondetection = false,
|
collisiondetection = false,
|
||||||
texture = "smoke_particle_"..image_number..".png",
|
texture = "smoke_particle_"..image_number..".png",
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -1,32 +1,3 @@
|
|||||||
--[[
|
|
||||||
|
|
||||||
NEVER-ENDING FLINT and STEEL
|
|
||||||
|
|
||||||
Uncraftable, at the moment, and I'm not sure yet how many wanna-be-firebug
|
|
||||||
griefers are going to litter with fake-fire. Why give them this if it only
|
|
||||||
makes the mess bigger? ~ LazyJ, 2014_03_13
|
|
||||||
|
|
||||||
May add a priv for this later so trusted players can use it.
|
|
||||||
~ LazyJ, 2014_06_19
|
|
||||||
|
|
||||||
minetest.register_craftitem("fake_fire:old_flint_and_steel", {
|
|
||||||
description = "Never ending flint and steel",
|
|
||||||
inventory_image = "flint_and_steel.png",
|
|
||||||
stack_max = 1,
|
|
||||||
liquids_pointable = false,
|
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
|
||||||
n = minetest.env:get_node(pointed_thing)
|
|
||||||
if pointed_thing.type == "node" then
|
|
||||||
minetest.env:add_node(pointed_thing.above,
|
|
||||||
{name="fake_fire:fake_fire"})
|
|
||||||
minetest.sound_play("",
|
|
||||||
{gain = 1.0, max_hear_distance = 20,})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
-- RECIPE ITEM - FLINT
|
-- RECIPE ITEM - FLINT
|
||||||
minetest.register_craftitem("fake_fire:flint", {
|
minetest.register_craftitem("fake_fire:flint", {
|
||||||
description = "flint",
|
description = "flint",
|
||||||
@ -35,8 +6,6 @@ minetest.register_craftitem("fake_fire:flint", {
|
|||||||
liquids_pointable = false,
|
liquids_pointable = false,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- FLINT
|
-- FLINT
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@ -47,8 +16,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- FLINT & STEEL
|
-- FLINT & STEEL
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@ -59,8 +26,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- EMBERS
|
-- EMBERS
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@ -71,14 +36,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOPS - SMOKELESS
|
|
||||||
|
|
||||||
-- Only the smokeless kind will be craftable and shown in the inventory.
|
|
||||||
-- The nodes are coded to switch to the smoking chimney tops when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
|
|
||||||
-- STONE CHIMNEY TOP
|
-- STONE CHIMNEY TOP
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@ -89,8 +46,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SANDSTONE CHIMNEY TOP
|
-- SANDSTONE CHIMNEY TOP
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
@ -101,35 +56,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Crafting Chain - Cobble-to-Gravel-to-Sand and Convert Sands
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
Craft one cobble into one gravel.
|
|
||||||
Craft one gravel into one sand.
|
|
||||||
Convert-craft sand to desert sand and vice-versa.
|
|
||||||
|
|
||||||
This was suggested by klappspaten and it makes sense in both its natural
|
|
||||||
progression and as a practical way for players to get some of the non-
|
|
||||||
renewable resources that they need.
|
|
||||||
|
|
||||||
Because the gravel-to-sand recipe (from one of our other custom mods)
|
|
||||||
conflicted with the Fake Fire mod's flint recipe, the Fake Fire mod's
|
|
||||||
recipe was changed to require 2 gravel.
|
|
||||||
|
|
||||||
I've added the cobble-gravel-sand and convert sands recipes as a bonus and
|
|
||||||
to make-up for the more expensive flint recipe. You can comment-out these
|
|
||||||
recipes because they aren't *required* by this fork of Fake Fire, but they
|
|
||||||
*are* handy recipes to have.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
-- Cobble to Gravel
|
-- Cobble to Gravel
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:gravel',
|
output = 'default:gravel',
|
||||||
@ -138,8 +64,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Gravel to Sand
|
-- Gravel to Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:sand',
|
output = 'default:sand',
|
||||||
@ -148,8 +72,6 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Desert Sand to Sand
|
-- Desert Sand to Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:sand',
|
output = 'default:sand',
|
||||||
@ -158,12 +80,10 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Sand to Desert Sand
|
-- Sand to Desert Sand
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'default:desert_sand',
|
output = 'default:desert_sand',
|
||||||
recipe = {
|
recipe = {
|
||||||
{'default:sand'},
|
{'default:sand'},
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -4,54 +4,41 @@ local function register_fake_fire(name, def)
|
|||||||
assert(name, "local registration called without name")
|
assert(name, "local registration called without name")
|
||||||
assert(def, "local registration called without node definition")
|
assert(def, "local registration called without node definition")
|
||||||
|
|
||||||
-- make sure shared definitions are set
|
|
||||||
def.is_ground_content = true
|
def.is_ground_content = true
|
||||||
def.inventory_image = def.inventory_image or name.. ".png"
|
def.inventory_image = def.inventory_image or name..".png"
|
||||||
def.drawtype = "plantlike"
|
def.drawtype = "plantlike"
|
||||||
def.waving = 1 -- Waving wasn't an option when this mod was written. ~ LazyJ, 2014_03_13
|
def.waving = 1
|
||||||
def.light_source = def.lightsource or 14
|
def.light_source = def.lightsource or 14
|
||||||
-- Adding sunlight_propagtes and leaving comments as a future reference.
|
|
||||||
-- If true, sunlight will go infinitely through this (no shadow is cast).
|
|
||||||
-- Because fire produces light it should be "true" so fire *doesn't* have
|
|
||||||
-- a shadow.
|
|
||||||
def.sunlight_propagates = true
|
def.sunlight_propagates = true
|
||||||
-- damage_per_second = 2*0.5, -- It's *fake* fire. PvP on our server has
|
|
||||||
-- been disabled for a reason. I don't want griefers lighting players on
|
|
||||||
-- fire or trapping them in blazes. ~ LazyJ, 2014_0_13
|
|
||||||
|
|
||||||
def.groups = def.groups or {
|
def.groups = def.groups or {
|
||||||
oddly_breakable_by_hand=3, dig_immediate=2,
|
oddly_breakable_by_hand=3, dig_immediate=2,
|
||||||
attached_node=1, not_in_creative_inventory=1
|
attached_node=1, not_in_creative_inventory=1
|
||||||
}
|
}
|
||||||
def.paramtype = "light"
|
def.paramtype = "light"
|
||||||
def.walkable = false
|
def.walkable = false
|
||||||
def.drop = "" -- So fire won't return to the inventory. ~ LazyJ
|
def.drop = ""
|
||||||
def.sounds = def.sounds or minetest.sound_play("fire_small", {pos=cp, loop=true})
|
def.sounds = def.sounds or minetest.sound_play("fire_small", {pos=cp, loop=true})
|
||||||
def.buildable_to = true
|
def.buildable_to = true
|
||||||
|
|
||||||
local swap_on_punch = def.swap_on_punch
|
local swap_on_punch = def.swap_on_punch
|
||||||
def.on_punch = def.on_punch or function (pos, node, puncher)
|
def.on_punch = def.on_punch or function (pos, node, puncher)
|
||||||
-- A max_hear_distance of 20 may freak some players out by the "hiss"
|
|
||||||
-- so I reduced it to 5.
|
|
||||||
minetest.sound_play("fire_extinguish", {pos = pos, gain = 1.0, max_hear_distance = 5,})
|
minetest.sound_play("fire_extinguish", {pos = pos, gain = 1.0, max_hear_distance = 5,})
|
||||||
-- swap the node on_punch if def.swap_on_punch is set
|
|
||||||
if swap_on_punch then
|
if swap_on_punch then
|
||||||
minetest.set_node(pos, {name = swap_on_punch})
|
minetest.set_node(pos, {name = swap_on_punch})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- no need to add these to the global registration table
|
|
||||||
def.swap_on_punch = nil
|
def.swap_on_punch = nil
|
||||||
def.smoking = nil
|
def.smoking = nil
|
||||||
minetest.register_node("fake_fire:" .. name, def)
|
minetest.register_node("fake_fire:"..name, def)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- FLAME TYPES
|
-- FLAME TYPES
|
||||||
register_fake_fire("fake_fire", {
|
register_fake_fire("fake_fire", {
|
||||||
description = "Smokey, Fake Fire",
|
description = "Smokey, Fake Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="fake_fire_animated.png", animation={type="vertical_frames",
|
{name="fake_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
swap_on_punch = "fake_fire:smokeless_fire",
|
swap_on_punch = "fake_fire:smokeless_fire",
|
||||||
})
|
})
|
||||||
@ -59,8 +46,7 @@ register_fake_fire("fake_fire", {
|
|||||||
register_fake_fire("smokeless_fire", {
|
register_fake_fire("smokeless_fire", {
|
||||||
description = "Smokeless, Fake Fire",
|
description = "Smokeless, Fake Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="fake_fire_animated.png", animation={type="vertical_frames",
|
{name="fake_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
inventory_image = 'fake_fire.png',
|
inventory_image = 'fake_fire.png',
|
||||||
swap_on_punch = "fake_fire:fake_fire",
|
swap_on_punch = "fake_fire:fake_fire",
|
||||||
@ -69,8 +55,7 @@ register_fake_fire("smokeless_fire", {
|
|||||||
register_fake_fire("ice_fire", {
|
register_fake_fire("ice_fire", {
|
||||||
description = "Smoky, Fake, Ice Fire",
|
description = "Smoky, Fake, Ice Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="ice_fire_animated.png", animation={type="vertical_frames",
|
{name="ice_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
swap_on_punch = "fake_fire:smokeless_ice_fire",
|
swap_on_punch = "fake_fire:smokeless_ice_fire",
|
||||||
})
|
})
|
||||||
@ -78,13 +63,13 @@ register_fake_fire("ice_fire", {
|
|||||||
register_fake_fire("smokeless_ice_fire", {
|
register_fake_fire("smokeless_ice_fire", {
|
||||||
description = "Smokeless, Fake, Ice Fire",
|
description = "Smokeless, Fake, Ice Fire",
|
||||||
tiles = {
|
tiles = {
|
||||||
{name="ice_fire_animated.png", animation={type="vertical_frames",
|
{name="ice_fire_animated.png", animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.5}},
|
||||||
aspect_w=16, aspect_h=16, length=1.5}},
|
|
||||||
},
|
},
|
||||||
inventory_image = 'ice_fire.png',
|
inventory_image = 'ice_fire.png',
|
||||||
swap_on_punch = "fake_fire:ice_fire",
|
swap_on_punch = "fake_fire:ice_fire",
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
-- FLINT and STEEL
|
-- FLINT and STEEL
|
||||||
minetest.register_tool("fake_fire:flint_and_steel", {
|
minetest.register_tool("fake_fire:flint_and_steel", {
|
||||||
description = "Flint and steel",
|
description = "Flint and steel",
|
||||||
@ -98,138 +83,40 @@ minetest.register_tool("fake_fire:flint_and_steel", {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
-- This next section took me a lot of keyboard bashing to figure out.
|
|
||||||
-- The lua documentation and examples for Minetest are terrible.
|
|
||||||
-- ~ LazyJ, 2014_06_23
|
|
||||||
|
|
||||||
local snow_ice_list = {"snow", "ice",}
|
local snow_ice_list = {"snow", "ice",}
|
||||||
|
|
||||||
for _, which_one_is_it in pairs(snow_ice_list) do
|
for _, which_one_is_it in pairs(snow_ice_list) do
|
||||||
local snow_ice = which_one_is_it
|
local snow_ice = which_one_is_it
|
||||||
|
|
||||||
if
|
if pointed_thing.type == "node"
|
||||||
-- A *node*, not a player or sprite. ~ LazyJ
|
and not string.find(minetest.get_node(pointed_thing.under).name, "snow")
|
||||||
pointed_thing.type == "node"
|
and not string.find(minetest.get_node(pointed_thing.under).name, "ice")
|
||||||
|
and minetest.get_node(pointed_thing.above).name == "air"
|
||||||
--[[
|
|
||||||
These next two "and nots" tell Minetest not to put the
|
|
||||||
red flame on snow and ice stuff. This "string" bit was
|
|
||||||
the workable solution that took many hours, over
|
|
||||||
several days, to finally come around to. It's a search
|
|
||||||
for any node name that contains whatever is between the
|
|
||||||
double-quotes, ie. "snow" or "ice". I had been trying
|
|
||||||
to identify the nodes by their group properties and I
|
|
||||||
couldn't figure out how to do it. The clue for the
|
|
||||||
"string"came from Blockmen's "Landscape" mod.
|
|
||||||
|
|
||||||
Another quirk is that the "string" doesn't work well
|
|
||||||
with variable lists (see "snow_ice_list") when using
|
|
||||||
"and not". Ice-fire would light on snow but when I
|
|
||||||
clicked on ice, the regular flame appeared. I couldn't
|
|
||||||
understand what was happening until I mentally changed
|
|
||||||
the wording "and not" to "is not" and spoke out-loud
|
|
||||||
each thing that line of code was to accomplish:
|
|
||||||
|
|
||||||
"Is not snow, then make fake-fire."
|
|
||||||
"Is not ice, then make fake-fire."
|
|
||||||
|
|
||||||
That's when I caught the problem.
|
|
||||||
|
|
||||||
Ice *is not* snow, so Minetest was correctly following
|
|
||||||
the instruction, "Is not snow, then make fake-fire."
|
|
||||||
and that is why fake-fire appeared instead of ice-fire
|
|
||||||
when I clicked on ice.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
--]]
|
|
||||||
|
|
||||||
and not
|
|
||||||
string.find(minetest.get_node(pointed_thing.under).name, "snow")
|
|
||||||
and not
|
|
||||||
string.find(minetest.get_node(pointed_thing.under).name, "ice")
|
|
||||||
and
|
|
||||||
minetest.get_node(pointed_thing.above).name == "air"
|
|
||||||
then
|
then
|
||||||
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
||||||
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_fire"})
|
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_fire"})
|
||||||
else
|
else
|
||||||
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
||||||
end
|
end
|
||||||
elseif
|
elseif pointed_thing.type == "node"
|
||||||
|
and string.find(minetest.get_node(pointed_thing.under).name,snow_ice)
|
||||||
pointed_thing.type == "node"
|
and minetest.get_node(pointed_thing.above).name == "air" then
|
||||||
and
|
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
||||||
-- Split this "string" across several lines because I ran out
|
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_ice_fire"})
|
||||||
-- of room while trying to adhere to the 80-column wide rule
|
else
|
||||||
-- of coding style.
|
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
||||||
string.find(
|
end
|
||||||
minetest.get_node(pointed_thing.under).name,
|
end
|
||||||
snow_ice
|
end
|
||||||
)
|
|
||||||
and
|
|
||||||
minetest.get_node(pointed_thing.above).name == "air"
|
|
||||||
then
|
|
||||||
if not minetest.is_protected(pointed_thing.above, user:get_player_name()) then
|
|
||||||
minetest.set_node(pointed_thing.above, {name="fake_fire:smokeless_ice_fire"})
|
|
||||||
else
|
|
||||||
minetest.chat_send_player(user:get_player_name(), "You can't set a fire in someone else's area!")
|
|
||||||
end
|
|
||||||
end -- Line 210, if
|
|
||||||
end -- Line 207, for/do
|
|
||||||
|
|
||||||
minetest.sound_play("",
|
minetest.sound_play("", {gain = 1.0, max_hear_distance = 2,})
|
||||||
{gain = 1.0, max_hear_distance = 2,})
|
|
||||||
itemstack:add_wear(65535/65)
|
itemstack:add_wear(65535/65)
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
}) -- Closes the flint and steel tool registration
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
SOME LESSONS LEARNED (and keeping this because I'll forget)
|
|
||||||
|
|
||||||
flint_and_steel is registered as a tool. Tools do not materialize something
|
|
||||||
like placing a block (on_construct) makes that block appear. Tools are
|
|
||||||
*used* so "on_use" works but not "on_construct".
|
|
||||||
|
|
||||||
on_rightclick is meant for the code of the thing being clicked on, not the
|
|
||||||
code of the thing doing the clicking.
|
|
||||||
|
|
||||||
~ LazyJ
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- ANIMATED, RISING, DISPAPPEARING SMOKE
|
|
||||||
|
|
||||||
--[[
|
|
||||||
|
|
||||||
These next two sections of code are a real bonus that I figured out how
|
|
||||||
to pull-off. ;)
|
|
||||||
|
|
||||||
The first section creates animated smoke. Trying to figure out how to make
|
|
||||||
the animation appear to go upward was a headache.
|
|
||||||
|
|
||||||
The second section places the animated smoke *only* above the fake-fire
|
|
||||||
*if* there is nothing but air straight above the fake-fire. I also made
|
|
||||||
the smoke skip a space so it looks more like puffs of smoke and made it
|
|
||||||
stretch high enough to be used in chimneys. For large builds, a second
|
|
||||||
fake-fire will have to be hidden close to the top of the chimney so the
|
|
||||||
smoke will be visible. The smoke also emmits a low-level light.
|
|
||||||
|
|
||||||
Yup, I'm proud of this little addition I've made to Semmett9's mod. :D
|
|
||||||
|
|
||||||
~ LazyJ, 2014_03_15
|
|
||||||
|
|
||||||
--]]
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- EMBERS
|
-- EMBERS
|
||||||
|
|
||||||
minetest.register_node("fake_fire:embers", {
|
minetest.register_node("fake_fire:embers", {
|
||||||
description = "Glowing Embers",
|
description = "Glowing Embers",
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -239,30 +126,15 @@ minetest.register_node("fake_fire:embers", {
|
|||||||
inventory_image = minetest.inventorycube('fake_fire_embers.png'),
|
inventory_image = minetest.inventorycube('fake_fire_embers.png'),
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
light_source = 9,
|
light_source = 9,
|
||||||
-- Adding sunlight_propagtes and leaving comments as a future reference.
|
|
||||||
-- If true, sunlight will go infinitely through this (no shadow is cast).
|
|
||||||
-- Because embers produce some light it should be somewhat "true" but this
|
|
||||||
-- is an area where Minetest lacks in subtlety so I'm opting for 100% that
|
|
||||||
-- embers *don't* have a shadow.
|
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
-- It's almost soft, brittle charcoal. ~ LazyJ
|
|
||||||
groups = {choppy=3, crumbly=3, oddly_breakable_by_hand=3},
|
groups = {choppy=3, crumbly=3, oddly_breakable_by_hand=3},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
-- You never know when a creative builder may use the screwdriver or
|
|
||||||
-- position to create a subtle effect that makes their creation just
|
|
||||||
-- that little bit nicer looking. ~ Lazyj
|
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
walkable = true,
|
walkable = true,
|
||||||
sounds = minetest.sound_play("fire_small", {pos=cp, loop=true}),
|
sounds = minetest.sound_play("fire_small", {pos=cp, loop=true}),
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOPS
|
|
||||||
|
|
||||||
-- Stone (cool tone) to go with cool colors.
|
|
||||||
-- Sandstone (warm tone) to go with warm colors.
|
|
||||||
|
|
||||||
-- CHIMNEY TOP - STONE
|
-- CHIMNEY TOP - STONE
|
||||||
minetest.register_node("fake_fire:chimney_top_stone", {
|
minetest.register_node("fake_fire:chimney_top_stone", {
|
||||||
description = "Chimney Top - Stone",
|
description = "Chimney Top - Stone",
|
||||||
@ -278,14 +150,11 @@ minetest.register_node("fake_fire:chimney_top_stone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_stone"})
|
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_stone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- CHIMNEY TOP - SANDSTONE
|
-- CHIMNEY TOP - SANDSTONE
|
||||||
minetest.register_node("fake_fire:chimney_top_sandstone", {
|
minetest.register_node("fake_fire:chimney_top_sandstone", {
|
||||||
description = "Chimney Top - Sandstone",
|
description = "Chimney Top - Sandstone",
|
||||||
@ -301,22 +170,11 @@ minetest.register_node("fake_fire:chimney_top_sandstone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
minetest.set_node(pos, {name = "fake_fire:smokeless_chimney_top_sandstone"})
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos,
|
|
||||||
{name = "fake_fire:smokeless_chimney_top_sandstone"})
|
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOPS
|
|
||||||
|
|
||||||
-- Some players may want a chimney top *without* smoke. This is the node
|
|
||||||
-- that will be craftable. To get the smoking variety, simply punch the
|
|
||||||
-- node. Same approach is used with the smoking and non-smoking flames.
|
|
||||||
-- ~ LazyJ
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOP - STONE
|
-- SMOKELESS CHIMNEY TOP - STONE
|
||||||
minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
||||||
description = "Chimney Top - Stone",
|
description = "Chimney Top - Stone",
|
||||||
@ -331,14 +189,11 @@ minetest.register_node("fake_fire:smokeless_chimney_top_stone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:chimney_top_stone"})
|
minetest.set_node(pos, {name = "fake_fire:chimney_top_stone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- SMOKELESS CHIMNEY TOP - SANDSTONE
|
-- SMOKELESS CHIMNEY TOP - SANDSTONE
|
||||||
minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
||||||
description = "Chimney Top - Sandstone",
|
description = "Chimney Top - Sandstone",
|
||||||
@ -353,8 +208,6 @@ minetest.register_node("fake_fire:smokeless_chimney_top_sandstone", {
|
|||||||
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
fixed = {-0.5, -0.5, -0.5, 0.5, 0, 0.5},
|
||||||
},
|
},
|
||||||
on_punch = function (pos,node,puncher)
|
on_punch = function (pos,node,puncher)
|
||||||
-- This swaps the smokeless version with the smoky version when punched.
|
|
||||||
-- ~ LazyJ
|
|
||||||
minetest.set_node(pos, {name = "fake_fire:chimney_top_sandstone"})
|
minetest.set_node(pos, {name = "fake_fire:chimney_top_sandstone"})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@ -417,7 +417,7 @@ function homedecor.flip_door(pos, node, player, name, side, isClosed)
|
|||||||
gain = 2,
|
gain = 2,
|
||||||
})
|
})
|
||||||
-- XXX: does the top half have to remember open/closed too?
|
-- XXX: does the top half have to remember open/closed too?
|
||||||
minetest.add_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
minetest.set_node({x=pos.x, y=pos.y+1, z=pos.z}, { name = "homedecor:door_"..name.."_top_"..rside, param2=nfdir})
|
||||||
|
|
||||||
addDoorNode(pos,{ name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir },isClosed)
|
addDoorNode(pos,{ name = "homedecor:door_"..name.."_bottom_"..rside, param2=nfdir },isClosed)
|
||||||
end
|
end
|
||||||
|
@ -16,7 +16,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -36,7 +36,7 @@ for i in ipairs(colors) do
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
local nfdir = dirs2[fdir+1]
|
local nfdir = dirs2[fdir+1]
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = nfdir})
|
minetest.set_node(pos, {name = "homedecor:glowlight_quarter_"..color, param2 = nfdir})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ for i in ipairs(colors) do
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
local nfdir = dirs2[fdir+1]
|
local nfdir = dirs2[fdir+1]
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = nfdir})
|
minetest.set_node(pos, {name = "homedecor:glowlight_half_"..color, param2 = nfdir})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -56,7 +56,7 @@ for i in ipairs(colors) do
|
|||||||
interval = 1,
|
interval = 1,
|
||||||
chance = 1,
|
chance = 1,
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
minetest.add_node(pos, {name = "homedecor:glowlight_small_cube_"..color, param2 = 20})
|
minetest.set_node(pos, {name = "homedecor:glowlight_small_cube_"..color, param2 = 20})
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -164,7 +164,7 @@ homedecor.register("fishtank", {
|
|||||||
sounds = default.node_sound_glass_defaults(),
|
sounds = default.node_sound_glass_defaults(),
|
||||||
on_rightclick = function(pos, node, clicker)
|
on_rightclick = function(pos, node, clicker)
|
||||||
fdir = minetest.get_node(pos).param2
|
fdir = minetest.get_node(pos).param2
|
||||||
minetest.add_node(pos, {name = "homedecor:fishtank_lighted", param2 = fdir})
|
minetest.set_node(pos, {name = "homedecor:fishtank_lighted", param2 = fdir})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -200,7 +200,7 @@ homedecor.register("fishtank_lighted", {
|
|||||||
sounds = default.node_sound_glass_defaults(),
|
sounds = default.node_sound_glass_defaults(),
|
||||||
on_rightclick = function(pos, node, clicker)
|
on_rightclick = function(pos, node, clicker)
|
||||||
fdir = minetest.get_node(pos).param2
|
fdir = minetest.get_node(pos).param2
|
||||||
minetest.add_node(pos, {name = "homedecor:fishtank", param2 = fdir})
|
minetest.set_node(pos, {name = "homedecor:fishtank", param2 = fdir})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -110,7 +110,7 @@ minetest.register_abm({
|
|||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
action = function(pos, node, active_object_count, active_object_count_wider)
|
||||||
local newnode = string.sub(node.name, 1, -3) -- strip the "_s" from the name
|
local newnode = string.sub(node.name, 1, -3) -- strip the "_s" from the name
|
||||||
local fdir = node.param2 or 0
|
local fdir = node.param2 or 0
|
||||||
minetest.add_node(pos, {name = newnode, param2 = dirs2[fdir+1]})
|
minetest.set_node(pos, {name = newnode, param2 = dirs2[fdir+1]})
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user