2022-09-19 16:27:59 +00:00
|
|
|
local wea_c = worldeditadditions_core
|
2022-09-18 23:18:03 +00:00
|
|
|
local Vector3 = wea_c.Vector3
|
|
|
|
|
2018-10-13 23:19:32 +00:00
|
|
|
--- Overlap command. Places a specified node on top of each column.
|
2018-05-22 21:20:26 +00:00
|
|
|
-- @module worldeditadditions.overlay
|
|
|
|
|
2020-06-07 19:46:46 +00:00
|
|
|
function worldeditadditions.overlay(pos1, pos2, node_weights)
|
2022-09-18 23:18:03 +00:00
|
|
|
pos1, pos2 = Vector3.sort(pos1, pos2)
|
2018-05-22 21:20:26 +00:00
|
|
|
-- pos2 will always have the highest co-ordinates now
|
|
|
|
|
|
|
|
-- Fetch the nodes in the specified area
|
|
|
|
local manip, area = worldedit.manip_helpers.init(pos1, pos2)
|
|
|
|
local data = manip:get_data()
|
|
|
|
|
2020-06-07 19:46:46 +00:00
|
|
|
local node_id_ignore = minetest.get_content_id("ignore")
|
|
|
|
|
2022-09-18 23:18:03 +00:00
|
|
|
local node_ids, node_ids_count = wea_c.make_weighted(node_weights)
|
2018-05-22 21:20:26 +00:00
|
|
|
|
2022-09-19 16:33:02 +00:00
|
|
|
-- minetest.log("action", "pos1: " .. pos1)
|
|
|
|
-- minetest.log("action", "pos2: " .. pos2)
|
2018-05-22 21:20:26 +00:00
|
|
|
|
|
|
|
-- z y x is the preferred loop order, but that isn't really possible here
|
|
|
|
|
2020-09-14 00:19:15 +00:00
|
|
|
local changes = { updated = 0, skipped_columns = 0, placed = {} }
|
2018-05-22 21:20:26 +00:00
|
|
|
for z = pos2.z, pos1.z, -1 do
|
|
|
|
for x = pos2.x, pos1.x, -1 do
|
|
|
|
local found_air = false
|
|
|
|
local placed_node = false
|
2021-03-02 00:09:46 +00:00
|
|
|
-- print("\n\n[overlay] ****** column start ******")
|
2018-05-22 21:20:26 +00:00
|
|
|
for y = pos2.y, pos1.y, -1 do
|
2020-06-07 19:46:46 +00:00
|
|
|
local i = area:index(x, y, z)
|
2022-09-18 23:18:03 +00:00
|
|
|
-- print("[overlay] pos", x, y, z, "id", data[i], "name", minetest.get_name_from_content_id(data[i]), "is_liquid", wea_c.is_liquidlike(data[i]))
|
2020-06-07 19:46:46 +00:00
|
|
|
|
2022-09-18 23:18:03 +00:00
|
|
|
local is_air = wea_c.is_airlike(data[i])
|
|
|
|
local is_liquid = wea_c.is_liquidlike(data[i])
|
|
|
|
-- wielded_light is now handled by wea_c.is_airlike
|
2020-09-14 00:19:15 +00:00
|
|
|
|
2020-06-07 19:46:46 +00:00
|
|
|
local is_ignore = data[i] == node_id_ignore
|
|
|
|
|
|
|
|
if not is_air and not is_ignore then
|
2021-03-02 00:09:46 +00:00
|
|
|
local i_above = area:index(x, y + 1, z)
|
|
|
|
if found_air and not is_liquid then
|
2020-06-07 19:46:46 +00:00
|
|
|
local new_id = node_ids[math.random(node_ids_count)]
|
2018-05-22 21:20:26 +00:00
|
|
|
-- We've found an air block previously, so it must be above us
|
|
|
|
-- Replace the node above us with the target block
|
2021-03-02 00:09:46 +00:00
|
|
|
data[i_above] = new_id
|
2018-05-22 21:20:26 +00:00
|
|
|
changes.updated = changes.updated + 1
|
|
|
|
placed_node = true
|
2020-09-14 00:19:15 +00:00
|
|
|
if not changes.placed[new_id] then
|
|
|
|
changes.placed[new_id] = 0
|
|
|
|
end
|
|
|
|
changes.placed[new_id] = changes.placed[new_id] + 1
|
2021-03-02 00:09:46 +00:00
|
|
|
-- print("[overlay] placed above ", x, y, z)
|
2018-05-22 21:20:26 +00:00
|
|
|
break -- Move on to the next column
|
|
|
|
end
|
2021-03-02 00:09:46 +00:00
|
|
|
elseif not is_ignore and not is_liquid then
|
|
|
|
-- print("[overlay] found air at", x, y, z)
|
2018-05-22 21:20:26 +00:00
|
|
|
found_air = true
|
|
|
|
end
|
2021-03-02 00:09:46 +00:00
|
|
|
if is_liquid then found_air = false end
|
2018-05-22 21:20:26 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
if not placed_node then
|
|
|
|
changes.skipped_columns = changes.skipped_columns + 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
-- Save the modified nodes back to disk & return
|
|
|
|
worldedit.manip_helpers.finish(manip, data)
|
|
|
|
|
|
|
|
return changes
|
|
|
|
end
|