commit
f74da0509b
@ -201,9 +201,7 @@ minetest.register_node("stm_nodes:tank2", {
|
||||
|
||||
minetest.register_node("stm_nodes:stand", {
|
||||
description = "Tin Machinery Stand",
|
||||
tiles = {
|
||||
"stm_nodes_tin2.png",
|
||||
},
|
||||
tiles = {"stm_nodes_tin2.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
node_box = {
|
||||
@ -221,15 +219,13 @@ minetest.register_node("stm_nodes:stand", {
|
||||
{-0.4375, 0.375, -0.4375, 0.4375, 0.4375, 0.4375}, -- NodeBox10
|
||||
}
|
||||
},
|
||||
groups = {cracky=1,},
|
||||
groups = {cracky = 1},
|
||||
sounds = default.node_sound_metal_defaults()
|
||||
})
|
||||
|
||||
minetest.register_node("stm_nodes:stand2", {
|
||||
description = "Copper Machinery Stand",
|
||||
tiles = {
|
||||
"stm_nodes_copper2.png",
|
||||
},
|
||||
tiles = {"stm_nodes_copper2.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
node_box = {
|
||||
@ -247,7 +243,7 @@ minetest.register_node("stm_nodes:stand2", {
|
||||
{-0.4375, 0.375, -0.4375, 0.4375, 0.4375, 0.4375}, -- NodeBox10
|
||||
}
|
||||
},
|
||||
groups = {cracky=1,},
|
||||
groups = {cracky = 1},
|
||||
sounds = default.node_sound_metal_defaults()
|
||||
})
|
||||
|
||||
@ -282,18 +278,24 @@ minetest.register_abm({
|
||||
interval = 1,
|
||||
chance = 1,
|
||||
action = function(pos, node)
|
||||
local steam_source = minetest.find_node_near(pos, 1, {"default:furnace_active2", "stm_nodes:pipe_active", "stm_nodes:reactor_active"})
|
||||
local steam_source = minetest.find_node_near(pos, 1, {
|
||||
"default:furnace_active2",
|
||||
"stm_nodes:pipe_active",
|
||||
"stm_nodes:reactor_active"
|
||||
})
|
||||
if steam_source then
|
||||
minetest.set_node(pos, {name="stm_nodes:pipe_active", param2=node.param2})
|
||||
end
|
||||
local boiler_output = minetest.find_node_near(pos, 1, {"stm_nodes:boiler_output"})
|
||||
if boiler_output and minetest.get_item_group(minetest.get_node({x=boiler_output.x, y=boiler_output.y-1, z=boiler_output.z}).name, "boiler") ~= 0 then
|
||||
local heat = minetest.find_node_near({x=boiler_output.x, y=boiler_output.y-2, z=boiler_output.z}, 1, {"stm_nodes:furnace_active", "default:furnace_active2"})
|
||||
if not boiler_output or minetest.get_item_group(minetest.get_node(vector.add(boiler_output, {x=0,y=-1,z=0})).name, "boiler") == 0 then
|
||||
return
|
||||
end
|
||||
local heat = minetest.find_node_near(vector.add(boiler_output, {x=0,y=-2,z=0}),
|
||||
1, {"stm_nodes:furnace_active", "default:furnace_active2"})
|
||||
if heat then
|
||||
minetest.set_node(pos, {name="stm_nodes:pipe_active", param2=node.param2})
|
||||
end
|
||||
end
|
||||
end
|
||||
})
|
||||
|
||||
minetest.register_abm({
|
||||
@ -310,8 +312,7 @@ minetest.register_abm({
|
||||
interval = 1,
|
||||
chance = 1,
|
||||
action = function(pos, node)
|
||||
local furnace = minetest.find_node_near(pos, 1, {"default:furnace_active2"})
|
||||
if furnace then
|
||||
if minetest.find_node_near(pos, 1, {"default:furnace_active2"}) then
|
||||
minetest.set_node(pos, {name="stm_nodes:pipe_active", param2=node.param2})
|
||||
end
|
||||
end
|
||||
@ -387,11 +388,11 @@ minetest.register_node("stm_nodes:output_tray", {
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
{-0.5, -0.5, -0.5, 0.5, -0.4375, 0.5}, -- NodeBox21
|
||||
{-0.5, -0.5, 0.4375, 0.5, -0.125, 0.5}, -- NodeBox22
|
||||
{-0.5, -0.5, -0.5, 0.5, -0.125, -0.4375}, -- NodeBox23
|
||||
{0.4375, -0.5, -0.5, 0.5, -0.125, 0.5}, -- NodeBox24
|
||||
{-0.5, -0.5, -0.5, -0.4375, -0.125, 0.5}, -- NodeBox25
|
||||
{-0.5, -0.5, -0.5, 0.5, -0.4375, 0.5}, -- NodeBox1
|
||||
{-0.5, -0.5, 0.4375, 0.5, -0.125, 0.5}, -- NodeBox2
|
||||
{-0.5, -0.5, -0.5, 0.5, -0.125, -0.4375}, -- NodeBox3
|
||||
{0.4375, -0.5, -0.5, 0.5, -0.125, 0.5}, -- NodeBox4
|
||||
{-0.5, -0.5, -0.5, -0.4375, -0.125, 0.5}, -- NodeBox5
|
||||
}
|
||||
},
|
||||
groups = {cracky=1},
|
||||
@ -404,12 +405,10 @@ minetest.register_abm({
|
||||
chance = 1,
|
||||
action = function(pos, node)
|
||||
local steam_source = minetest.find_node_near(pos, 1, {"stm_nodes:pipe_active", "default:furnace_active2"})
|
||||
|
||||
if steam_source == nil then
|
||||
local input_pos = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
if not steam_source or minetest.get_node(input_pos).name ~= "stm_nodes:hopper" then
|
||||
return
|
||||
end
|
||||
|
||||
local input_pos = {x=pos.x, y=pos.y+1, z=pos.z}
|
||||
local output_pos = minetest.find_node_near(pos, 1.5, {"stm_nodes:output_tray"})
|
||||
local n = {
|
||||
{x=pos.x+1, y=pos.y, z=pos.z},
|
||||
@ -418,23 +417,27 @@ minetest.register_abm({
|
||||
{x=pos.x, y=pos.y, z=pos.z-1},
|
||||
{x=pos.x, y=pos.y+1, z=pos.z},
|
||||
}
|
||||
local vent_pos = nil
|
||||
|
||||
local vent_pos
|
||||
for _, position in ipairs(n) do
|
||||
local item = minetest.get_node(position).name
|
||||
if minetest.get_item_group(item, "ventilation") ~= 0 then
|
||||
vent_pos = position
|
||||
break
|
||||
end
|
||||
end
|
||||
if vent_pos ~= nil then
|
||||
if minetest.get_node(input_pos).name == "stm_nodes:hopper" then
|
||||
if not vent_pos then
|
||||
return
|
||||
end
|
||||
|
||||
local objects = minetest.get_objects_inside_radius(input_pos, 0.5)
|
||||
for _, obj in ipairs(objects) do
|
||||
if obj:get_luaentity().name == "__builtin:item" then
|
||||
if not obj:is_player() and obj:get_luaentity().name == "__builtin:item" then
|
||||
local input_item = obj:get_luaentity().itemstring
|
||||
local itemname = ItemStack(input_item):get_name()
|
||||
local itemcount = ItemStack(input_item):get_count()
|
||||
if minetest.get_item_group(itemname, "cracky") ~= 0 then
|
||||
if minetest.get_item_group(itemname, "cracky") == 0 then
|
||||
return
|
||||
end
|
||||
obj:remove()
|
||||
minetest.add_particlespawner({
|
||||
amount = 4,
|
||||
@ -455,14 +458,15 @@ minetest.register_abm({
|
||||
})
|
||||
minetest.after(itemcount/2, function()
|
||||
minetest.add_item(output_pos, "default:gravel "..itemcount)
|
||||
minetest.sound_play("default_place_node_metal", {pos = pos, gain = 0.3, max_hear_distance = 16})
|
||||
minetest.sound_play("default_place_node_metal", {
|
||||
pos = pos,
|
||||
gain = 0.3,
|
||||
max_hear_distance = 16
|
||||
})
|
||||
end)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
})
|
||||
|
||||
minetest.register_node("stm_nodes:compressor_open", {
|
||||
@ -506,9 +510,13 @@ minetest.register_node("stm_nodes:compressor_open", {
|
||||
local compressor_function = function(pos)
|
||||
minetest.after(0.5, function()
|
||||
local steam_source = minetest.find_node_near(pos, 1, "stm_nodes:pipe_active")
|
||||
if steam_source ~= nil then
|
||||
if steam_source then
|
||||
minetest.set_node(pos, {name="stm_nodes:compressor_closed"})
|
||||
minetest.sound_play("default_place_node_metal", {pos = pos, gain = 0.3, max_hear_distance = 16})
|
||||
minetest.sound_play("default_place_node_metal", {
|
||||
pos = pos,
|
||||
gain = 0.3,
|
||||
max_hear_distance = 16
|
||||
})
|
||||
end
|
||||
end)
|
||||
end
|
||||
@ -525,14 +533,12 @@ local closed_compressor_function = function(pos)
|
||||
minetest.after(1, function()
|
||||
minetest.add_item(pos, "default:paper "..itemcount)
|
||||
end)
|
||||
end
|
||||
if itemname == "default:gravel" then
|
||||
elseif itemname == "default:gravel" then
|
||||
obj:remove()
|
||||
minetest.after(1, function()
|
||||
minetest.add_item(pos, "default:stone "..itemcount)
|
||||
end)
|
||||
end
|
||||
if itemname == "default:dirt" then
|
||||
elseif itemname == "default:dirt" then
|
||||
obj:remove()
|
||||
minetest.after(1, function()
|
||||
minetest.add_item(pos, "mapgen:coarse_dirt "..itemcount)
|
||||
@ -542,7 +548,11 @@ local closed_compressor_function = function(pos)
|
||||
end
|
||||
minetest.after(1, function()
|
||||
minetest.set_node(pos, {name="stm_nodes:compressor_open"})
|
||||
minetest.sound_play("default_metal_footstep", {pos = pos, gain = 0.3, max_hear_distance = 16})
|
||||
minetest.sound_play("default_metal_footstep", {
|
||||
pos = pos,
|
||||
gain = 0.3,
|
||||
max_hear_distance = 16
|
||||
})
|
||||
end)
|
||||
end
|
||||
|
||||
@ -652,7 +662,7 @@ minetest.register_node("stm_nodes:lever_closed", {
|
||||
on_rightclick = function(pos, node)
|
||||
minetest.set_node(pos, {name="stm_nodes:lever_open", param2=node.param2})
|
||||
end,
|
||||
groups = {cracky=1,},
|
||||
groups = {cracky = 1},
|
||||
sounds = default.node_sound_metal_defaults(),
|
||||
})
|
||||
|
||||
@ -691,9 +701,7 @@ minetest.register_node("stm_nodes:cable", {
|
||||
})
|
||||
|
||||
minetest.register_node("stm_nodes:cable_active", {
|
||||
tiles = {
|
||||
"stm_nodes_cable.png",
|
||||
},
|
||||
tiles = {"stm_nodes_cable.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
@ -726,9 +734,7 @@ minetest.register_node("stm_nodes:cable_active", {
|
||||
|
||||
minetest.register_node("stm_nodes:cable_ceiling", {
|
||||
description = "Ceiling Cable",
|
||||
tiles = {
|
||||
"stm_nodes_cable.png",
|
||||
},
|
||||
tiles = {"stm_nodes_cable.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
@ -865,9 +871,7 @@ minetest.register_node("stm_nodes:big_vent", {
|
||||
|
||||
minetest.register_node("stm_nodes:coal_feed", {
|
||||
description = "Coal Feeder",
|
||||
tiles = {
|
||||
"stm_nodes_block.png",
|
||||
},
|
||||
tiles = {"stm_nodes_block.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
node_box = {
|
||||
@ -943,7 +947,8 @@ minetest.register_abm({
|
||||
interval = 3,
|
||||
chance = 1,
|
||||
action = function(pos, node)
|
||||
local ventilation = minetest.find_node_near(pos, 1, {"stm_nodes:chimney", "stm_nodes:chimney2", "stm_nodes:big_vent"})
|
||||
local ventilation = minetest.find_node_near(pos, 1,
|
||||
{"stm_nodes:chimney", "stm_nodes:chimney2", "stm_nodes:big_vent"})
|
||||
local fuel = minetest.find_node_near(pos, 1, {"stm_nodes:coal_feed"})
|
||||
if ventilation and fuel and check_for_coal(fuel) then
|
||||
minetest.set_node(pos, {name="stm_nodes:furnace_active", param2=node.param2})
|
||||
@ -974,14 +979,17 @@ minetest.register_abm({
|
||||
chance = 1,
|
||||
action = function(pos, node)
|
||||
local ventilation = minetest.find_node_near(pos, 1, {"stm_nodes:chimney", "stm_nodes:chimney2", "stm_nodes:big_vent"})
|
||||
local base = minetest.find_node_near({x=pos.x, y=pos.y-1, z=pos.z}, 1, {"stm_nodes:machinery_base", "stm_nodes:stand", "stm_nodes:stand2", "default:steelblock", "default:bronzeblock"})
|
||||
local base = minetest.find_node_near({x=pos.x, y=pos.y-1, z=pos.z}, 1, {
|
||||
"stm_nodes:machinery_base", "stm_nodes:stand", "stm_nodes:stand2",
|
||||
"default:steelblock", "default:bronzeblock"
|
||||
})
|
||||
local fuel = minetest.find_node_near(pos, 1, {"stm_nodes:coal_feed"})
|
||||
if ventilation then
|
||||
minetest.add_particlespawner({
|
||||
amount = 4,
|
||||
time = 2,
|
||||
minpos = {x=ventilation.x-0.1, y=ventilation.y+0.8, z=ventilation.z-0.1},
|
||||
maxpos = {x=ventilation.x+0.1, y=ventilation.y+1, z=ventilation.z+0.1},
|
||||
minpos = vector.add(ventilation, {x=-0.1, y=0.8, z=-0.1}),
|
||||
maxpos = vector.add(ventilation, {x=0.1, y=1, z=0.1}),
|
||||
minvel = {x=-0.2, y=1, z=-0.2},
|
||||
maxvel = {x=0.2, y=3, z=0.2},
|
||||
minacc = {x=0, y=0.1, z=0},
|
||||
@ -996,7 +1004,8 @@ minetest.register_abm({
|
||||
})
|
||||
end
|
||||
if not base or not ventilation then
|
||||
tnt.boom(pos, {damage_radius=3,radius=2,ignore_protection=false, disable_playerdamage=false})
|
||||
tnt.boom(pos, {damage_radius = 3, radius = 2,
|
||||
ignore_protection = false, disable_playerdamage = false})
|
||||
end
|
||||
if not ventilation or not fuel or not check_for_coal(fuel) then
|
||||
minetest.set_node(pos, {name="stm_nodes:furnace", param2=node.param2})
|
||||
@ -1095,9 +1104,7 @@ minetest.register_node("stm_nodes:boiler_output", {
|
||||
|
||||
minetest.register_node("stm_nodes:plate", {
|
||||
description = "Metal Plate",
|
||||
tiles = {
|
||||
"stm_nodes_plate.png",
|
||||
},
|
||||
tiles = {"stm_nodes_plate.png"},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
@ -1256,16 +1263,15 @@ minetest.register_node("stm_nodes:bulb", {
|
||||
},
|
||||
sounds = default.node_sound_glass_defaults(),
|
||||
on_rightclick = function(pos, node)
|
||||
if minetest.find_node_near(pos, 1, {"stm_nodes:cable_active", "stm_nodes:cable_ceiling_active"}) ~= nil then
|
||||
if minetest.find_node_near(pos, 1,
|
||||
{"stm_nodes:cable_active", "stm_nodes:cable_ceiling_active"}) then
|
||||
minetest.set_node(pos, {name="stm_nodes:bulb_active", param2=node.param2})
|
||||
end
|
||||
end,
|
||||
})
|
||||
|
||||
minetest.register_node("stm_nodes:bulb_active", {
|
||||
tiles = {
|
||||
"stm_nodes_bulb_active.png",
|
||||
},
|
||||
tiles = {"stm_nodes_bulb_active.png"},
|
||||
drawtype = "plantlike",
|
||||
paramtype = "light",
|
||||
light_source = 8,
|
||||
@ -1312,5 +1318,5 @@ minetest.register_node("stm_nodes:conveyor", {
|
||||
{-0.5, -0.5, -0.125, 0.5, -0.25, 0.125}, -- NodeBox4
|
||||
}
|
||||
},
|
||||
groups = {cracky=1,}
|
||||
groups = {cracky=1}
|
||||
})
|
Loading…
x
Reference in New Issue
Block a user