Minetest-WorldEditAdditions/worldeditadditions_commands/commands/maze.lua

116 lines
5.3 KiB
Lua
Raw Normal View History

2020-05-03 01:37:18 +02:00
local we_c = worldeditadditions_commands
local function parse_params_maze(params_text, is_3d)
2020-05-03 01:37:18 +02:00
if not params_text then
return false, "No arguments specified"
2020-05-03 01:37:18 +02:00
end
2020-05-12 01:38:42 +02:00
local parts = worldeditadditions.split(params_text, "%s+", false)
2020-05-03 01:37:18 +02:00
local replace_node = parts[1]
local seed = os.time()
local path_length = 2
local path_width = 1
local path_depth = 1
local param_index_seed = 4
if is_3d then param_index_seed = 5 end
2020-05-03 01:37:18 +02:00
if #parts >= 2 then
path_length = tonumber(parts[2])
end
if #parts >= 3 then
path_width = tonumber(parts[3])
end
if #parts >= 4 and is_3d then
path_depth = tonumber(parts[4])
end
if #parts >= param_index_seed then
seed = tonumber(parts[param_index_seed])
if not seed then
return false, "Error: Invalid seed value (seeds may only be integers)."
end
end
2020-05-03 01:37:18 +02:00
replace_node = worldedit.normalize_nodename(replace_node)
if not replace_node then
return false, "Error: Invalid node name for replace_node"
end
if not path_length or path_length < 1 then
return false, "Error: Invalid path length (it must be a positive integer)"
end
if not path_width or path_width < 1 then
return false, "Error: Invalid path width (it must be a positive integer)"
end
if not path_depth or path_depth < 1 then
return false, "Error: Invalid path depth (it must be a positive integer)"
end
-- We unconditionally math.floor here because when we tried to test for it directly it was unreliable
return true, replace_node, seed, math.floor(path_length), math.floor(path_width), math.floor(path_depth)
2020-05-03 01:37:18 +02:00
end
-- ███ ███ █████ ███████ ███████
-- ████ ████ ██ ██ ███ ██
-- ██ ████ ██ ███████ ███ █████
-- ██ ██ ██ ██ ██ ███ ██
-- ██ ██ ██ ██ ███████ ███████
worldedit.register_command("maze", {
params = "<replace_node> [<path_length> [<path_width> [<seed>]]]",
description = "Generates a maze covering the currently selected area (must be at least 3x3 on the x,z axes) with replace_node as the walls. Optionally takes a (integer) seed and the path length and width (see the documentation in the worldeditadditions README for more information).",
2020-05-03 01:37:18 +02:00
privs = { worldedit = true },
require_pos = 2,
parse = function(params_text)
local success, replace_node, seed, path_length, path_width = parse_params_maze(params_text, false)
return success, replace_node, seed, path_length, path_width
end,
nodes_needed = function(name)
-- Note that we could take in additional parameters from the return value of parse (minue the success bool there), but we don't actually need them here
return worldedit.volume(worldedit.pos1[name], worldedit.pos2[name])
end,
func = function(name, replace_node, seed, path_length, path_width)
local start_time = worldeditadditions.get_ms_time()
local replaced = worldeditadditions.maze2d(worldedit.pos1[name], worldedit.pos2[name], replace_node, seed, path_length, path_width)
local time_taken = worldeditadditions.get_ms_time() - start_time
2020-05-03 01:37:18 +02:00
2020-05-11 00:46:19 +02:00
minetest.log("action", name .. " used //maze at " .. worldeditadditions.vector.tostring(worldedit.pos1[name]) .. " - "..worldeditadditions.vector.tostring(worldedit.pos2[name])..", replacing " .. replaced .. " nodes in " .. time_taken .. "s")
return true, replaced .. " nodes replaced in " .. worldeditadditions.human_time(time_taken)
end
2020-05-03 01:37:18 +02:00
})
-- ███ ███ █████ ███████ ███████ ██████ ██████
-- ████ ████ ██ ██ ███ ██ ██ ██ ██
-- ██ ████ ██ ███████ ███ █████ █████ ██ ██
-- ██ ██ ██ ██ ██ ███ ██ ██ ██ ██
-- ██ ██ ██ ██ ███████ ███████ ██████ ██████
worldedit.register_command("maze3d", {
params = "<replace_node> [<path_length> [<path_width> [<path_depth> [<seed>]]]]",
description = "Generates a 3d maze covering the currently selected area (must be at least 3x3x3) with replace_node as the walls. Optionally takes a (integer) seed and the path length, width, and depth (see the documentation in the worldeditadditions README for more information).",
2020-05-03 01:37:18 +02:00
privs = { worldedit = true },
require_pos = 2,
parse = function(params_text)
local values = {parse_params_maze(params_text, true)}
return unpack(values)
end,
nodes_needed = function(name)
return worldedit.volume(worldedit.pos1[name], worldedit.pos2[name])
end,
func = function(name, replace_node, seed, path_length, path_width, path_depth)
local start_time = worldeditadditions.get_ms_time()
local replaced = worldeditadditions.maze3d(worldedit.pos1[name], worldedit.pos2[name], replace_node, seed, path_length, path_width, path_depth)
local time_taken = worldeditadditions.get_ms_time() - start_time
2020-05-03 01:37:18 +02:00
2020-05-11 00:46:19 +02:00
minetest.log("action", name .. " used //maze3d at " .. worldeditadditions.vector.tostring(worldedit.pos1[name]) .. " - "..worldeditadditions.vector.tostring(worldedit.pos2[name])..", replacing " .. replaced .. " nodes in " .. time_taken .. "s")
return true, replaced .. " nodes replaced in " .. worldeditadditions.human_time(time_taken)
end
2020-05-03 01:37:18 +02:00
})