1
0
mirror of https://github.com/Uberi/Minetest-WorldEdit.git synced 2025-10-24 19:05:25 +02:00

Use chatcommand return values

This commit is contained in:
HybridDog
2020-02-17 12:42:41 +01:00
parent bf55f52197
commit 17d704799a
3 changed files with 56 additions and 55 deletions

View File

@@ -54,10 +54,13 @@ local brush_on_use = function(itemstack, placer)
minetest.log("action", string.format("%s uses WorldEdit brush (//%s) at %s", minetest.log("action", string.format("%s uses WorldEdit brush (//%s) at %s",
name, cmd, minetest.pos_to_string(pointed_thing.under))) name, cmd, minetest.pos_to_string(pointed_thing.under)))
cmddef.func(name, unpack(parsed)) local success, msg = cmddef.func(name, unpack(parsed))
worldedit.player_notify = player_notify_old worldedit.player_notify = player_notify_old
return true
if msg then
worldedit.player_notify(name, msg)
end
return success ~= false
end end
minetest.register_tool(":worldedit:brush", { minetest.register_tool(":worldedit:brush", {
@@ -89,37 +92,47 @@ worldedit.register_command("brush", {
func = function(name, cmd, params) func = function(name, cmd, params)
local itemstack = minetest.get_player_by_name(name):get_wielded_item() local itemstack = minetest.get_player_by_name(name):get_wielded_item()
if itemstack == nil or itemstack:get_name() ~= "worldedit:brush" then if itemstack == nil or itemstack:get_name() ~= "worldedit:brush" then
worldedit.player_notify(name, "Not holding brush item.") return false, worldedit.notify_form:format(
return "Not holding brush item.")
end end
cmd = cmd:lower() cmd = cmd:lower()
local meta = itemstack:get_meta() local meta = itemstack:get_meta()
if cmd == "none" then if cmd == "none" then
meta:from_table(nil) meta:from_table(nil)
worldedit.player_notify(name, "Brush assignment cleared.") minetest.get_player_by_name(name):set_wielded_item(itemstack)
else return true, worldedit.notify_form:format(
local cmddef = worldedit.registered_commands[cmd] "Brush assignment cleared.")
if cmddef == nil or cmddef.require_pos ~= 1 then
worldedit.player_notify(name, "//" .. cmd .. " cannot be used with brushes")
return
end
-- Try parsing command params so we can give the user feedback
local ok, err = cmddef.parse(params)
if not ok then
err = err or "invalid usage"
worldedit.player_notify(name, "Error with brush command: " .. err)
return
end
meta:set_string("command", cmd)
meta:set_string("params", params)
local fullcmd = "//" .. cmd .. " " .. params
meta:set_string("description",
minetest.registered_tools["worldedit:brush"].description .. ": " .. fullcmd)
worldedit.player_notify(name, "Brush assigned to command: " .. fullcmd)
end end
local cmddef = worldedit.registered_commands[cmd]
if cmddef == nil or cmddef.require_pos ~= 1 then
return false, worldedit.notify_form:format("//" .. cmd ..
" cannot be used with brushes")
end
-- Try parsing command params so we can give the user feedback
local ok, err = cmddef.parse(params)
if not ok then
err = err or "invalid usage"
return false, worldedit.notify_form:format(
"Error with brush command: " .. err)
end
meta:set_string("command", cmd)
meta:set_string("params", params)
local fullcmd = "//" .. cmd .. " " .. params
meta:set_string("description",
minetest.registered_tools["worldedit:brush"].description .. ": " .. fullcmd)
worldedit.player_notify(name, "Brush assigned to command: " .. fullcmd)
meta:set_string("command", cmd)
meta:set_string("params", params)
local fullcmd = "//" .. cmd .. " " .. params
meta:set_string("description",
minetest.registered_tools["worldedit:brush"].description .. ": " .. fullcmd)
minetest.get_player_by_name(name):set_wielded_item(itemstack) minetest.get_player_by_name(name):set_wielded_item(itemstack)
return true, worldedit.notify_form:format(
"Brush assigned to command: " .. fullcmd)
end, end,
}) })

View File

@@ -12,8 +12,10 @@ worldedit.prob_list = {}
local safe_region, reset_pending = dofile(minetest.get_modpath("worldedit_commands") .. "/safe.lua") local safe_region, reset_pending = dofile(minetest.get_modpath("worldedit_commands") .. "/safe.lua")
-- The prefix avoids chat messages being mixed up with WorldEdit messages
worldedit.notify_form = minetest.colorize("#94ffcc", "WorldEdit -!- ") .. "%s"
function worldedit.player_notify(name, message) function worldedit.player_notify(name, message)
minetest.chat_send_player(name, "WorldEdit -!- " .. message, false) minetest.chat_send_player(name, worldedit.notify_form:format(message))
end end
worldedit.registered_commands = {} worldedit.registered_commands = {}
@@ -22,40 +24,27 @@ local function chatcommand_handler(cmd_name, name, param)
local def = assert(worldedit.registered_commands[cmd_name]) local def = assert(worldedit.registered_commands[cmd_name])
if def.require_pos == 2 then if def.require_pos == 2 then
local pos1, pos2 = worldedit.pos1[name], worldedit.pos2[name] if not worldedit.pos1[name] or not worldedit.pos2[name] then
if pos1 == nil or pos2 == nil then return false, worldedit.notify_form:format("no region selected")
worldedit.player_notify(name, "no region selected")
return
end
elseif def.require_pos == 1 then
local pos1 = worldedit.pos1[name]
if pos1 == nil then
worldedit.player_notify(name, "no position 1 selected")
return
end end
elseif def.require_pos == 1 and not worldedit.pos1[name] then
return false, worldedit.notify_form:format("no position 1 selected")
end end
local parsed = {def.parse(param)} local parsed = {def.parse(param)}
local success = table.remove(parsed, 1) local success = table.remove(parsed, 1)
if not success then if not success then
worldedit.player_notify(name, parsed[1] or "invalid usage") return false, worldedit.notify_form:format(parsed[1] or "invalid usage")
return
end end
if def.nodes_needed then if def.nodes_needed then
local count = def.nodes_needed(name, unpack(parsed)) local count = def.nodes_needed(name, unpack(parsed))
safe_region(name, count, function() return safe_region(name, count, function()
local success, msg = def.func(name, unpack(parsed)) return def.func(name, unpack(parsed))
if msg then
minetest.chat_send_player(name, msg)
end
end) end)
else else
-- no "safe region" check -- no "safe region" check
local success, msg = def.func(name, unpack(parsed)) return def.func(name, unpack(parsed))
if msg then
minetest.chat_send_player(name, msg)
end
end end
end end

View File

@@ -9,7 +9,8 @@ local function safe_region(name, count, callback)
--save callback to call later --save callback to call later
safe_region_callback[name] = callback safe_region_callback[name] = callback
worldedit.player_notify(name, "WARNING: this operation could affect up to " .. count .. " nodes; type //y to continue or //n to cancel") return false, "WARNING: this operation could affect up to " .. count ..
" nodes; type //y to continue or //n to cancel"
end end
local function reset_pending(name) local function reset_pending(name)
@@ -22,12 +23,11 @@ minetest.register_chatcommand("/y", {
func = function(name) func = function(name)
local callback = safe_region_callback[name] local callback = safe_region_callback[name]
if not callback then if not callback then
worldedit.player_notify(name, "no operation pending") return false, worldedit.notify_form:format("no operation pending")
return
end end
reset_pending(name) reset_pending(name)
callback(name) return callback(name)
end, end,
}) })
@@ -36,8 +36,7 @@ minetest.register_chatcommand("/n", {
description = "Abort a pending operation", description = "Abort a pending operation",
func = function(name) func = function(name)
if not safe_region_callback[name] then if not safe_region_callback[name] then
worldedit.player_notify(name, "no operation pending") return false, worldedit.notify_form:format("no operation pending")
return
end end
reset_pending(name) reset_pending(name)