forked from minetest-mods/irc
Add success and message return values to bot commands
This commit is contained in:
parent
8e6a9a287f
commit
5655f75946
7
API.md
7
API.md
@ -28,12 +28,13 @@ irc:register_bot_command(name, 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 "")
|
||||||
|
-- This function should return boolean success and a message.
|
||||||
end,
|
end,
|
||||||
};
|
};
|
||||||
Example:
|
Example:
|
||||||
@ -41,7 +42,7 @@ irc:register_bot_command(name, cmdDef)
|
|||||||
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,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
45
botcmds.lua
45
botcmds.lua
@ -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
|
||||||
|
local player = minetest.get_player_by_name(args)
|
||||||
|
if not player then
|
||||||
|
return false, "There is no player named '"..args.."'"
|
||||||
end
|
end
|
||||||
local player = minetest.env:get_player_by_name(args)
|
|
||||||
if player then
|
|
||||||
local fmt = "Player %s is at (%.2f,%.2f,%.2f)"
|
local fmt = "Player %s is at (%.2f,%.2f,%.2f)"
|
||||||
local pos = player:getpos()
|
local pos = player:getpos()
|
||||||
irc:reply(fmt:format(args, pos.x, pos.y, pos.z))
|
return true, fmt:format(args, pos.x, pos.y, pos.z)
|
||||||
return
|
|
||||||
end
|
|
||||||
irc:reply("There is no player named '"..args.."'")
|
|
||||||
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
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user