forked from Mirrorlandia_minetest/mesecons
Compare commits
5 Commits
master
...
piston-rot
Author | SHA1 | Date | |
---|---|---|---|
|
199fb62108 | ||
|
c7136b72cb | ||
|
774aac6e90 | ||
|
410f43bbc1 | ||
|
5e8c3584d1 |
@ -1 +1,2 @@
|
|||||||
default
|
default
|
||||||
|
screwdriver?
|
||||||
|
@ -12,3 +12,86 @@ for hash, _ in pairs(old_forceloaded_blocks) do
|
|||||||
minetest.forceload_free_block(unhash_blockpos(hash))
|
minetest.forceload_free_block(unhash_blockpos(hash))
|
||||||
end
|
end
|
||||||
os.remove(minetest.get_worldpath()..DIR_DELIM.."mesecon_forceloaded")
|
os.remove(minetest.get_worldpath()..DIR_DELIM.."mesecon_forceloaded")
|
||||||
|
|
||||||
|
-- LBMs to convert old pistons to use facedir instead of separate up/down nodes
|
||||||
|
minetest.register_lbm({
|
||||||
|
label = "Convert up pistons to use facedir",
|
||||||
|
name = ":mesecons_pistons:update_up_pistons",
|
||||||
|
nodenames = {"mesecons_pistons:piston_up_normal_on","mesecons_pistons:piston_up_normal_off",
|
||||||
|
"mesecons_pistons:piston_up_sticky_on","mesecons_pistons:piston_up_sticky_off"},
|
||||||
|
action = function(pos, node)
|
||||||
|
if string.find(node.name, "sticky") then
|
||||||
|
if string.sub(node.name, -3, -1) == "_on" then
|
||||||
|
node.name = "mesecons_pistons:piston_sticky_on"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_sticky_off"
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if string.sub(node.name, -3, -1) == "_on" then
|
||||||
|
node.name = "mesecons_pistons:piston_normal_on"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_normal_off"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local dir = {x=0, y=-1, z=0}
|
||||||
|
node.param2 = minetest.dir_to_facedir(dir, true)
|
||||||
|
minetest.swap_node(pos, node)
|
||||||
|
end
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_lbm({
|
||||||
|
label = "Convert down pistons to use facedir",
|
||||||
|
name = ":mesecons_pistons:update_down_pistons",
|
||||||
|
nodenames = {"mesecons_pistons:piston_down_normal_on","mesecons_pistons:piston_down_normal_off",
|
||||||
|
"mesecons_pistons:piston_down_sticky_on","mesecons_pistons:piston_down_sticky_off"},
|
||||||
|
action = function(pos, node)
|
||||||
|
if string.find(node.name, "sticky") then
|
||||||
|
if string.sub(node.name, -3, -1) == "_on" then
|
||||||
|
node.name = "mesecons_pistons:piston_sticky_on"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_sticky_off"
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if string.sub(node.name, -3, -1) == "_on" then
|
||||||
|
node.name = "mesecons_pistons:piston_normal_on"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_normal_off"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local dir = {x=0, y=1, z=0}
|
||||||
|
node.param2 = minetest.dir_to_facedir(dir, true)
|
||||||
|
minetest.swap_node(pos, node)
|
||||||
|
end
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_lbm({
|
||||||
|
label = "Convert up piston pushers to use facedir",
|
||||||
|
name = ":mesecons_pistons:update_up_pushers",
|
||||||
|
nodenames = {"mesecons_pistons:piston_up_pusher_normal", "mesecons_pistons:piston_up_pusher_sticky"},
|
||||||
|
action = function(pos, node)
|
||||||
|
if string.find(node.name, "sticky") then
|
||||||
|
node.name = "mesecons_pistons:piston_pusher_sticky"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_pusher_normal"
|
||||||
|
end
|
||||||
|
local dir = {x=0, y=-1, z=0}
|
||||||
|
node.param2 = minetest.dir_to_facedir(dir, true)
|
||||||
|
minetest.swap_node(pos, node)
|
||||||
|
end
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_lbm({
|
||||||
|
label = "Convert down piston pushers to use facedir",
|
||||||
|
name = ":mesecons_pistons:update_down_pushers",
|
||||||
|
nodenames = {"mesecons_pistons:piston_down_pusher_normal", "mesecons_pistons:piston_down_pusher_sticky"},
|
||||||
|
action = function(pos, node)
|
||||||
|
if string.find(node.name, "sticky") then
|
||||||
|
node.name = "mesecons_pistons:piston_pusher_sticky"
|
||||||
|
else
|
||||||
|
node.name = "mesecons_pistons:piston_pusher_normal"
|
||||||
|
end
|
||||||
|
local dir = {x=0, y=1, z=0}
|
||||||
|
node.param2 = minetest.dir_to_facedir(dir, true)
|
||||||
|
minetest.swap_node(pos, node)
|
||||||
|
end
|
||||||
|
})
|
||||||
|
@ -93,3 +93,11 @@ mesecon.queue:add_function("cooldown", function (pos)
|
|||||||
meta:set_int("heat", heat - 1)
|
meta:set_int("heat", heat - 1)
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
-- "Shim" for simple rotation, will result in the following item in nodedefs using it:
|
||||||
|
-- "on_rotate = screwdriver.rotate_simple" if screwdriver mod is installed
|
||||||
|
-- "on_rotate = nil" (essentially not present) if screwdriver mod is missing
|
||||||
|
|
||||||
|
if screwdriver then
|
||||||
|
mesecon.rotate_simple = screwdriver.rotate_simple
|
||||||
|
end
|
||||||
|
@ -37,6 +37,7 @@ minetest.register_node("mesecons_extrawires:corner_on", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = corner_selectionbox,
|
selection_box = corner_selectionbox,
|
||||||
node_box = corner_nodebox,
|
node_box = corner_nodebox,
|
||||||
|
on_rotate = mesecon.rotate_simple,
|
||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
drop = "mesecons_extrawires:corner_off",
|
drop = "mesecons_extrawires:corner_off",
|
||||||
mesecons = {conductor =
|
mesecons = {conductor =
|
||||||
@ -64,6 +65,7 @@ minetest.register_node("mesecons_extrawires:corner_off", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = corner_selectionbox,
|
selection_box = corner_selectionbox,
|
||||||
node_box = corner_nodebox,
|
node_box = corner_nodebox,
|
||||||
|
on_rotate = mesecon.rotate_simple,
|
||||||
groups = {dig_immediate = 3},
|
groups = {dig_immediate = 3},
|
||||||
mesecons = {conductor =
|
mesecons = {conductor =
|
||||||
{
|
{
|
||||||
|
@ -38,6 +38,7 @@ minetest.register_node("mesecons_extrawires:tjunction_on", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = tjunction_selectionbox,
|
selection_box = tjunction_selectionbox,
|
||||||
node_box = tjunction_nodebox,
|
node_box = tjunction_nodebox,
|
||||||
|
on_rotate = mesecon.rotate_simple,
|
||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
drop = "mesecons_extrawires:tjunction_off",
|
drop = "mesecons_extrawires:tjunction_off",
|
||||||
mesecons = {conductor =
|
mesecons = {conductor =
|
||||||
@ -65,6 +66,7 @@ minetest.register_node("mesecons_extrawires:tjunction_off", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = tjunction_selectionbox,
|
selection_box = tjunction_selectionbox,
|
||||||
node_box = tjunction_nodebox,
|
node_box = tjunction_nodebox,
|
||||||
|
on_rotate = mesecon.rotate_simple,
|
||||||
groups = {dig_immediate = 3},
|
groups = {dig_immediate = 3},
|
||||||
mesecons = {conductor =
|
mesecons = {conductor =
|
||||||
{
|
{
|
||||||
|
@ -84,6 +84,7 @@ mesecon.register_node("mesecons_extrawires:vertical", {
|
|||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
selection_box = vertical_box,
|
selection_box = vertical_box,
|
||||||
node_box = vertical_box,
|
node_box = vertical_box,
|
||||||
|
on_rotate = false,
|
||||||
is_vertical_conductor = true,
|
is_vertical_conductor = true,
|
||||||
drop = "mesecons_extrawires:vertical_off",
|
drop = "mesecons_extrawires:vertical_off",
|
||||||
after_place_node = vertical_update,
|
after_place_node = vertical_update,
|
||||||
@ -116,6 +117,7 @@ mesecon.register_node("mesecons_extrawires:vertical_top", {
|
|||||||
groups = {dig_immediate=3, not_in_creative_inventory=1},
|
groups = {dig_immediate=3, not_in_creative_inventory=1},
|
||||||
selection_box = top_box,
|
selection_box = top_box,
|
||||||
node_box = top_box,
|
node_box = top_box,
|
||||||
|
on_rotate = false,
|
||||||
is_vertical_conductor = true,
|
is_vertical_conductor = true,
|
||||||
drop = "mesecons_extrawires:vertical_off",
|
drop = "mesecons_extrawires:vertical_off",
|
||||||
after_place_node = vertical_update,
|
after_place_node = vertical_update,
|
||||||
@ -146,6 +148,7 @@ mesecon.register_node("mesecons_extrawires:vertical_bottom", {
|
|||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
selection_box = bottom_box,
|
selection_box = bottom_box,
|
||||||
node_box = bottom_box,
|
node_box = bottom_box,
|
||||||
|
on_rotate = false,
|
||||||
is_vertical_conductor = true,
|
is_vertical_conductor = true,
|
||||||
drop = "mesecons_extrawires:vertical_off",
|
drop = "mesecons_extrawires:vertical_off",
|
||||||
after_place_node = vertical_update,
|
after_place_node = vertical_update,
|
||||||
|
@ -30,6 +30,7 @@ minetest.register_node("mesecons_insulated:insulated_on", {
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = { -16/32-0.001, -17/32, -3/32, 16/32+0.001, -13/32, 3/32 }
|
fixed = { -16/32-0.001, -17/32, -3/32, 16/32+0.001, -13/32, 3/32 }
|
||||||
},
|
},
|
||||||
|
on_rotate = mesecon.rotate_simple,
|
||||||
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
groups = {dig_immediate = 3, not_in_creative_inventory = 1},
|
||||||
drop = "mesecons_insulated:insulated_off",
|
drop = "mesecons_insulated:insulated_off",
|
||||||
mesecons = {conductor = {
|
mesecons = {conductor = {
|
||||||
@ -62,6 +63,7 @@ minetest.register_node("mesecons_insulated:insulated_off", {
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = { -16/32-0.001, -17/32, -3/32, 16/32+0.001, -13/32, 3/32 }
|
fixed = { -16/32-0.001, -17/32, -3/32, 16/32+0.001, -13/32, 3/32 }
|
||||||
},
|
},
|
||||||
|
on_rotate = screwdriver.rotate_simple,
|
||||||
groups = {dig_immediate = 3},
|
groups = {dig_immediate = 3},
|
||||||
mesecons = {conductor = {
|
mesecons = {conductor = {
|
||||||
state = mesecon.state.off,
|
state = mesecon.state.off,
|
||||||
|
@ -1,44 +1,24 @@
|
|||||||
-- Get mesecon rules of pistons
|
local piston_get_rules = function (node)
|
||||||
local piston_rules = {
|
local all_rules ={
|
||||||
{x=0, y=0, z=1}, --everything apart from z- (pusher side)
|
{x=0, y=0, z=1},
|
||||||
{x=1, y=0, z=0},
|
{x=0, y=0, z=-1},
|
||||||
{x=-1, y=0, z=0},
|
{x=1, y=0, z=0},
|
||||||
{x=1, y=1, z=0},
|
{x=-1, y=0, z=0},
|
||||||
{x=1, y=-1, z=0},
|
{x=1, y=1, z=0},
|
||||||
{x=-1, y=1, z=0},
|
{x=1, y=-1, z=0},
|
||||||
{x=-1, y=-1, z=0},
|
{x=-1, y=1, z=0},
|
||||||
{x=0, y=1, z=1},
|
{x=-1, y=-1, z=0},
|
||||||
{x=0, y=-1, z=1}
|
{x=0, y=1, z=1},
|
||||||
}
|
{x=0, y=-1, z=1},
|
||||||
|
{x=0, y=1, z=-1},
|
||||||
local piston_up_rules = {
|
{x=0, y=-1, z=-1}}
|
||||||
{x=0, y=0, z=-1}, --everything apart from y+ (pusher side)
|
local pusher_dir = vector.multiply(minetest.facedir_to_dir(node.param2), -1)
|
||||||
{x=1, y=0, z=0},
|
for k,v in ipairs(all_rules) do
|
||||||
{x=-1, y=0, z=0},
|
if vector.equals(v, pusher_dir) then
|
||||||
{x=0, y=0, z=1},
|
table.remove(all_rules, k)
|
||||||
{x=1, y=-1, z=0},
|
end
|
||||||
{x=-1, y=-1, z=0},
|
|
||||||
{x=0, y=-1, z=1},
|
|
||||||
{x=0, y=-1, z=-1}
|
|
||||||
}
|
|
||||||
|
|
||||||
local piston_down_rules = {
|
|
||||||
{x=0, y=0, z=-1}, --everything apart from y- (pusher side)
|
|
||||||
{x=1, y=0, z=0},
|
|
||||||
{x=-1, y=0, z=0},
|
|
||||||
{x=0, y=0, z=1},
|
|
||||||
{x=1, y=1, z=0},
|
|
||||||
{x=-1, y=1, z=0},
|
|
||||||
{x=0, y=1, z=1},
|
|
||||||
{x=0, y=1, z=-1}
|
|
||||||
}
|
|
||||||
|
|
||||||
local function piston_get_rules(node)
|
|
||||||
local rules = piston_rules
|
|
||||||
for i = 1, node.param2 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
end
|
||||||
return rules
|
return all_rules
|
||||||
end
|
end
|
||||||
|
|
||||||
local function piston_facedir_direction(node)
|
local function piston_facedir_direction(node)
|
||||||
@ -49,17 +29,9 @@ local function piston_facedir_direction(node)
|
|||||||
return rules[1]
|
return rules[1]
|
||||||
end
|
end
|
||||||
|
|
||||||
local function piston_get_direction(dir, node)
|
|
||||||
if type(dir) == "function" then
|
|
||||||
return dir(node)
|
|
||||||
else
|
|
||||||
return dir
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local piston_remove_pusher = function(pos, node)
|
local piston_remove_pusher = function(pos, node)
|
||||||
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
||||||
local dir = piston_get_direction(pistonspec.dir, node)
|
local dir = vector.multiply(minetest.facedir_to_dir(node.param2), -1)
|
||||||
local pusherpos = vector.add(pos, dir)
|
local pusherpos = vector.add(pos, dir)
|
||||||
local pushername = minetest.get_node(pusherpos).name
|
local pushername = minetest.get_node(pusherpos).name
|
||||||
|
|
||||||
@ -79,8 +51,7 @@ end
|
|||||||
|
|
||||||
local piston_on = function(pos, node)
|
local piston_on = function(pos, node)
|
||||||
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
||||||
|
local dir = vector.multiply(minetest.facedir_to_dir(node.param2), -1)
|
||||||
local dir = piston_get_direction(pistonspec.dir, node)
|
|
||||||
local np = vector.add(pos, dir)
|
local np = vector.add(pos, dir)
|
||||||
local maxpush = mesecon.setting("piston_max_push", 15)
|
local maxpush = mesecon.setting("piston_max_push", 15)
|
||||||
local success, stack, oldstack = mesecon.mvps_push(np, dir, maxpush)
|
local success, stack, oldstack = mesecon.mvps_push(np, dir, maxpush)
|
||||||
@ -101,41 +72,22 @@ local piston_off = function(pos, node)
|
|||||||
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
||||||
minetest.set_node(pos, {param2 = node.param2, name = pistonspec.offname})
|
minetest.set_node(pos, {param2 = node.param2, name = pistonspec.offname})
|
||||||
piston_remove_pusher(pos, node)
|
piston_remove_pusher(pos, node)
|
||||||
|
|
||||||
if pistonspec.sticky then
|
if pistonspec.sticky then
|
||||||
local maxpull = mesecon.setting("piston_max_pull", 15)
|
local maxpull = mesecon.setting("piston_max_pull", 15)
|
||||||
local dir = piston_get_direction(pistonspec.dir, node)
|
local dir = vector.multiply(minetest.facedir_to_dir(node.param2), -1)
|
||||||
local pullpos = vector.add(pos, vector.multiply(dir, 2))
|
local pullpos = vector.add(pos, vector.multiply(dir, 2))
|
||||||
local stack = mesecon.mvps_pull_single(pullpos, vector.multiply(dir, -1), maxpull)
|
local stack = mesecon.mvps_pull_single(pullpos, vector.multiply(dir, -1), maxpull)
|
||||||
mesecon.mvps_process_stack(pos, dir, stack)
|
mesecon.mvps_process_stack(pos, dir, stack)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local piston_orientate = function(pos, placer)
|
local piston_onrotate = function(pos, node, _, _, newparam2)
|
||||||
-- not placed by player
|
local node_copy = minetest.get_node(pos)
|
||||||
if not placer then return end
|
minetest.after(0, mesecon.on_dignode, pos, node)
|
||||||
|
node_copy.param2 = newparam2
|
||||||
-- placer pitch in degrees
|
minetest.after(0, mesecon.on_placenode, pos, node_copy)
|
||||||
local pitch = placer:get_look_pitch() * (180 / math.pi)
|
|
||||||
|
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
|
||||||
|
|
||||||
-- looking upwards (pitch > 55) / looking downwards (pitch < -55)
|
|
||||||
local nn = nil
|
|
||||||
if pitch > 55 then nn = {name = pistonspec.piston_down} end
|
|
||||||
if pitch < -55 then nn = {name = pistonspec.piston_up} end
|
|
||||||
|
|
||||||
if nn then
|
|
||||||
minetest.set_node(pos, nn)
|
|
||||||
-- minetest.after, because on_placenode for unoriented piston must be processed first
|
|
||||||
minetest.after(0, mesecon.on_placenode, pos, nn)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Horizontal pistons
|
|
||||||
|
|
||||||
local pt = 3/16 -- pusher thickness
|
local pt = 3/16 -- pusher thickness
|
||||||
|
|
||||||
local piston_pusher_box = {
|
local piston_pusher_box = {
|
||||||
@ -161,8 +113,6 @@ local pistonspec_normal = {
|
|||||||
onname = "mesecons_pistons:piston_normal_on",
|
onname = "mesecons_pistons:piston_normal_on",
|
||||||
dir = piston_facedir_direction,
|
dir = piston_facedir_direction,
|
||||||
pusher = "mesecons_pistons:piston_pusher_normal",
|
pusher = "mesecons_pistons:piston_pusher_normal",
|
||||||
piston_down = "mesecons_pistons:piston_down_normal_off",
|
|
||||||
piston_up = "mesecons_pistons:piston_up_normal_off",
|
|
||||||
}
|
}
|
||||||
|
|
||||||
-- offstate
|
-- offstate
|
||||||
@ -178,8 +128,8 @@ minetest.register_node("mesecons_pistons:piston_normal_off", {
|
|||||||
},
|
},
|
||||||
groups = {cracky = 3},
|
groups = {cracky = 3},
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
after_place_node = piston_orientate,
|
|
||||||
mesecons_piston = pistonspec_normal,
|
mesecons_piston = pistonspec_normal,
|
||||||
|
on_rotate = piston_onrotate,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
mesecons = {effector={
|
mesecons = {effector={
|
||||||
action_on = piston_on,
|
action_on = piston_on,
|
||||||
@ -208,6 +158,7 @@ minetest.register_node("mesecons_pistons:piston_normal_on", {
|
|||||||
node_box = piston_on_box,
|
node_box = piston_on_box,
|
||||||
selection_box = piston_on_box,
|
selection_box = piston_on_box,
|
||||||
mesecons_piston = pistonspec_normal,
|
mesecons_piston = pistonspec_normal,
|
||||||
|
on_rotate = false,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
mesecons = {effector={
|
mesecons = {effector={
|
||||||
action_off = piston_off,
|
action_off = piston_off,
|
||||||
@ -229,6 +180,7 @@ minetest.register_node("mesecons_pistons:piston_pusher_normal", {
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
diggable = false,
|
diggable = false,
|
||||||
|
on_rotate = false,
|
||||||
corresponding_piston = "mesecons_pistons:piston_normal_on",
|
corresponding_piston = "mesecons_pistons:piston_normal_on",
|
||||||
selection_box = piston_pusher_box,
|
selection_box = piston_pusher_box,
|
||||||
node_box = piston_pusher_box,
|
node_box = piston_pusher_box,
|
||||||
@ -242,8 +194,6 @@ local pistonspec_sticky = {
|
|||||||
dir = piston_facedir_direction,
|
dir = piston_facedir_direction,
|
||||||
pusher = "mesecons_pistons:piston_pusher_sticky",
|
pusher = "mesecons_pistons:piston_pusher_sticky",
|
||||||
sticky = true,
|
sticky = true,
|
||||||
piston_down = "mesecons_pistons:piston_down_sticky_off",
|
|
||||||
piston_up = "mesecons_pistons:piston_up_sticky_off",
|
|
||||||
}
|
}
|
||||||
|
|
||||||
-- offstate
|
-- offstate
|
||||||
@ -259,7 +209,7 @@ minetest.register_node("mesecons_pistons:piston_sticky_off", {
|
|||||||
},
|
},
|
||||||
groups = {cracky = 3},
|
groups = {cracky = 3},
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
after_place_node = piston_orientate,
|
on_rotate = piston_onrotate,
|
||||||
mesecons_piston = pistonspec_sticky,
|
mesecons_piston = pistonspec_sticky,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
mesecons = {effector={
|
mesecons = {effector={
|
||||||
@ -289,6 +239,7 @@ minetest.register_node("mesecons_pistons:piston_sticky_on", {
|
|||||||
node_box = piston_on_box,
|
node_box = piston_on_box,
|
||||||
selection_box = piston_on_box,
|
selection_box = piston_on_box,
|
||||||
mesecons_piston = pistonspec_sticky,
|
mesecons_piston = pistonspec_sticky,
|
||||||
|
on_rotate = false,
|
||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
mesecons = {effector={
|
mesecons = {effector={
|
||||||
action_off = piston_off,
|
action_off = piston_off,
|
||||||
@ -310,377 +261,12 @@ minetest.register_node("mesecons_pistons:piston_pusher_sticky", {
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
diggable = false,
|
diggable = false,
|
||||||
|
on_rotate = false,
|
||||||
corresponding_piston = "mesecons_pistons:piston_sticky_on",
|
corresponding_piston = "mesecons_pistons:piston_sticky_on",
|
||||||
selection_box = piston_pusher_box,
|
selection_box = piston_pusher_box,
|
||||||
node_box = piston_pusher_box,
|
node_box = piston_pusher_box,
|
||||||
})
|
})
|
||||||
|
|
||||||
--
|
|
||||||
--
|
|
||||||
-- UP
|
|
||||||
--
|
|
||||||
--
|
|
||||||
|
|
||||||
local piston_up_pusher_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-2/16, -.5 - pt, -2/16, 2/16, .5 - pt, 2/16},
|
|
||||||
{-.5 , .5 - pt, -.5 , .5 , .5 , .5},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
local piston_up_on_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-.5, -.5, -.5 , .5, .5-pt, .5}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
-- Normal
|
|
||||||
|
|
||||||
local pistonspec_normal_up = {
|
|
||||||
offname = "mesecons_pistons:piston_up_normal_off",
|
|
||||||
onname = "mesecons_pistons:piston_up_normal_on",
|
|
||||||
dir = {x = 0, y = 1, z = 0},
|
|
||||||
pusher = "mesecons_pistons:piston_up_pusher_normal"
|
|
||||||
}
|
|
||||||
|
|
||||||
-- offstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_normal_off", {
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_front.png",
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_left.png^[transformR270",
|
|
||||||
"mesecons_piston_right.png^[transformR90",
|
|
||||||
"mesecons_piston_bottom.png",
|
|
||||||
"mesecons_piston_top.png^[transformR180",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_normal_off",
|
|
||||||
mesecons_piston = pistonspec_normal_up,
|
|
||||||
mesecons = {effector={
|
|
||||||
action_on = piston_on,
|
|
||||||
rules = piston_up_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- onstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_normal_on", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_on_front.png",
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_left.png^[transformR270",
|
|
||||||
"mesecons_piston_right.png^[transformR90",
|
|
||||||
"mesecons_piston_bottom.png",
|
|
||||||
"mesecons_piston_top.png^[transformR180",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_normal_off",
|
|
||||||
after_dig_node = piston_remove_pusher,
|
|
||||||
node_box = piston_up_on_box,
|
|
||||||
selection_box = piston_up_on_box,
|
|
||||||
mesecons_piston = pistonspec_normal_up,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_off = piston_off,
|
|
||||||
rules = piston_up_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- pusher
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_pusher_normal", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_front.png",
|
|
||||||
"mesecons_piston_pusher_back.png",
|
|
||||||
"mesecons_piston_pusher_left.png^[transformR270",
|
|
||||||
"mesecons_piston_pusher_right.png^[transformR90",
|
|
||||||
"mesecons_piston_pusher_bottom.png",
|
|
||||||
"mesecons_piston_pusher_top.png^[transformR180",
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
diggable = false,
|
|
||||||
corresponding_piston = "mesecons_pistons:piston_up_normal_on",
|
|
||||||
selection_box = piston_up_pusher_box,
|
|
||||||
node_box = piston_up_pusher_box,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Sticky
|
|
||||||
|
|
||||||
|
|
||||||
local pistonspec_sticky_up = {
|
|
||||||
offname = "mesecons_pistons:piston_up_sticky_off",
|
|
||||||
onname = "mesecons_pistons:piston_up_sticky_on",
|
|
||||||
dir = {x = 0, y = 1, z = 0},
|
|
||||||
pusher = "mesecons_pistons:piston_up_pusher_sticky",
|
|
||||||
sticky = true
|
|
||||||
}
|
|
||||||
|
|
||||||
-- offstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_sticky_off", {
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_front_sticky.png",
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_left.png^[transformR270",
|
|
||||||
"mesecons_piston_right.png^[transformR90",
|
|
||||||
"mesecons_piston_bottom.png",
|
|
||||||
"mesecons_piston_top.png^[transformR180",
|
|
||||||
"mesecons_piston_tb.png"
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_sticky_off",
|
|
||||||
mesecons_piston = pistonspec_sticky_up,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_on = piston_on,
|
|
||||||
rules = piston_up_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- onstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_sticky_on", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_on_front.png",
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_left.png^[transformR270",
|
|
||||||
"mesecons_piston_right.png^[transformR90",
|
|
||||||
"mesecons_piston_bottom.png",
|
|
||||||
"mesecons_piston_top.png^[transformR180",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_normal_off",
|
|
||||||
after_dig_node = piston_remove_pusher,
|
|
||||||
node_box = piston_up_on_box,
|
|
||||||
selection_box = piston_up_on_box,
|
|
||||||
mesecons_piston = pistonspec_sticky_up,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_off = piston_off,
|
|
||||||
rules = piston_up_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- pusher
|
|
||||||
minetest.register_node("mesecons_pistons:piston_up_pusher_sticky", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_front_sticky.png",
|
|
||||||
"mesecons_piston_pusher_back.png",
|
|
||||||
"mesecons_piston_pusher_left.png^[transformR270",
|
|
||||||
"mesecons_piston_pusher_right.png^[transformR90",
|
|
||||||
"mesecons_piston_pusher_bottom.png",
|
|
||||||
"mesecons_piston_pusher_top.png^[transformR180",
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
diggable = false,
|
|
||||||
corresponding_piston = "mesecons_pistons:piston_up_sticky_on",
|
|
||||||
selection_box = piston_up_pusher_box,
|
|
||||||
node_box = piston_up_pusher_box,
|
|
||||||
})
|
|
||||||
|
|
||||||
--
|
|
||||||
--
|
|
||||||
-- DOWN
|
|
||||||
--
|
|
||||||
--
|
|
||||||
|
|
||||||
local piston_down_pusher_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-2/16, -.5 + pt, -2/16, 2/16, .5 + pt, 2/16},
|
|
||||||
{-.5 , -.5 , -.5 , .5 , -.5 + pt, .5},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
local piston_down_on_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-.5, -.5+pt, -.5 , .5, .5, .5}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- Normal
|
|
||||||
|
|
||||||
local pistonspec_normal_down = {
|
|
||||||
offname = "mesecons_pistons:piston_down_normal_off",
|
|
||||||
onname = "mesecons_pistons:piston_down_normal_on",
|
|
||||||
dir = {x = 0, y = -1, z = 0},
|
|
||||||
pusher = "mesecons_pistons:piston_down_pusher_normal",
|
|
||||||
}
|
|
||||||
|
|
||||||
-- offstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_normal_off", {
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_pusher_front.png",
|
|
||||||
"mesecons_piston_left.png^[transformR90",
|
|
||||||
"mesecons_piston_right.png^[transformR270",
|
|
||||||
"mesecons_piston_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_top.png",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_normal_off",
|
|
||||||
mesecons_piston = pistonspec_normal_down,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_on = piston_on,
|
|
||||||
rules = piston_down_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- onstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_normal_on", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_on_front.png",
|
|
||||||
"mesecons_piston_left.png^[transformR90",
|
|
||||||
"mesecons_piston_right.png^[transformR270",
|
|
||||||
"mesecons_piston_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_top.png",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_normal_off",
|
|
||||||
after_dig_node = piston_remove_pusher,
|
|
||||||
node_box = piston_down_on_box,
|
|
||||||
selection_box = piston_down_on_box,
|
|
||||||
mesecons_piston = pistonspec_normal_down,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_off = piston_off,
|
|
||||||
rules = piston_down_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- pusher
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_pusher_normal", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_back.png",
|
|
||||||
"mesecons_piston_pusher_front.png",
|
|
||||||
"mesecons_piston_pusher_left.png^[transformR90",
|
|
||||||
"mesecons_piston_pusher_right.png^[transformR270",
|
|
||||||
"mesecons_piston_pusher_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_pusher_top.png",
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
diggable = false,
|
|
||||||
corresponding_piston = "mesecons_pistons:piston_down_normal_on",
|
|
||||||
selection_box = piston_down_pusher_box,
|
|
||||||
node_box = piston_down_pusher_box,
|
|
||||||
})
|
|
||||||
|
|
||||||
-- Sticky
|
|
||||||
|
|
||||||
local pistonspec_sticky_down = {
|
|
||||||
onname = "mesecons_pistons:piston_down_sticky_on",
|
|
||||||
offname = "mesecons_pistons:piston_down_sticky_off",
|
|
||||||
dir = {x = 0, y = -1, z = 0},
|
|
||||||
pusher = "mesecons_pistons:piston_down_pusher_sticky",
|
|
||||||
sticky = true
|
|
||||||
}
|
|
||||||
|
|
||||||
-- offstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_sticky_off", {
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_pusher_front_sticky.png",
|
|
||||||
"mesecons_piston_left.png^[transformR90",
|
|
||||||
"mesecons_piston_right.png^[transformR270",
|
|
||||||
"mesecons_piston_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_top.png",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_sticky_off",
|
|
||||||
mesecons_piston = pistonspec_sticky_down,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_on = piston_on,
|
|
||||||
rules = piston_down_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- onstate
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_sticky_on", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_back.png",
|
|
||||||
"mesecons_piston_on_front.png",
|
|
||||||
"mesecons_piston_left.png^[transformR90",
|
|
||||||
"mesecons_piston_right.png^[transformR270",
|
|
||||||
"mesecons_piston_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_top.png",
|
|
||||||
},
|
|
||||||
inventory_image = "mesecons_piston_top.png",
|
|
||||||
wield_image = "mesecons_piston_top.png",
|
|
||||||
groups = {cracky = 3, not_in_creative_inventory = 1},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
drop = "mesecons_pistons:piston_sticky_off",
|
|
||||||
after_dig_node = piston_remove_pusher,
|
|
||||||
node_box = piston_down_on_box,
|
|
||||||
selection_box = piston_down_on_box,
|
|
||||||
mesecons_piston = pistonspec_sticky_down,
|
|
||||||
sounds = default.node_sound_wood_defaults(),
|
|
||||||
mesecons = {effector={
|
|
||||||
action_off = piston_off,
|
|
||||||
rules = piston_down_rules,
|
|
||||||
}}
|
|
||||||
})
|
|
||||||
|
|
||||||
-- pusher
|
|
||||||
minetest.register_node("mesecons_pistons:piston_down_pusher_sticky", {
|
|
||||||
drawtype = "nodebox",
|
|
||||||
tiles = {
|
|
||||||
"mesecons_piston_pusher_back.png",
|
|
||||||
"mesecons_piston_pusher_front_sticky.png",
|
|
||||||
"mesecons_piston_pusher_left.png^[transformR90",
|
|
||||||
"mesecons_piston_pusher_right.png^[transformR270",
|
|
||||||
"mesecons_piston_pusher_bottom.png^[transformR180",
|
|
||||||
"mesecons_piston_pusher_top.png",
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
diggable = false,
|
|
||||||
corresponding_piston = "mesecons_pistons:piston_down_sticky_on",
|
|
||||||
selection_box = piston_down_pusher_box,
|
|
||||||
node_box = piston_down_pusher_box,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
-- Register pushers as stoppers if they would be seperated from the piston
|
-- Register pushers as stoppers if they would be seperated from the piston
|
||||||
local piston_pusher_get_stopper = function (node, dir, stack, stackid)
|
local piston_pusher_get_stopper = function (node, dir, stack, stackid)
|
||||||
if (stack[stackid + 1]
|
if (stack[stackid + 1]
|
||||||
@ -707,13 +293,6 @@ end
|
|||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_pusher_normal", piston_pusher_get_stopper)
|
mesecon.register_mvps_stopper("mesecons_pistons:piston_pusher_normal", piston_pusher_get_stopper)
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_pusher_sticky", piston_pusher_get_stopper)
|
mesecon.register_mvps_stopper("mesecons_pistons:piston_pusher_sticky", piston_pusher_get_stopper)
|
||||||
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_up_pusher_normal", piston_pusher_up_down_get_stopper)
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_up_pusher_sticky", piston_pusher_up_down_get_stopper)
|
|
||||||
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_down_pusher_normal", piston_pusher_up_down_get_stopper)
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_down_pusher_sticky", piston_pusher_up_down_get_stopper)
|
|
||||||
|
|
||||||
|
|
||||||
-- Register pistons as stoppers if they would be seperated from the stopper
|
-- Register pistons as stoppers if they would be seperated from the stopper
|
||||||
local piston_up_down_get_stopper = function (node, dir, stack, stackid)
|
local piston_up_down_get_stopper = function (node, dir, stack, stackid)
|
||||||
if (stack[stackid + 1]
|
if (stack[stackid + 1]
|
||||||
@ -726,8 +305,8 @@ local piston_up_down_get_stopper = function (node, dir, stack, stackid)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local piston_get_stopper = function (node, dir, stack, stackid)
|
local piston_get_stopper = function (node, dir, stack, stackid)
|
||||||
pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
local pistonspec = minetest.registered_nodes[node.name].mesecons_piston
|
||||||
dir = piston_get_direction(pistonspec.dir, node)
|
local dir = pistonspec.dir(node)
|
||||||
local pusherpos = vector.add(stack[stackid].pos, dir)
|
local pusherpos = vector.add(stack[stackid].pos, dir)
|
||||||
local pushernode = minetest.get_node(pusherpos)
|
local pushernode = minetest.get_node(pusherpos)
|
||||||
|
|
||||||
@ -745,12 +324,6 @@ end
|
|||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_normal_on", piston_get_stopper)
|
mesecon.register_mvps_stopper("mesecons_pistons:piston_normal_on", piston_get_stopper)
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_sticky_on", piston_get_stopper)
|
mesecon.register_mvps_stopper("mesecons_pistons:piston_sticky_on", piston_get_stopper)
|
||||||
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_up_normal_on", piston_up_down_get_stopper)
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_up_sticky_on", piston_up_down_get_stopper)
|
|
||||||
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_down_normal_on", piston_up_down_get_stopper)
|
|
||||||
mesecon.register_mvps_stopper("mesecons_pistons:piston_down_sticky_on", piston_up_down_get_stopper)
|
|
||||||
|
|
||||||
--craft recipes
|
--craft recipes
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "mesecons_pistons:piston_normal_off 2",
|
output = "mesecons_pistons:piston_normal_off 2",
|
||||||
@ -768,3 +341,4 @@ minetest.register_craft({
|
|||||||
{"mesecons_pistons:piston_normal_off"},
|
{"mesecons_pistons:piston_normal_off"},
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -200,7 +200,6 @@ local function register_wires()
|
|||||||
if nodeid ~= "00000000" then
|
if nodeid ~= "00000000" then
|
||||||
groups_off["not_in_creative_inventory"] = 1
|
groups_off["not_in_creative_inventory"] = 1
|
||||||
end
|
end
|
||||||
|
|
||||||
mesecon.register_node(":mesecons:wire_"..nodeid, {
|
mesecon.register_node(":mesecons:wire_"..nodeid, {
|
||||||
description = "Mesecon",
|
description = "Mesecon",
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
@ -212,6 +211,7 @@ local function register_wires()
|
|||||||
selection_box = selectionbox,
|
selection_box = selectionbox,
|
||||||
node_box = nodebox,
|
node_box = nodebox,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
on_rotate = false,
|
||||||
drop = "mesecons:wire_00000000_off",
|
drop = "mesecons:wire_00000000_off",
|
||||||
mesecon_wire = true
|
mesecon_wire = true
|
||||||
}, {tiles = tiles_off, mesecons = meseconspec_off, groups = groups_off},
|
}, {tiles = tiles_off, mesecons = meseconspec_off, groups = groups_off},
|
||||||
|
Loading…
Reference in New Issue
Block a user