Add support for common CTCP commands

This commit is contained in:
ShadowNinja 2013-10-08 12:29:22 -04:00
parent 5b0671b512
commit 290082760b
3 changed files with 31 additions and 15 deletions

View File

@ -5,6 +5,7 @@ cmake_minimum_required(VERSION 2.8)
project(MINETEST_IRC C) project(MINETEST_IRC C)
# Also update init.lua
set(MINETEST_IRC_VERSION 0.2.0) set(MINETEST_IRC_VERSION 0.2.0)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake") list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")

View File

@ -40,16 +40,36 @@ function mt_irc.hooks.chat(user, channel, message)
message = message:gsub('\2', '') message = message:gsub('\2', '')
message = message:gsub('\31', '') message = message:gsub('\31', '')
message = message:gsub('\3[0-9][0-9,]*', '') message = message:gsub('\3[0-9][0-9,]*', '')
if string.sub(message, 1, 1) == string.char(1) then
mt_irc.conn:invoke("OnCTCP", user, channel, message)
return
end
if channel == mt_irc.conn.nick then if channel == mt_irc.conn.nick then
mt_irc.conn:invoke("PrivateMessage", user, message) mt_irc.conn:invoke("PrivateMessage", user, message)
else else
local c = string.char(1) mt_irc.conn:invoke("OnChannelChat", user, channel, message)
local found, _, action = message:find(("^%sACTION ([^%s]*)%s$"):format(c, c, c)) end
if found then end
mt_irc.conn:invoke("OnChannelAction", user, channel, action)
else
mt_irc.conn:invoke("OnChannelChat", user, channel, message) function mt_irc.hooks.ctcp(user, channel, message)
end if message:sub(2, 7):upper() == "ACTION" and
channel ~= mt_irc.conn.nick then
local action = message:sub(9, -2)
mt_irc:sendLocal(("* %s@IRC %s"):format(user.nick, action))
elseif message:sub(2, 8):upper() == "VERSION" then
mt_irc:queueMsg(mt_irc.msgs.notice(user.nick,
("\1VERSION Minetest IRC mod %s\1")
:format(mt_irc.version)))
elseif message:sub(2, 5):upper() == "PING" then
local ts = message:sub(7, -2)
mt_irc:queueMsg(mt_irc.msgs.notice(user.nick,
("\1PING %s\1"):format(ts)))
elseif message:sub(2, 5):upper() == "TIME" then
mt_irc:queueMsg(mt_irc.msgs.notice(user.nick,
("\1TIME %s\1"):format(os.date())))
end end
end end
@ -170,12 +190,6 @@ function mt_irc.hooks.quit(user, reason)
end end
function mt_irc.hooks.action(user, channel, message)
mt_irc:sendLocal(("* %s@IRC %s")
:format(user.nick, message))
end
function mt_irc.hooks.disconnect(message, isError) function mt_irc.hooks.disconnect(message, isError)
mt_irc.connected = false mt_irc.connected = false
if isError then if isError then
@ -213,7 +227,7 @@ mt_irc:register_hook("OnKick", mt_irc.hooks.kick)
mt_irc:register_hook("OnJoin", mt_irc.hooks.join) mt_irc:register_hook("OnJoin", mt_irc.hooks.join)
mt_irc:register_hook("OnQuit", mt_irc.hooks.quit) mt_irc:register_hook("OnQuit", mt_irc.hooks.quit)
mt_irc:register_hook("NickChange", mt_irc.hooks.nick) mt_irc:register_hook("NickChange", mt_irc.hooks.nick)
mt_irc:register_hook("OnChannelAction", mt_irc.hooks.action) mt_irc:register_hook("OnCTCP", mt_irc.hooks.ctcp)
mt_irc:register_hook("PrivateMessage", mt_irc.hooks.pm) mt_irc:register_hook("PrivateMessage", mt_irc.hooks.pm)
mt_irc:register_hook("OnNotice", mt_irc.hooks.notice) mt_irc:register_hook("OnNotice", mt_irc.hooks.notice)
mt_irc:register_hook("OnChannelChat", mt_irc.hooks.channelChat) mt_irc:register_hook("OnChannelChat", mt_irc.hooks.channelChat)

View File

@ -3,12 +3,13 @@
mt_irc = { mt_irc = {
version = "0.2.0", -- Also update CMakeLists.txt
connected = false, connected = false,
cur_time = 0, cur_time = 0,
message_buffer = {}, message_buffer = {},
recent_message_count = 0, recent_message_count = 0,
joined_players = {}, joined_players = {},
modpath = minetest.get_modpath("irc") modpath = minetest.get_modpath(minetest.get_current_modname()),
} }
-- To find LuaIRC and LuaSocket -- To find LuaIRC and LuaSocket