Compare commits

...

37 commits

Author SHA1 Message Date
3a3003eff6 Add files to be tracked after Mercurial import. 2011-09-18 21:29:57 -04:00
5c9e38952e Added tag r60-beta for changeset d6af5da2e1ea 2011-08-12 19:11:38 -04:00
ed5089c103 Don't overwrite settings if joining an already joined channel. 2011-08-12 19:11:05 -04:00
0d2ad26892 Monitor all forms of chat changes instead of just slash commands. 2011-08-12 18:42:39 -04:00
76a3df5b2e Remove slash command. 2011-08-12 18:40:45 -04:00
a78df7bc99 Reverting to last release. 2011-08-12 18:38:52 -04:00
a663d6d8aa Added tag r55-beta for changeset 512ac2d65d2c 2011-08-09 06:16:46 -04:00
1a4f3b0f71 Remove random debug stuff. 2011-08-09 06:16:32 -04:00
a005f12194 Use CHANNEL_UI_UPDATE for rejoining channels as well as initial setup. 2011-08-09 06:10:10 -04:00
8d437e2f06 Attempt to use PLAYER_ALIVE for rejoining channels. 2011-08-09 06:00:52 -04:00
e34a237c84 Attempt to use CHANNEL_UI_UPDATE for initial setup. 2011-08-09 05:43:46 -04:00
7536a5e14d Remove hooked functions 2011-08-09 05:30:28 -04:00
5b1d50758d Remove slash command. 2011-08-09 05:27:56 -04:00
d8bb220987 Use CHAT_MSG_CHANNEL_NOTICE to handle channel information instead of hooking functions. 2011-08-09 05:27:31 -04:00
204d62bf9d Added tag r46-release for changeset 43639d15a889 2011-06-29 07:15:08 -04:00
61def6d36d Updating TOC file 2011-06-29 07:13:06 -04:00
44209c946a Added tag r44-beta for changeset c53d6817e699 2011-06-03 21:24:41 -04:00
61e66753a2 Do not attempt to process '/leave' with no message 2011-06-03 09:43:27 -04:00
3e27e26db1 Added tag r42-alpha for changeset dff165a50535 2011-06-03 08:53:57 -04:00
2bdea38132 Added missed variable scoping. 2011-06-03 08:49:37 -04:00
7d55d0ee93 Use GetChannelInfo() to setup initial database. 2011-06-03 08:28:09 -04:00
41f9cd47f3 Tying it all together: Use GetChannelInfo to decide if this channel needs stored when joining. 2011-06-03 07:33:09 -04:00
86a904b502 Typo fixes in new functions: NOY FUNCTIONAL 2011-06-03 05:53:45 -04:00
2dcf64b159 GetChannelInfo function to return number, name, and category of a channel: NOT TESTED 2011-06-03 05:42:15 -04:00
71036313e9 GetChannelTable fucntion to return a list of channels: NOT FUNCTIONAL 2011-06-03 04:56:12 -04:00
dcde240f24 Using GetChannelDisplayInfo() to check channel type; NOT FUNCTIONAL 2011-06-02 16:12:14 -04:00
9c2a744a87 Added tag r34-release for changeset c6373adcf295 2011-06-02 09:53:29 -04:00
034ef82eb2 Fixed silly debugging error 2011-06-02 09:51:18 -04:00
fee07b3a37 Added tag v1.1-release for changeset 50f6183ae551 2011-06-02 08:39:47 -04:00
7892099ef0 Sort saved channels by index before joining 2011-06-02 04:53:40 -04:00
46a0d47d35 Reverting to hooking slash commands instead of event. 2011-06-02 04:37:29 -04:00
db153fe08a Reverted back to version hooking slash commands instead of events for managing stored data. 2011-06-02 04:32:58 -04:00
304dcd0fdc Added sorting by index to attempt to join in the same order. 2011-06-02 00:52:46 -04:00
aa65c554a3 Use CHAT_MSG_CHANNEL_NOTICE instead of hooking join and leave slash functions for stored channels 2011-06-01 14:25:42 -04:00
0b51f257ed Added tag v1.0a-release for changeset ed22c2b79ca1 2011-05-29 11:27:09 -04:00
56cc3d6191 Fixed LUA error in SetupChatServer. Fixes #1 2011-05-29 11:26:59 -04:00
3ec2840580 Added tag v1.0-release for changeset 26f2a6d4de58 2011-05-29 06:48:37 -04:00
3 changed files with 77 additions and 34 deletions

View file

@ -2,8 +2,6 @@ ChatSaver = LibStub('AceAddon-3.0'):NewAddon('ChatSaver','AceConsole-3.0','AceHo
local core = ChatSaver;
function core:OnInitialize()
self:RegisterChatCommand('cs','SlashCommand');
if(ChatSaverDB == nil) then
core.firstrun = true;
ChatSaverDB = {};
@ -13,8 +11,6 @@ function core:OnInitialize()
end
function core:OnEnable()
self:RawHook(SlashCmdList,'JOIN','JoinChannel',true);
self:RawHook(SlashCmdList,'LEAVE','LeaveChannel',true);
self:Hook('ToggleChatChannel','ToggleChatChannel',true);
self:RegisterEvent('CHANNEL_UI_UPDATE','RejoinChannels');
@ -23,8 +19,68 @@ function core:OnEnable()
end
end
function core:SlashCommand()
core:RejoinChannels();
--[[
-- CHANNEL FUNCTIONS
-- Because GetChannelName() and GetChannelDisplayInfo() are less
-- than good.
]] --
function core:GetChannelInfo(id)
local channelNumber,channelName = GetChannelName(id);
local channelTable = core:GetChannelTable();
if(channelName == nil) then
id = channelTable[id];
if(id ~= nil) then
channelNumber,channelName = GetChannelName(id);
end
end
return channelNumber,channelName,core:GetChannelCategory(channelNumber);
end
function core:GetChannelTable()
local channelList = { GetChannelList() };
local channelTable = {};
for i = 1,#channelList,2 do
channelTable[channelList[i]] = channelList[i + 1];
channelTable[channelList[i + 1]] = channelList[i];
if(type(channelList[i + 1]) == 'string') then
channelTable[channelList[i + 1]:lower()] = channelList[i];
end
end
return channelTable;
end
function core:GetChannelCategory(number)
for i = 1,GetNumDisplayChannels(),1 do
local _,_,_,channelNumber,_,_,category = GetChannelDisplayInfo(i);
if(channelNumber == number) then
return category;
end
end
end
--[[ EVENT FUNCTIONS ]] --
function core:ProcessChannelChange(_,message,_,_,_,_,_,_,index,name)
if message == 'YOU_JOINED' then
local number,_,category = core:GetChannelInfo(name)
if category == 'CHANNEL_CATEGORY_CUSTOM' then
if ChatSaverDB[name] == nil then
ChatSaverDB[name] = {}
ChatSaverDB[name]['frames'] = {}
ChatSaverDB[name]['index'] = number
ChatSaverDB[name]['frames'][DEFAULT_CHAT_FRAME:GetID()] = true
end
end
elseif message == 'YOU_LEFT' then
ChatSaverDB[name] = nil
end
end
function core:RejoinChannels(...)
@ -33,7 +89,13 @@ function core:RejoinChannels(...)
currentChannels[select(i,GetChannelList())] = true
end
local sortedChannels = {};
for channel,_ in pairs(ChatSaverDB) do
table.insert(sortedChannels,channel);
end
table.sort(sortedChannels,function(a,b) return ChatSaverDB[a].index < ChatSaverDB[b].index end);
for _,channel in pairs(sortedChannels) do
if(currentChannels[channel] == nil) then
JoinPermanentChannel(channel); -- does not place in chat frame properly
for index,_ in pairs(ChatSaverDB[channel].frames) do
@ -43,20 +105,20 @@ function core:RejoinChannels(...)
end
self:UnregisterEvent('CHANNEL_UI_UPDATE');
self:RegisterEvent('CHAT_MSG_CHANNEL_NOTICE','ProcessChannelChange')
end
function core:SetupChatSaver(...)
local chatWindowChannels = { GetChatWindowChannels(frame) };
for frame = 1,NUM_CHAT_WINDOWS do
local chatWindowChannels = { GetChatWindowChannels(frame) };
for i = 1,#chatWindowChannels,2 do
local name,zone = chatWindowChannels[i], chatWindowChannels[i + 1];
local number,name,category = core:GetChannelInfo(chatWindowChannels[i]);
if(zone == 0) then
if(category == 'CHANNEL_CATEGORY_CUSTOM') then
if(ChatSaverDB[name] == nil) then
ChatSaverDB[name] = {};
ChatSaverDB[name]['frames'] = {};
ChatSaverDB[name]['index'] = GetChannelName(name);
ChatSaverDB[name]['index'] = number;
end
ChatSaverDB[name]['frames'][frame] = true;
@ -65,29 +127,10 @@ function core:SetupChatSaver(...)
end
self:UnregisterEvent('CHAT_MSG_CHANNEL_NOTICE');
self:RegisterEvent('CHAT_MSG_CHANNEL_NOTICE','ProcessChannelChange')
end
function core:JoinChannel(msg)
self.hooks[SlashCmdList].JOIN(msg);
local name = gsub(msg, "%s*([^%s]+).*", "%1");
if(strlen(name) > 0 and string.match(name,"%a+")) then
ChatSaverDB[name] = {};
ChatSaverDB[name]['frames'] = {};
ChatSaverDB[name]['index'] = GetChannelName(name);
ChatSaverDB[name]['frames'][DEFAULT_CHAT_FRAME:GetID()] = true;
end
end
function core:LeaveChannel(msg)
self.hooks[SlashCmdList].LEAVE(msg);
local number = gsub(msg, "%s*([^%s]+).*", "%1");
local _,name = GetChannelName(number);
ChatSaverDB[name] = nil;
end
--[[ HOOKED FUNCTIONS ]] --
function core:ToggleChatChannel(checked,channel)
if(ChatSaverDB[channel] == nil) then

View file

@ -1,4 +1,4 @@
## Interface: 40100
## Interface: 42000
## Title: ChatSaver
## Version: @project-version@
## Author: Gaffer

0
README Normal file
View file