Mercurial > wow > askmrrobot
comparison Libs/AceComm-3.0/AceComm-3.0.lua @ 124:e31b02b24488
Updated for 8.0 pre-patch and BfA.
author | yellowfive |
---|---|
date | Tue, 17 Jul 2018 09:57:39 -0700 |
parents | 01b63b8ed811 |
children |
comparison
equal
deleted
inserted
replaced
123:7a6364917f86 | 124:e31b02b24488 |
---|---|
7 -- and can be accessed directly, without having to explicitly call AceComm itself.\\ | 7 -- and can be accessed directly, without having to explicitly call AceComm itself.\\ |
8 -- It is recommended to embed AceComm, otherwise you'll have to specify a custom `self` on all calls you | 8 -- It is recommended to embed AceComm, otherwise you'll have to specify a custom `self` on all calls you |
9 -- make into AceComm. | 9 -- make into AceComm. |
10 -- @class file | 10 -- @class file |
11 -- @name AceComm-3.0 | 11 -- @name AceComm-3.0 |
12 -- @release $Id: AceComm-3.0.lua 1107 2014-02-19 16:40:32Z nevcairiel $ | 12 -- @release $Id: AceComm-3.0.lua 1174 2018-05-14 17:29:49Z h.leppkes@gmail.com $ |
13 | 13 |
14 --[[ AceComm-3.0 | 14 --[[ AceComm-3.0 |
15 | 15 |
16 TODO: Time out old data rotting around from dead senders? Not a HUGE deal since the number of possible sender names is somewhat limited. | 16 TODO: Time out old data rotting around from dead senders? Not a HUGE deal since the number of possible sender names is somewhat limited. |
17 | 17 |
18 ]] | 18 ]] |
19 | 19 |
20 local MAJOR, MINOR = "AceComm-3.0", 9 | 20 local CallbackHandler = LibStub("CallbackHandler-1.0") |
21 | 21 local CTL = assert(ChatThrottleLib, "AceComm-3.0 requires ChatThrottleLib") |
22 | |
23 local MAJOR, MINOR = "AceComm-3.0", 12 | |
22 local AceComm,oldminor = LibStub:NewLibrary(MAJOR, MINOR) | 24 local AceComm,oldminor = LibStub:NewLibrary(MAJOR, MINOR) |
23 | 25 |
24 if not AceComm then return end | 26 if not AceComm then return end |
25 | |
26 local CallbackHandler = LibStub:GetLibrary("CallbackHandler-1.0") | |
27 local CTL = assert(ChatThrottleLib, "AceComm-3.0 requires ChatThrottleLib") | |
28 | 27 |
29 -- Lua APIs | 28 -- Lua APIs |
30 local type, next, pairs, tostring = type, next, pairs, tostring | 29 local type, next, pairs, tostring = type, next, pairs, tostring |
31 local strsub, strfind = string.sub, string.find | 30 local strsub, strfind = string.sub, string.find |
32 local match = string.match | 31 local match = string.match |
64 end | 63 end |
65 | 64 |
66 if #prefix > 16 then -- TODO: 15? | 65 if #prefix > 16 then -- TODO: 15? |
67 error("AceComm:RegisterComm(prefix,method): prefix length is limited to 16 characters") | 66 error("AceComm:RegisterComm(prefix,method): prefix length is limited to 16 characters") |
68 end | 67 end |
69 RegisterAddonMessagePrefix(prefix) | 68 if C_ChatInfo then |
69 C_ChatInfo.RegisterAddonMessagePrefix(prefix) | |
70 else | |
71 RegisterAddonMessagePrefix(prefix) | |
72 end | |
70 | 73 |
71 return AceComm._RegisterComm(self, prefix, method) -- created by CallbackHandler | 74 return AceComm._RegisterComm(self, prefix, method) -- created by CallbackHandler |
72 end | 75 end |
73 | 76 |
74 local warnedPrefix=false | 77 local warnedPrefix=false |
84 function AceComm:SendCommMessage(prefix, text, distribution, target, prio, callbackFn, callbackArg) | 87 function AceComm:SendCommMessage(prefix, text, distribution, target, prio, callbackFn, callbackArg) |
85 prio = prio or "NORMAL" -- pasta's reference implementation had different prio for singlepart and multipart, but that's a very bad idea since that can easily lead to out-of-sequence delivery! | 88 prio = prio or "NORMAL" -- pasta's reference implementation had different prio for singlepart and multipart, but that's a very bad idea since that can easily lead to out-of-sequence delivery! |
86 if not( type(prefix)=="string" and | 89 if not( type(prefix)=="string" and |
87 type(text)=="string" and | 90 type(text)=="string" and |
88 type(distribution)=="string" and | 91 type(distribution)=="string" and |
89 (target==nil or type(target)=="string") and | 92 (target==nil or type(target)=="string" or type(target)=="number") and |
90 (prio=="BULK" or prio=="NORMAL" or prio=="ALERT") | 93 (prio=="BULK" or prio=="NORMAL" or prio=="ALERT") |
91 ) then | 94 ) then |
92 error('Usage: SendCommMessage(addon, "prefix", "text", "distribution"[, "target"[, "prio"[, callbackFn, callbackarg]]])', 2) | 95 error('Usage: SendCommMessage(addon, "prefix", "text", "distribution"[, "target"[, "prio"[, callbackFn, callbackarg]]])', 2) |
93 end | 96 end |
94 | 97 |