forked from minetest-mods/mesecons
Consolidate horizontal rules getters (#602)
This commit is contained in:
parent
58305f52bc
commit
0a4a88b1b9
@ -72,7 +72,28 @@ function mesecon.rotate_rules_up(rules)
|
|||||||
end
|
end
|
||||||
return nr
|
return nr
|
||||||
end
|
end
|
||||||
--
|
|
||||||
|
-- Returns a rules getter function that returns different rules depending on the node's horizontal rotation.
|
||||||
|
-- If param2 % 4 == 0, then the rules returned by the getter are a copy of base_rules.
|
||||||
|
function mesecon.horiz_rules_getter(base_rules)
|
||||||
|
local rotations = {mesecon.tablecopy(base_rules)}
|
||||||
|
for i = 2, 4 do
|
||||||
|
local right_rules = rotations[i - 1]
|
||||||
|
if not right_rules[1] or right_rules[1].x then
|
||||||
|
-- flat rules
|
||||||
|
rotations[i] = mesecon.rotate_rules_left(right_rules)
|
||||||
|
else
|
||||||
|
-- not flat
|
||||||
|
rotations[i] = {}
|
||||||
|
for j, rules in ipairs(right_rules) do
|
||||||
|
rotations[i][j] = mesecon.rotate_rules_left(rules)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return function(node)
|
||||||
|
return rotations[node.param2 % 4 + 1]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function mesecon.flattenrules(allrules)
|
function mesecon.flattenrules(allrules)
|
||||||
--[[
|
--[[
|
||||||
|
@ -1,19 +1,7 @@
|
|||||||
-- Function that get the input/output rules of the delayer
|
-- Function that get the input/output rules of the delayer
|
||||||
local delayer_get_output_rules = function(node)
|
local delayer_get_output_rules = mesecon.horiz_rules_getter({{x = 1, y = 0, z = 0}})
|
||||||
local rules = {{x = 0, y = 0, z = 1}}
|
|
||||||
for i = 0, node.param2 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
local delayer_get_input_rules = function(node)
|
local delayer_get_input_rules = mesecon.horiz_rules_getter({{x = -1, y = 0, z = 0}})
|
||||||
local rules = {{x = 0, y = 0, z = -1}}
|
|
||||||
for i = 0, node.param2 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Functions that are called after the delay time
|
-- Functions that are called after the delay time
|
||||||
|
|
||||||
|
@ -3,17 +3,10 @@ local corner_selectionbox = {
|
|||||||
fixed = { -16/32, -16/32, -16/32, 5/32, -12/32, 5/32 },
|
fixed = { -16/32, -16/32, -16/32, 5/32, -12/32, 5/32 },
|
||||||
}
|
}
|
||||||
|
|
||||||
local corner_get_rules = function (node)
|
local corner_get_rules = mesecon.horiz_rules_getter({
|
||||||
local rules =
|
{x = 0, y = 0, z = -1},
|
||||||
{{x = 1, y = 0, z = 0},
|
{x = -1, y = 0, z = 0},
|
||||||
{x = 0, y = 0, z = -1}}
|
})
|
||||||
|
|
||||||
for i = 0, node.param2 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
|
||||||
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node("mesecons_extrawires:corner_on", {
|
minetest.register_node("mesecons_extrawires:corner_on", {
|
||||||
drawtype = "mesh",
|
drawtype = "mesh",
|
||||||
|
@ -3,7 +3,7 @@ local doublecorner_selectionbox = {
|
|||||||
fixed = { -8/16, -8/16, -8/16, 8/16, -6/16, 8/16 },
|
fixed = { -8/16, -8/16, -8/16, 8/16, -6/16, 8/16 },
|
||||||
}
|
}
|
||||||
|
|
||||||
local rules = {
|
local doublecorner_get_rules = mesecon.horiz_rules_getter({
|
||||||
{
|
{
|
||||||
{ x = 1, y = 0, z = 0 },
|
{ x = 1, y = 0, z = 0 },
|
||||||
{ x = 0, y = 0, z = 1 },
|
{ x = 0, y = 0, z = 1 },
|
||||||
@ -12,19 +12,7 @@ local rules = {
|
|||||||
{ x = -1, y = 0, z = 0 },
|
{ x = -1, y = 0, z = 0 },
|
||||||
{ x = 0, y = 0, z = -1 },
|
{ x = 0, y = 0, z = -1 },
|
||||||
},
|
},
|
||||||
}
|
})
|
||||||
|
|
||||||
local doublecorner_rules = {}
|
|
||||||
for k = 1, 4 do
|
|
||||||
doublecorner_rules[k] = table.copy(rules)
|
|
||||||
for i, r in ipairs(rules) do
|
|
||||||
rules[i] = mesecon.rotate_rules_left(r)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local function doublecorner_get_rules(node)
|
|
||||||
return doublecorner_rules[node.param2 % 4 + 1]
|
|
||||||
end
|
|
||||||
|
|
||||||
local doublecorner_states = {
|
local doublecorner_states = {
|
||||||
"mesecons_extrawires:doublecorner_00",
|
"mesecons_extrawires:doublecorner_00",
|
||||||
|
@ -10,18 +10,11 @@ local tjunction_selectionbox = {
|
|||||||
fixed = { -16/32, -16/32, -16/32, 16/32, -12/32, 7/32 },
|
fixed = { -16/32, -16/32, -16/32, 16/32, -12/32, 7/32 },
|
||||||
}
|
}
|
||||||
|
|
||||||
local tjunction_get_rules = function (node)
|
local tjunction_get_rules = mesecon.horiz_rules_getter({
|
||||||
local rules =
|
{x = 1, y = 0, z = 0},
|
||||||
{{x = 0, y = 0, z = 1},
|
{x = 0, y = 0, z = -1},
|
||||||
{x = 1, y = 0, z = 0},
|
{x = -1, y = 0, z = 0},
|
||||||
{x = 0, y = 0, z = -1}}
|
})
|
||||||
|
|
||||||
for i = 0, node.param2 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
|
||||||
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node("mesecons_extrawires:tjunction_on", {
|
minetest.register_node("mesecons_extrawires:tjunction_on", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
|
@ -11,25 +11,14 @@ local nodebox = {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local function gate_rotate_rules(node, rules)
|
local gate_get_output_rules = mesecon.horiz_rules_getter({{x = 1, y = 0, z = 0}})
|
||||||
for rotations = 0, node.param2 - 1 do
|
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
end
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
local function gate_get_output_rules(node)
|
local gate_get_input_rules_oneinput = mesecon.horiz_rules_getter({{x =-1, y = 0, z = 0}})
|
||||||
return gate_rotate_rules(node, {{x=1, y=0, z=0}})
|
|
||||||
end
|
|
||||||
|
|
||||||
local function gate_get_input_rules_oneinput(node)
|
local gate_get_input_rules_twoinputs = mesecon.horiz_rules_getter({
|
||||||
return gate_rotate_rules(node, {{x=-1, y=0, z=0}})
|
{x = 0, y = 0, z = 1, name = "input1"},
|
||||||
end
|
{x = 0, y = 0, z = -1, name = "input2"},
|
||||||
|
})
|
||||||
local function gate_get_input_rules_twoinputs(node)
|
|
||||||
return gate_rotate_rules(node, {{x=0, y=0, z=1, name="input1"},
|
|
||||||
{x=0, y=0, z=-1, name="input2"}})
|
|
||||||
end
|
|
||||||
|
|
||||||
local function set_gate(pos, node, state)
|
local function set_gate(pos, node, state)
|
||||||
local gate = minetest.registered_nodes[node.name]
|
local gate = minetest.registered_nodes[node.name]
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
local function insulated_wire_get_rules(node)
|
local insulated_wire_get_rules = mesecon.horiz_rules_getter({
|
||||||
local rules = {{x = 1, y = 0, z = 0},
|
{x = 1, y = 0, z = 0},
|
||||||
{x =-1, y = 0, z = 0}}
|
{x = -1, y = 0, z = 0},
|
||||||
if node.param2 == 1 or node.param2 == 3 then
|
})
|
||||||
return mesecon.rotate_rules_right(rules)
|
|
||||||
end
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node("mesecons_insulated:insulated_on", {
|
minetest.register_node("mesecons_insulated:insulated_on", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
|
@ -25,18 +25,10 @@ local up_rcvboxes = {
|
|||||||
{6/16, -8/16, 1/16, 8/16, -7/16, -1/16}, -- Plate extension (East)
|
{6/16, -8/16, 1/16, 8/16, -7/16, -1/16}, -- Plate extension (East)
|
||||||
}
|
}
|
||||||
|
|
||||||
local receiver_get_rules = function (node)
|
local receiver_get_rules = mesecon.horiz_rules_getter({
|
||||||
local rules = { {x = 1, y = 0, z = 0},
|
{x = 0, y = 0, z = 1},
|
||||||
{x = -2, y = 0, z = 0}}
|
{x = 0, y = 0, z = -2},
|
||||||
if node.param2 == 2 then
|
})
|
||||||
rules = mesecon.rotate_rules_left(rules)
|
|
||||||
elseif node.param2 == 3 then
|
|
||||||
rules = mesecon.rotate_rules_right(mesecon.rotate_rules_right(rules))
|
|
||||||
elseif node.param2 == 0 then
|
|
||||||
rules = mesecon.rotate_rules_right(rules)
|
|
||||||
end
|
|
||||||
return rules
|
|
||||||
end
|
|
||||||
|
|
||||||
mesecon.register_node("mesecons_receiver:receiver", {
|
mesecon.register_node("mesecons_receiver:receiver", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
|
Loading…
Reference in New Issue
Block a user