summaryrefslogtreecommitdiff
path: root/devices.lua
diff options
context:
space:
mode:
Diffstat (limited to 'devices.lua')
-rw-r--r--devices.lua362
1 files changed, 124 insertions, 238 deletions
diff --git a/devices.lua b/devices.lua
index 5f1ce0d..513104a 100644
--- a/devices.lua
+++ b/devices.lua
@@ -18,42 +18,23 @@ pipes_devicelist = {
-- tables
-minetest.register_alias("pipeworks:pump", "pipeworks:pump_off_x")
-minetest.register_alias("pipeworks:valve", "pipeworks:valve_off_x")
-minetest.register_alias("pipeworks:storage_tank", "pipeworks:storage_tank_0_x")
-
-pipe_pumpbody_x = {
- { -6/16, -8/16, -6/16, 6/16, 8/16, 6/16 }
-}
-
-pipe_pumpbody_z = {
- { -6/16, -8/16, -6/16, 6/16, 8/16, 6/16 }
+pipe_pumpbody = {
+ { -7/16, -6/16, -7/16, 7/16, 5/16, 7/16 },
+ { -8/16, -8/16, -8/16, 8/16, -6/16, 8/16 }
}
-pipe_valvebody_x = {
+pipe_valvebody = {
{ -4/16, -4/16, -4/16, 4/16, 4/16, 4/16 }
}
-pipe_valvebody_z = {
- { -4/16, -4/16, -4/16, 4/16, 4/16, 4/16 }
-}
-
-pipe_valvehandle_on_x = {
+pipe_valvehandle_on = {
{ -5/16, 4/16, -1/16, 0, 5/16, 1/16 }
}
-pipe_valvehandle_on_z = {
- { -1/16, 4/16, -5/16, 1/16, 5/16, 0 }
-}
-
-pipe_valvehandle_off_x = {
+pipe_valvehandle_off = {
{ -1/16, 4/16, -5/16, 1/16, 5/16, 0 }
}
-pipe_valvehandle_off_z = {
- { -5/16, 4/16, -1/16, 0, 5/16, 1/16 }
-}
-
-- Now define the nodes.
local states = { "on", "off" }
@@ -68,24 +49,22 @@ for s in ipairs(states) do
end
local pumpboxes = {}
- pipe_addbox(pumpboxes, pipe_leftstub)
- pipe_addbox(pumpboxes, pipe_pumpbody_x)
- pipe_addbox(pumpboxes, pipe_rightstub)
- local tilex = "pipeworks_pump_ends.png"
- local tilez = "pipeworks_pump_"..states[s]..".png"
+ pipe_addbox(pumpboxes, pipe_pumpbody)
+ pipe_addbox(pumpboxes, pipe_topstub)
- minetest.register_node("pipeworks:pump_"..states[s].."_x", {
- description = "Pump Module ("..states[s]..")",
+ minetest.register_node("pipeworks:pump_"..states[s], {
+ description = "Pump/Intake Module",
drawtype = "nodebox",
tiles = {
- "pipeworks_pump_top_x.png",
+ "pipeworks_pump_top.png",
+ "pipeworks_pump_bottom.png",
"pipeworks_pump_sides.png",
- tilex,
- tilex,
"pipeworks_pump_sides.png",
- tilez
+ "pipeworks_pump_sides.png",
+ "pipeworks_pump_"..states[s]..".png"
},
paramtype = "light",
+ paramtype2 = "facedir",
selection_box = {
type = "fixed",
fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
@@ -99,71 +78,31 @@ for s in ipairs(states) do
walkable = true,
stack_max = 99,
after_place_node = function(pos)
- pipe_device_autorotate(pos, states[s], "pipeworks:pump")
pipe_scanforobjects(pos)
end,
after_dig_node = function(pos)
pipe_scanforobjects(pos)
end,
- drop = "pipeworks:pump_off_x"
+ drop = "pipeworks:pump_off"
})
- local pumpboxes = {}
- pipe_addbox(pumpboxes, pipe_frontstub)
- pipe_addbox(pumpboxes, pipe_pumpbody_z)
- pipe_addbox(pumpboxes, pipe_backstub)
-
- minetest.register_node("pipeworks:pump_"..states[s].."_z", {
- description = "Pump Module ("..states[s]..", Z-axis)",
- drawtype = "nodebox",
- tiles = {
- "pipeworks_pump_top_z.png",
- "pipeworks_pump_sides.png",
- tilez,
- tilez,
- "pipeworks_pump_sides.png",
- tilex
- },
- paramtype = "light",
- selection_box = {
- type = "fixed",
- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
- },
- node_box = {
- type = "fixed",
- fixed = pumpboxes
- },
- groups = {snappy=3, pipe=1, not_in_creative_inventory=1},
- sounds = default.node_sound_wood_defaults(),
- walkable = true,
- stack_max = 99,
- after_place_node = function(pos)
- pipe_device_autorotate(pos, states[s], "pipeworks:pump")
- pipe_scanforobjects(pos)
- end,
- after_dig_node = function(pos)
- pipe_scanforobjects(pos)
- end,
- drop = "pipeworks:pump_off_x"
- })
-
local valveboxes = {}
pipe_addbox(valveboxes, pipe_leftstub)
- pipe_addbox(valveboxes, pipe_valvebody_x)
+ pipe_addbox(valveboxes, pipe_valvebody)
if states[s] == "off" then
- pipe_addbox(valveboxes, pipe_valvehandle_off_x)
+ pipe_addbox(valveboxes, pipe_valvehandle_off)
else
- pipe_addbox(valveboxes, pipe_valvehandle_on_x)
+ pipe_addbox(valveboxes, pipe_valvehandle_on)
end
pipe_addbox(valveboxes, pipe_rightstub)
local tilex = "pipeworks_valvebody_ends.png"
local tilez = "pipeworks_valvebody_sides.png"
- minetest.register_node("pipeworks:valve_"..states[s].."_x", {
- description = "Valve ("..states[s]..")",
+ minetest.register_node("pipeworks:valve_"..states[s], {
+ description = "Valve",
drawtype = "nodebox",
tiles = {
- "pipeworks_valvebody_top_"..states[s].."_x.png",
+ "pipeworks_valvebody_top_"..states[s]..".png",
"pipeworks_valvebody_bottom.png",
tilex,
tilex,
@@ -171,6 +110,7 @@ for s in ipairs(states) do
tilez,
},
paramtype = "light",
+ paramtype2 = "facedir",
selection_box = {
type = "fixed",
fixed = { -8/16, -4/16, -5/16, 8/16, 5/16, 5/16 }
@@ -184,63 +124,12 @@ for s in ipairs(states) do
walkable = true,
stack_max = 99,
after_place_node = function(pos)
- pipe_device_autorotate(pos, states[s], "pipeworks:valve")
pipe_scanforobjects(pos)
end,
after_dig_node = function(pos)
pipe_scanforobjects(pos)
end,
- drop = "pipeworks:valve_off_x",
- pipelike=1,
- on_construct = function(pos)
- local meta = minetest.env:get_meta(pos)
- meta:set_int("pipelike",1)
- end,
- })
-
- local valveboxes = {}
- pipe_addbox(valveboxes, pipe_frontstub)
- pipe_addbox(valveboxes, pipe_valvebody_z)
- if states[s] == "off" then
- pipe_addbox(valveboxes, pipe_valvehandle_off_z)
- else
- pipe_addbox(valveboxes, pipe_valvehandle_on_z)
- end
- pipe_addbox(valveboxes, pipe_backstub)
-
- minetest.register_node("pipeworks:valve_"..states[s].."_z", {
- description = "Valve ("..states[s]..", Z-axis)",
- drawtype = "nodebox",
- tiles = {
- "pipeworks_valvebody_top_"..states[s].."_z.png",
- "pipeworks_valvebody_bottom.png",
- tilez,
- tilez,
- tilex,
- tilex,
- },
- paramtype = "light",
- selection_box = {
- type = "fixed",
- fixed = { -5/16, -4/16, -8/16, 5/16, 5/16, 8/16 }
- },
- node_box = {
- type = "fixed",
- fixed = valveboxes
- },
- groups = {snappy=3, pipe=1, not_in_creative_inventory=1},
- sounds = default.node_sound_wood_defaults(),
- walkable = true,
- stack_max = 99,
- after_place_node = function(pos)
- pipe_device_autorotate(pos, states[s], "pipeworks:valve")
- pipe_scanforobjects(pos)
-
- end,
- after_dig_node = function(pos)
- pipe_scanforobjects(pos)
- end,
- drop = "pipeworks:valve_off_x",
+ drop = "pipeworks:valve_off",
pipelike=1,
on_construct = function(pos)
local meta = minetest.env:get_meta(pos)
@@ -249,26 +138,17 @@ for s in ipairs(states) do
})
end
--- intake grate
+-- grating
-minetest.register_node("pipeworks:intake", {
- description = "Intake grate",
- drawtype = "nodebox",
+minetest.register_node("pipeworks:grating", {
+ description = "Decorative grating",
tiles = {
- "pipeworks_intake_top.png",
- "pipeworks_intake_sides.png",
- "pipeworks_intake_sides.png",
- "pipeworks_intake_sides.png",
- "pipeworks_intake_sides.png",
- "pipeworks_intake_sides.png"
- },
- selection_box = {
- type = "fixed",
- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
- },
- node_box = {
- type = "fixed",
- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
+ "pipeworks_grating_top.png",
+ "pipeworks_grating_sides.png",
+ "pipeworks_grating_sides.png",
+ "pipeworks_grating_sides.png",
+ "pipeworks_grating_sides.png",
+ "pipeworks_grating_sides.png"
},
paramtype = "light",
groups = {snappy=3, pipe=1},
@@ -288,28 +168,26 @@ minetest.register_node("pipeworks:intake", {
end,
})
--- outlet grate
+-- outlet spigot
+
+ local spigotboxes = {}
+ pipe_addbox(spigotboxes, pipe_leftstub)
+ pipe_addbox(spigotboxes, spigot_bottomstub)
+ pipe_addbox(spigotboxes, pipe_bendsphere)
-minetest.register_node("pipeworks:outlet", {
- description = "Outlet grate",
+minetest.register_node("pipeworks:spigot", {
+ description = "Spigot outlet",
drawtype = "nodebox",
tiles = {
- "pipeworks_outlet_top.png",
- "pipeworks_outlet_sides.png",
- "pipeworks_outlet_sides.png",
- "pipeworks_outlet_sides.png",
- "pipeworks_outlet_sides.png",
- "pipeworks_outlet_sides.png"
- },
- selection_box = {
- type = "fixed",
- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
- },
- node_box = {
- type = "fixed",
- fixed = { -0.5, -0.5, -0.5, 0.5, 0.5, 0.5 }
+ "pipeworks_spigot_sides.png",
+ "pipeworks_pipe_end_empty.png",
+ "pipeworks_spigot_sides.png",
+ "pipeworks_pipe_end_empty.png",
+ "pipeworks_spigot_sides.png",
+ "pipeworks_spigot_sides.png"
},
paramtype = "light",
+ paramtype2 = "facedir",
groups = {snappy=3, pipe=1},
sounds = default.node_sound_wood_defaults(),
walkable = true,
@@ -325,6 +203,14 @@ minetest.register_node("pipeworks:outlet", {
local meta = minetest.env:get_meta(pos)
meta:set_int("pipelike",1)
end,
+ node_box = {
+ type = "fixed",
+ fixed = spigotboxes,
+ },
+ selection_box = {
+ type = "fixed",
+ fixed = { -8/16, -6/16, -2/16, 2/16, 2/16, 2/16 }
+ }
})
-- tanks
@@ -354,7 +240,7 @@ for fill = 0, 10 do
sounds = default.node_sound_wood_defaults(),
walkable = true,
stack_max = 99,
- drop = "pipeworks:storage_tank_"..fill.."_x",
+ drop = "pipeworks:storage_tank_"..fill,
after_place_node = function(pos)
pipe_look_for_stackable_tanks(pos)
pipe_scanforobjects(pos)
@@ -369,59 +255,24 @@ for fill = 0, 10 do
end,
})
- minetest.register_node("pipeworks:storage_tank_"..fill.."_x", {
+ minetest.register_node("pipeworks:storage_tank_"..fill, {
description = "Fluid Storage Tank ("..filldesc..")",
tiles = {
"pipeworks_storage_tank_fittings.png",
"pipeworks_storage_tank_back.png",
- "pipeworks_storage_tank_fittings.png",
- "pipeworks_storage_tank_fittings.png",
"pipeworks_storage_tank_back.png",
- "pipeworks_storage_tank_front_"..fill..".png"
- },
- paramtype = "light",
- groups = sgroups,
- sounds = default.node_sound_wood_defaults(),
- walkable = true,
- stack_max = 99,
- after_place_node = function(pos)
- pipe_look_for_stackable_tanks(pos)
- if string.find(minetest.env:get_node(pos).name, "pipeworks:storage_tank_") ~= nil then
- pipe_device_autorotate(pos, nil, "pipeworks:storage_tank_"..fill)
- end
- pipe_scanforobjects(pos)
- end,
- after_dig_node = function(pos)
- pipe_scanforobjects(pos)
- end,
- pipelike=1,
- on_construct = function(pos)
- local meta = minetest.env:get_meta(pos)
- meta:set_int("pipelike",1)
- end,
- })
-
- minetest.register_node("pipeworks:storage_tank_"..fill.."_z", {
- description = "Fluid Storage Tank (Z axis, "..filldesc..")... You hacker, you.",
- tiles = {
- "pipeworks_storage_tank_fittings.png",
"pipeworks_storage_tank_back.png",
- "pipeworks_storage_tank_front_"..fill..".png",
"pipeworks_storage_tank_back.png",
- "pipeworks_storage_tank_fittings.png",
- "pipeworks_storage_tank_fittings.png"
+ "pipeworks_storage_tank_front_"..fill..".png"
},
paramtype = "light",
- groups = {snappy=3, pipe=1, tankfill=fill+1, not_in_creative_inventory=1},
+ paramtype2 = "facedir",
+ groups = sgroups,
sounds = default.node_sound_wood_defaults(),
walkable = true,
stack_max = 99,
- drop = "pipeworks:storage_tank_"..fill.."_x",
after_place_node = function(pos)
pipe_look_for_stackable_tanks(pos)
- if string.find(minetest.env:get_node(pos).name, "pipeworks:storage_tank_") ~= nil then
- pipe_device_autorotate(pos, nil, "pipeworks:storage_tank_"..fill)
- end
pipe_scanforobjects(pos)
end,
after_dig_node = function(pos)
@@ -437,35 +288,70 @@ end
-- various actions
-local axes = { "x", "z" }
-
-for a in ipairs(axes) do
- minetest.register_on_punchnode(function (pos, node)
- if node.name=="pipeworks:valve_on_"..axes[a] then
- minetest.env:add_node(pos, { name = "pipeworks:valve_off_"..axes[a] })
- local meta = minetest.env:get_meta(pos)
- meta:set_int("pipelike",0)
- end
- end)
+minetest.register_on_punchnode(function (pos, node)
+ if node.name=="pipeworks:valve_on" then
+ fdir = minetest.env:get_node(pos).param2
+ minetest.env:add_node(pos, { name = "pipeworks:valve_off", param2 = fdir })
+ local meta = minetest.env:get_meta(pos)
+ meta:set_int("pipelike",0)
+ end
+end)
- minetest.register_on_punchnode(function (pos, node)
- if node.name=="pipeworks:valve_off_"..axes[a] then
- minetest.env:add_node(pos, { name = "pipeworks:valve_on_"..axes[a] })
- local meta = minetest.env:get_meta(pos)
- meta:set_int("pipelike",1)
- end
- end)
+minetest.register_on_punchnode(function (pos, node)
+ if node.name=="pipeworks:valve_off" then
+ fdir = minetest.env:get_node(pos).param2
+ minetest.env:add_node(pos, { name = "pipeworks:valve_on", param2 = fdir })
+ local meta = minetest.env:get_meta(pos)
+ meta:set_int("pipelike",1)
+ end
+end)
- minetest.register_on_punchnode(function (pos, node)
- if node.name=="pipeworks:pump_on_"..axes[a] then
- minetest.env:add_node(pos, { name = "pipeworks:pump_off_"..axes[a] })
- end
- end)
+minetest.register_on_punchnode(function (pos, node)
+ if node.name=="pipeworks:pump_on" then
+ fdir = minetest.env:get_node(pos).param2
+ minetest.env:add_node(pos, { name = "pipeworks:pump_off", param2 = fdir })
+ end
+end)
- minetest.register_on_punchnode(function (pos, node)
- if node.name=="pipeworks:pump_off_"..axes[a] then
- minetest.env:add_node(pos, { name = "pipeworks:pump_on_"..axes[a] })
- end
- end)
-end
+minetest.register_on_punchnode(function (pos, node)
+ if node.name=="pipeworks:pump_off" then
+ fdir = minetest.env:get_node(pos).param2
+ minetest.env:add_node(pos, { name = "pipeworks:pump_on", param2 = fdir })
+ end
+end)
+
+-- backwards compatibility
+
+minetest.register_alias("pipeworks:intake", "pipeworks:grating")
+minetest.register_alias("pipeworks:outlet", "pipeworks:grating")
+minetest.register_alias("pipeworks:pump_off_x", "pipeworks:pump_off")
+minetest.register_alias("pipeworks:pump_off_z", "pipeworks:pump_off")
+minetest.register_alias("pipeworks:pump_on_x", "pipeworks:pump_on")
+minetest.register_alias("pipeworks:pump_on_z", "pipeworks:pump_on")
+minetest.register_alias("pipeworks:valve_off_x", "pipeworks:valve_off")
+minetest.register_alias("pipeworks:valve_off_z", "pipeworks:valve_off")
+minetest.register_alias("pipeworks:valve_on_x", "pipeworks:valve_on")
+minetest.register_alias("pipeworks:valve_on_z", "pipeworks:valve_on")
+minetest.register_alias("pipeworks:storage_tank_0_x", "pipeworks:storage_tank_0")
+minetest.register_alias("pipeworks:storage_tank_0_z", "pipeworks:storage_tank_0")
+minetest.register_alias("pipeworks:storage_tank_1_x", "pipeworks:storage_tank_1")
+minetest.register_alias("pipeworks:storage_tank_1_z", "pipeworks:storage_tank_1")
+minetest.register_alias("pipeworks:storage_tank_2_x", "pipeworks:storage_tank_2")
+minetest.register_alias("pipeworks:storage_tank_2_z", "pipeworks:storage_tank_2")
+minetest.register_alias("pipeworks:storage_tank_3_x", "pipeworks:storage_tank_3")
+minetest.register_alias("pipeworks:storage_tank_3_z", "pipeworks:storage_tank_3")
+minetest.register_alias("pipeworks:storage_tank_4_x", "pipeworks:storage_tank_4")
+minetest.register_alias("pipeworks:storage_tank_4_z", "pipeworks:storage_tank_4")
+minetest.register_alias("pipeworks:storage_tank_5_x", "pipeworks:storage_tank_5")
+minetest.register_alias("pipeworks:storage_tank_5_z", "pipeworks:storage_tank_5")
+minetest.register_alias("pipeworks:storage_tank_6_x", "pipeworks:storage_tank_6")
+minetest.register_alias("pipeworks:storage_tank_6_z", "pipeworks:storage_tank_6")
+minetest.register_alias("pipeworks:storage_tank_7_x", "pipeworks:storage_tank_7")
+minetest.register_alias("pipeworks:storage_tank_7_z", "pipeworks:storage_tank_7")
+minetest.register_alias("pipeworks:storage_tank_8_x", "pipeworks:storage_tank_8")
+minetest.register_alias("pipeworks:storage_tank_8_z", "pipeworks:storage_tank_8")
+minetest.register_alias("pipeworks:storage_tank_9_x", "pipeworks:storage_tank_9")
+minetest.register_alias("pipeworks:storage_tank_9_z", "pipeworks:storage_tank_9")
+minetest.register_alias("pipeworks:storage_tank_10_x", "pipeworks:storage_tank_10")
+minetest.register_alias("pipeworks:storage_tank_10_z", "pipeworks:storage_tank_10")