2019-03-02 14:24:48 +03:00
|
|
|
--[[
|
|
|
|
|
|
|
|
TechAge
|
|
|
|
=======
|
|
|
|
|
|
|
|
Copyright (C) 2019 Joachim Stolberg
|
|
|
|
|
|
|
|
LGPLv2.1+
|
|
|
|
See LICENSE.txt for more information
|
|
|
|
|
|
|
|
Junction for power distribution
|
|
|
|
|
|
|
|
]]--
|
|
|
|
|
|
|
|
-- for lazy programmers
|
|
|
|
local S = function(pos) if pos then return minetest.pos_to_string(pos) end end
|
|
|
|
local P = minetest.string_to_pos
|
|
|
|
local M = minetest.get_meta
|
|
|
|
|
|
|
|
|
|
|
|
local function bit(p)
|
|
|
|
return 2 ^ (p - 1) -- 1-based indexing
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Typical call: if hasbit(x, bit(3)) then ...
|
|
|
|
local function hasbit(x, p)
|
|
|
|
return x % (p + p) >= p
|
|
|
|
end
|
|
|
|
|
|
|
|
local function setbit(x, p)
|
|
|
|
return hasbit(x, p) and x or x + p
|
|
|
|
end
|
|
|
|
|
|
|
|
local function get_node_box(val, size, boxes)
|
|
|
|
local fixed = {{-size, -size, -size, size, size, size}}
|
|
|
|
for i = 1,6 do
|
|
|
|
if hasbit(val, bit(i)) then
|
|
|
|
for _,box in ipairs(boxes[i]) do
|
|
|
|
table.insert(fixed, box)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return {
|
|
|
|
type = "fixed",
|
|
|
|
fixed = fixed,
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
-- 'size' is the size of the junction cube without any connection, e.g. 1/8
|
|
|
|
-- 'boxes' is a table with 6 table elements for the 6 possible connection arms
|
|
|
|
-- 'network' is the tubelib2 instance
|
|
|
|
-- 'node' is the node definition with tiles, callback functions, and so on
|
2019-05-11 02:21:03 +03:00
|
|
|
-- 'techage' is the power network definition
|
2019-03-02 14:24:48 +03:00
|
|
|
function techage.register_junction(name, size, boxes, network, node)
|
|
|
|
for idx = 0,63 do
|
2019-05-11 02:21:03 +03:00
|
|
|
local node1 = table.copy(node)
|
|
|
|
node1.groups.techage_trowel = 1
|
|
|
|
if idx == 0 then
|
|
|
|
node1.groups.not_in_creative_inventory = 0
|
|
|
|
else
|
|
|
|
node1.groups.not_in_creative_inventory = 1
|
|
|
|
end
|
|
|
|
node1.drawtype = "nodebox"
|
|
|
|
node1.node_box = get_node_box(idx, size, boxes)
|
|
|
|
node1.paramtype2 = "facedir"
|
|
|
|
node1.on_rotate = screwdriver.disallow
|
|
|
|
node1.paramtype = "light"
|
|
|
|
node1.sunlight_propagates = true
|
|
|
|
node1.is_ground_content = false
|
|
|
|
node1.drop = name.."0"
|
|
|
|
--node.techage = techage
|
|
|
|
minetest.register_node(name..idx, node1)
|
2019-03-02 14:24:48 +03:00
|
|
|
network:add_secondary_node_names({name..idx})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-04-28 22:34:21 +03:00
|
|
|
|
|
|
|
|
2019-03-02 14:24:48 +03:00
|
|
|
function techage.junction_type(conn)
|
|
|
|
local val = 0
|
|
|
|
for idx = 1,6 do
|
|
|
|
if conn[idx] then
|
|
|
|
val = setbit(val, bit(idx))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return val
|
|
|
|
end
|
2019-03-03 20:15:30 +03:00
|
|
|
|