mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2025-01-22 03:38:48 +02:00
62 lines
1.8 KiB
Lua
62 lines
1.8 KiB
Lua
local direction_tendencies = {
|
|
[1] = {0, 2, 4, 6},
|
|
[2] = {2, 4, 6, 0},
|
|
[3] = {4, 6, 0, 2},
|
|
[4] = {6, 0, 2, 4}
|
|
}
|
|
|
|
local function get_optimal_direction(entity, direction_tendency)
|
|
local original_direction = entity.direction
|
|
local optimal_direction = entity.direction
|
|
local max_connection_count = #entity.belt_neighbours['inputs'] + #entity.belt_neighbours['outputs']
|
|
|
|
for _, d in pairs(direction_tendency) do
|
|
entity.direction = d
|
|
local count = #entity.belt_neighbours['inputs'] + #entity.belt_neighbours['outputs']
|
|
--if #entity.belt_neighbours["inputs"] > 0 and #entity.belt_neighbours["outputs"] > 0 then
|
|
-- optimal_direction = d
|
|
-- break
|
|
--end
|
|
if count > max_connection_count then
|
|
max_connection_count = count
|
|
optimal_direction = d
|
|
end
|
|
end
|
|
|
|
if max_connection_count == 1 then
|
|
for _, d in pairs(direction_tendency) do
|
|
entity.direction = d
|
|
if #entity.belt_neighbours['inputs'] > 0 then
|
|
if d == entity.belt_neighbours['inputs'][1].direction then
|
|
optimal_direction = d
|
|
break
|
|
end
|
|
end
|
|
if #entity.belt_neighbours['outputs'] > 0 then
|
|
if d == entity.belt_neighbours['outputs'][1].direction then
|
|
optimal_direction = d
|
|
break
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
entity.direction = original_direction
|
|
|
|
return optimal_direction
|
|
end
|
|
|
|
local function connect_belts(entities, d)
|
|
for _ = 1, 4, 1 do
|
|
local r = d
|
|
if not r then
|
|
r = math.random(1, 4)
|
|
end
|
|
for k, entity in pairs(entities) do
|
|
entity.direction = get_optimal_direction(entity, direction_tendencies[r])
|
|
end
|
|
end
|
|
end
|
|
|
|
return connect_belts
|