1
0
mirror of https://github.com/minetest-mods/irc.git synced 2025-10-26 03:05:24 +01:00

4 Commits

Author SHA1 Message Date
47f889c178 Merge branch 'master' into nalc-1.2 2019-05-09 22:41:39 +02:00
sys4-fr
6a7053582d Ajoute message de chargement du mod dans le journal "action" 2018-12-26 00:00:52 +01:00
sys4-fr
5e877956a5 Corrige l'url du submodule irc 2018-12-09 21:36:12 +01:00
sys4-fr
60bf32e157 Mise à jour du submodule irc 2018-12-09 21:19:42 +01:00
13 changed files with 27 additions and 37 deletions

View File

@@ -1,11 +0,0 @@
on: [push, pull_request]
name: Check & Release
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- name: lint
uses: Roang-zero1/factorio-mod-luacheck@master
with:
luacheckrc_url: https://raw.githubusercontent.com/minetest-mods/irc/master/.luacheckrc

4
.gitmodules vendored
View File

@@ -1,3 +1,3 @@
[submodule "src/LuaIRC"] [submodule "irc"]
path = irc path = irc
url = https://github.com/ShadowNinja/LuaIRC.git url = https://sys4.fr/gitea/nalc/LuaIRC.git

View File

@@ -2,7 +2,7 @@
allow_defined_top = true allow_defined_top = true
read_globals = { read_globals = {
"minetest" "minetest",
} }
exclude_files = { exclude_files = {

View File

@@ -1,4 +1,3 @@
[![](https://github.com/minetest-mods/irc/workflows/Check%20&%20Release/badge.svg)](https://github.com/minetest-mods/irc/actions)
IRC Mod for Minetest IRC Mod for Minetest
==================== ====================

View File

@@ -139,7 +139,7 @@ irc.register_bot_command("whereis", {
return false, "There is no player named '"..args.."'" return false, "There is no player named '"..args.."'"
end end
local fmt = "Player %s is at (%.2f,%.2f,%.2f)" local fmt = "Player %s is at (%.2f,%.2f,%.2f)"
local pos = player:get_pos() local pos = player:getpos()
return true, fmt:format(args, pos.x, pos.y, pos.z) return true, fmt:format(args, pos.x, pos.y, pos.z)
end end
}) })
@@ -169,10 +169,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
return true, string.format("%d connected player(s): %s", return true, "Connected players: "
#players, ..table.concat(names, ", ")
table.concat(names, ", ")
)
end end
}) })

View File

@@ -31,7 +31,7 @@ minetest.register_on_chat_message(function(name, message)
if nl then if nl then
message = message:sub(1, nl - 1) message = message:sub(1, nl - 1)
end end
irc.say(irc.playerMessage(name, minetest.strip_colors(message))) irc.say(irc.playerMessage(name, core.strip_colors(message)))
end) end)

View File

@@ -7,6 +7,7 @@ irc.config = {}
local function setting(stype, name, default, required) local function setting(stype, name, default, required)
local value local value
if minetest.settings and minetest.settings.get and minetest.settings.get_bool then if minetest.settings and minetest.settings.get and minetest.settings.get_bool then
-- The current methods for getting settings
if stype == "bool" then if stype == "bool" then
value = minetest.settings:get_bool("irc."..name) value = minetest.settings:get_bool("irc."..name)
elseif stype == "string" then elseif stype == "string" then
@@ -14,6 +15,15 @@ local function setting(stype, name, default, required)
elseif stype == "number" then elseif stype == "number" then
value = tonumber(minetest.settings:get("irc."..name)) value = tonumber(minetest.settings:get("irc."..name))
end end
else
-- The old methods for getting settings for backward compatibility. Deprecated on 0.4.16+
if stype == "bool" then
value = minetest.setting_getbool("irc."..name)
elseif stype == "string" then
value = minetest.setting_get("irc."..name)
elseif stype == "number" then
value = tonumber(minetest.setting_get("irc."..name))
end
end end
if value == nil then if value == nil then
if required then if required then

4
description.txt Normal file
View File

@@ -0,0 +1,4 @@
This mod is just a glue between IRC and Minetest.
It provides two-way communication between the
in-game chat, and an arbitrary IRC channel.

View File

@@ -120,8 +120,6 @@ function irc.hooks.channelChat(msg)
text:find("^%*%*%* ([^%s]+) joined the game$") text:find("^%*%*%* ([^%s]+) joined the game$")
local foundleave, _, leavenick = local foundleave, _, leavenick =
text:find("^%*%*%* ([^%s]+) left the game$") text:find("^%*%*%* ([^%s]+) left the game$")
local foundtimedout, _, timedoutnick =
text:find("^%*%*%* ([^%s]+) left the game %(Timed out%)$")
local foundaction, _, actionnick, actionmessage = local foundaction, _, actionnick, actionmessage =
text:find("^%* ([^%s]+) (.*)$") text:find("^%* ([^%s]+) (.*)$")
@@ -136,9 +134,6 @@ function irc.hooks.channelChat(msg)
elseif foundleave then elseif foundleave then
irc.sendLocal(("*** %s left %s") irc.sendLocal(("*** %s left %s")
:format(leavenick, msg.user.nick)) :format(leavenick, msg.user.nick))
elseif foundtimedout then
irc.sendLocal(("*** %s left %s (Timed out)")
:format(timedoutnick, msg.user.nick))
elseif foundaction then elseif foundaction then
irc.sendLocal(("* %s@%s %s") irc.sendLocal(("* %s@%s %s")
:format(actionnick, msg.user.nick, actionmessage)) :format(actionnick, msg.user.nick, actionmessage))
@@ -171,7 +166,7 @@ end
function irc.hooks.notice(user, target, message) function irc.hooks.notice(user, target, message)
if user and user.nick and target == irc.config.channel then if user.nick and target == irc.config.channel then
irc.sendLocal("-"..user.nick.."@IRC- "..message) irc.sendLocal("-"..user.nick.."@IRC- "..message)
end end
end end

View File

@@ -29,8 +29,7 @@ if not rawget(_G, "jit") and package.config:sub(1, 1) == "/" then
";/usr/share/lua/5.1/?/init.lua" ";/usr/share/lua/5.1/?/init.lua"
ie.package.cpath = ie.package.cpath.. ie.package.cpath = ie.package.cpath..
";/usr/lib/lua/5.1/?.so".. ";/usr/lib/lua/5.1/?.so"
";/usr/lib64/lua/5.1/?.so"
ie.package.cpath = "/usr/lib/x86_64-linux-gnu/lua/5.1/?.so;"..ie.package.cpath ie.package.cpath = "/usr/lib/x86_64-linux-gnu/lua/5.1/?.so;"..ie.package.cpath
@@ -111,8 +110,7 @@ end
minetest.register_privilege("irc_admin", { minetest.register_privilege("irc_admin", {
description = "Allow IRC administrative tasks to be performed.", description = "Allow IRC administrative tasks to be performed.",
give_to_singleplayer = true, give_to_singleplayer = true
give_to_admin = true,
}) })
local stepnum = 0 local stepnum = 0
@@ -224,3 +222,4 @@ function irc.queue(msg)
irc.conn:queue(msg) irc.conn:queue(msg)
end end
minetest.log("action", "[irc] loaded.")

2
irc

Submodule irc updated: e49a52ede1...b8d594e651

View File

@@ -1,5 +1 @@
name = irc name = irc
description = """
This mod is just a glue between IRC and Minetest.
It provides two-way communication between the in-game chat, and an arbitrary IRC channel.
"""

View File

@@ -47,7 +47,7 @@ minetest.register_chatcommand("who", {
out[n] = plname out[n] = plname
end end
table.sort(out) table.sort(out)
return true, n.." player(s) in channel: "..table.concat(out, ", ") return true, "Players in channel: "..table.concat(out, ", ")
end end
}) })