Add success and message return values to bot commands

This commit is contained in:
ShadowNinja 2014-05-28 20:05:26 -04:00
parent 8e6a9a287f
commit 5655f75946
2 changed files with 42 additions and 42 deletions

37
API.md
View File

@ -25,25 +25,26 @@ irc:register_bot_command(name, cmdDef)
When an user sends a private message to the bot with the command name, the When an user sends a private message to the bot with the command name, the
command's function is called. command's function is called.
Here's the format of a command definition (<cmdDef>): Here's the format of a command definition (<cmdDef>):
cmdDef = { cmdDef = {
params = "<param1> ...", -- A description of the command's parameters params = "<param1> ...", -- A description of the command's parameters
description = "My command", -- A description of what the command does. (one-liner) description = "My command", -- A description of what the command does. (one-liner)
func = function(user, param) func = function(user, args)
-- This function gets called when the command is invoked. -- This function gets called when the command is invoked.
-- <user> is a user table for the user that ran the command. -- <user> is a user table for the user that ran the command.
-- (See the LuaIRC documentation for details.) -- (See the LuaIRC documentation for details.)
-- It contains fields such as 'nick' and 'ident' -- It contains fields such as 'nick' and 'ident'
-- <param> is a string of parameters to the command (may be "") -- <args> is a string of arguments to the command (may be "")
end, -- This function should return boolean success and a message.
}; end,
};
Example: Example:
irc:register_bot_command("hello", { irc:register_bot_command("hello", {
params = "", params = "",
description = "Greet user", description = "Greet user",
func = function(user, param) func = function(user, param)
irc:say(user.nick, "Hello!") return true, "Hello!"
end, end,
}); });
irc.joined_players[name] irc.joined_players[name]
This table holds the players who are currently on the channel (may be less This table holds the players who are currently on the channel (may be less

View File

@ -52,7 +52,10 @@ function irc:bot_command(msg, text)
return return
end end
self.bot_commands[cmd].func(msg.user, args) local success, message = self.bot_commands[cmd].func(msg.user, args)
if message then
self:reply(message)
end
end end
@ -71,21 +74,19 @@ irc:register_bot_command("help", {
description = "Get help about a command", description = "Get help about a command",
func = function(user, args) func = function(user, args)
if args == "" then if args == "" then
irc:reply("No command name specified. Use 'list' for a list of commands") return false, "No command name specified. Use 'list' for a list of commands."
return
end end
local cmd = irc.bot_commands[args] local cmd = irc.bot_commands[args]
if not cmd then if not cmd then
irc:reply("Unknown command '"..cmdname.."'.") return false, "Unknown command '"..cmdname.."'."
return
end end
irc:reply(("Usage: %c%s %s -- %s"):format( return true, ("Usage: %c%s %s -- %s"):format(
irc.config.command_prefix, irc.config.command_prefix,
args, args,
cmd.params or "<no parameters>", cmd.params or "<no parameters>",
cmd.description or "<no description>")) cmd.description or "<no description>")
end end
}) })
@ -98,8 +99,8 @@ irc:register_bot_command("list", {
for name, cmd in pairs(irc.bot_commands) do for name, cmd in pairs(irc.bot_commands) do
cmdlist = cmdlist..name..", " cmdlist = cmdlist..name..", "
end end
irc:reply(cmdlist.." -- Use 'help <command name>' to get" return true, cmdlist.." -- Use 'help <command name>' to get"
.." help about a specific command.") .." help about a specific command."
end end
}) })
@ -109,17 +110,15 @@ irc:register_bot_command("whereis", {
description = "Tell the location of <player>", description = "Tell the location of <player>",
func = function(user, args) func = function(user, args)
if args == "" then if args == "" then
irc:bot_help(user, "whereis") return false, "Player name required."
return
end end
local player = minetest.env:get_player_by_name(args) local player = minetest.get_player_by_name(args)
if player then if not player then
local fmt = "Player %s is at (%.2f,%.2f,%.2f)" return false, "There is no player named '"..args.."'"
local pos = player:getpos()
irc:reply(fmt:format(args, pos.x, pos.y, pos.z))
return
end end
irc:reply("There is no player named '"..args.."'") local fmt = "Player %s is at (%.2f,%.2f,%.2f)"
local pos = player:getpos()
return true, fmt:format(args, pos.x, pos.y, pos.z)
end end
}) })
@ -131,11 +130,11 @@ irc:register_bot_command("uptime", {
local cur_time = os.time() local cur_time = os.time()
local diff = os.difftime(cur_time, starttime) local diff = os.difftime(cur_time, starttime)
local fmt = "Server has been running for %d:%02d:%02d" local fmt = "Server has been running for %d:%02d:%02d"
irc:reply(fmt:format( return true, fmt:format(
math.floor(diff / 60 / 60), math.floor(diff / 60 / 60),
math.mod(math.floor(diff / 60), 60), math.floor(diff / 60) % 60,
math.mod(math.floor(diff), 60) math.floor(diff) % 60
)) )
end end
}) })
@ -148,8 +147,8 @@ irc:register_bot_command("players", {
for _, player in pairs(players) do for _, player in pairs(players) do
table.insert(names, player:get_player_name()) table.insert(names, player:get_player_name())
end end
irc:reply("Connected players: " return true, "Connected players: "
..table.concat(names, ", ")) ..table.concat(names, ", ")
end end
}) })