summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/NewsAggregator/Src/CheckFeed.cpp4
-rw-r--r--protocols/NewsAggregator/Src/FeedEditor.cpp64
-rw-r--r--protocols/NewsAggregator/Src/Menus.cpp29
-rw-r--r--protocols/NewsAggregator/Src/NewsAggregator.cpp3
-rw-r--r--protocols/NewsAggregator/Src/Options.cpp62
-rw-r--r--protocols/NewsAggregator/Src/Services.cpp42
-rw-r--r--protocols/NewsAggregator/Src/stdafx.h92
7 files changed, 151 insertions, 145 deletions
diff --git a/protocols/NewsAggregator/Src/CheckFeed.cpp b/protocols/NewsAggregator/Src/CheckFeed.cpp
index e5a545ba6b..81413749b9 100644
--- a/protocols/NewsAggregator/Src/CheckFeed.cpp
+++ b/protocols/NewsAggregator/Src/CheckFeed.cpp
@@ -159,7 +159,7 @@ static void XmlToMsg(MCONTACT hContact, CMStringW &title, CMStringW &link, CMStr
DBEVENTINFO olddbei = {};
bool MesExist = false;
T2Utf pszTemp(message);
- uint32_t cbMemoLen = 10000, cbOrigLen = (uint32_t)mir_strlen(pszTemp);
+ int cbMemoLen = 10000, cbOrigLen = (uint32_t)mir_strlen(pszTemp);
uint8_t *pbBuffer = (uint8_t*)mir_alloc(cbMemoLen);
DB::ECPTR pCursor(DB::EventsRev(hContact));
@@ -174,7 +174,7 @@ static void XmlToMsg(MCONTACT hContact, CMStringW &title, CMStringW &link, CMStr
if (stamp > 0 && olddbei.timestamp < (uint32_t)stamp)
break;
- if ((uint32_t)mir_strlen((char*)olddbei.pBlob) == cbOrigLen && !mir_strcmp((char*)olddbei.pBlob, pszTemp)) {
+ if ((int)mir_strlen((char*)olddbei.pBlob) == cbOrigLen && !mir_strcmp((char*)olddbei.pBlob, pszTemp)) {
MesExist = true;
break;
}
diff --git a/protocols/NewsAggregator/Src/FeedEditor.cpp b/protocols/NewsAggregator/Src/FeedEditor.cpp
index bcf6c3535f..74233edba6 100644
--- a/protocols/NewsAggregator/Src/FeedEditor.cpp
+++ b/protocols/NewsAggregator/Src/FeedEditor.cpp
@@ -17,7 +17,13 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#include "stdafx.h"
-CFeedEditor::CFeedEditor(int iItem, CCtrlListView *m_feeds, MCONTACT Contact) :
+static CDlgBase *pAddFeedDialog = nullptr;
+
+static LIST<class CFeedEditor> g_arFeeds(1, PtrKeySortT);
+
+/////////////////////////////////////////////////////////////////////////////////////////
+
+CFeedEditor::CFeedEditor(int iItem, CCtrlListView *feeds, MCONTACT Contact) :
CSuper(g_plugin, IDD_ADDFEED),
m_feedtitle(this, IDC_FEEDTITLE), m_feedurl(this, IDC_FEEDURL),
m_checktime(this, IDC_CHECKTIME), m_checktimespin(this, IDC_TIMEOUT_VALUE_SPIN, 999),
@@ -27,12 +33,15 @@ CFeedEditor::CFeedEditor(int iItem, CCtrlListView *m_feeds, MCONTACT Contact) :
m_help(this, IDC_TAGHELP),
m_iItem(iItem)
{
- m_list = m_feeds;
+ m_list = feeds;
m_hContact = Contact;
m_checkfeed.OnClick = Callback(this, &CFeedEditor::OnCheckFeed);
m_useauth.OnChange = Callback(this, &CFeedEditor::OnUseAuth);
m_reset.OnClick = Callback(this, &CFeedEditor::OnReset);
m_help.OnClick = Callback(this, &CFeedEditor::OnHelp);
+
+ if (feeds)
+ SetParent(feeds->GetParent()->GetHwnd());
}
bool CFeedEditor::OnInitDialog()
@@ -225,3 +234,54 @@ void CFeedEditor::OnUseAuth(CCtrlBase*)
m_login.Enable(m_useauth.GetState());
m_password.Enable(m_useauth.GetState());
}
+
+/////////////////////////////////////////////////////////////////////////////////////////
+// Module entry point
+
+INT_PTR AddFeed(WPARAM, LPARAM lParam)
+{
+ if (pAddFeedDialog == nullptr) {
+ pAddFeedDialog = new CFeedEditor(-1, (CCtrlListView *)lParam, NULL);
+ pAddFeedDialog->Show();
+ }
+ else {
+ SetForegroundWindow(pAddFeedDialog->GetHwnd());
+ SetFocus(pAddFeedDialog->GetHwnd());
+ }
+ return 0;
+}
+
+INT_PTR ChangeFeed(WPARAM hContact, LPARAM)
+{
+ CFeedEditor *pDlg = nullptr;
+ for (auto &it : g_arFeeds)
+ if (it->getContact() == hContact)
+ pDlg = it;
+
+ if (pDlg == nullptr) {
+ pDlg = new CFeedEditor(-1, nullptr, hContact);
+ pDlg->Show();
+ }
+ else {
+ SetForegroundWindow(pDlg->GetHwnd());
+ SetFocus(pDlg->GetHwnd());
+ }
+ return 0;
+}
+
+CDlgBase* FindFeedEditor(const wchar_t *pwszNick, const wchar_t *pwszUrl)
+{
+ for (auto &it : g_arFeeds) {
+ ptrW dbNick(g_plugin.getWStringA(it->getContact(), "Nick"));
+ if (dbNick == nullptr || mir_wstrcmp(dbNick, pwszNick))
+ continue;
+
+ ptrW dbURL(g_plugin.getWStringA(it->getContact(), "URL"));
+ if (dbURL == nullptr || (mir_wstrcmp(dbURL, pwszUrl) != 0))
+ continue;
+
+ return it;
+ }
+
+ return nullptr;
+}
diff --git a/protocols/NewsAggregator/Src/Menus.cpp b/protocols/NewsAggregator/Src/Menus.cpp
index 16bd7163ef..d682415e4a 100644
--- a/protocols/NewsAggregator/Src/Menus.cpp
+++ b/protocols/NewsAggregator/Src/Menus.cpp
@@ -19,7 +19,7 @@ Boston, MA 02111-1307, USA.
#include "stdafx.h"
-HGENMENU hService2[7];
+HGENMENU hmiAutoUpdate;
void InitMenu()
{
@@ -36,34 +36,34 @@ void InitMenu()
mi.name.w = LPGENW("Auto Update Disabled");
mi.hIcolibItem = g_plugin.getIconHandle(IDI_ICON);
mi.pszService = MS_NEWSAGGREGATOR_ENABLED;
- hService2[0] = Menu_AddMainMenuItem(&mi);
+ hmiAutoUpdate = Menu_AddMainMenuItem(&mi);
SET_UID(mi, 0x8076bb4d, 0x1e44, 0x43af, 0x97, 0x1e, 0x31, 0xd8, 0xa4, 0xe9, 0xb8, 0x37);
mi.position = 20100001;
mi.name.w = LPGENW("Check All Feeds");
mi.pszService = MS_NEWSAGGREGATOR_CHECKALLFEEDS;
- hService2[1] = Menu_AddMainMenuItem(&mi);
+ Menu_AddMainMenuItem(&mi);
SET_UID(mi, 0xb876484d, 0x28aa, 0x4e03, 0x9e, 0x98, 0xed, 0xbc, 0xd1, 0xcf, 0x31, 0x80);
mi.position = 20100002;
mi.hIcolibItem = g_plugin.getIconHandle(IDI_ADDFEED);
mi.name.w = LPGENW("Add Feed");
mi.pszService = MS_NEWSAGGREGATOR_ADDFEED;
- hService2[2] = Menu_AddMainMenuItem(&mi);
+ Menu_AddMainMenuItem(&mi);
SET_UID(mi, 0x600bf2c2, 0xa974, 0x44d3, 0x98, 0xf9, 0xe6, 0x65, 0x7c, 0x1f, 0x63, 0x37);
mi.position = 20100003;
mi.hIcolibItem = g_plugin.getIconHandle(IDI_IMPORTFEEDS);
mi.name.w = LPGENW("Import Feeds");
mi.pszService = MS_NEWSAGGREGATOR_IMPORTFEEDS;
- hService2[3] = Menu_AddMainMenuItem(&mi);
+ Menu_AddMainMenuItem(&mi);
SET_UID(mi, 0xc09c8119, 0x64c2, 0x49bd, 0x81, 0xf, 0x54, 0x20, 0x69, 0xd7, 0x30, 0xcf);
mi.position = 20100004;
mi.hIcolibItem = g_plugin.getIconHandle(IDI_EXPORTFEEDS);
mi.name.w = LPGENW("Export Feeds");
mi.pszService = MS_NEWSAGGREGATOR_EXPORTFEEDS;
- hService2[4] = Menu_AddMainMenuItem(&mi);
+ Menu_AddMainMenuItem(&mi);
// adding contact menu items
SET_UID(mi, 0x92be499c, 0x928c, 0x4789, 0x8f, 0x36, 0x28, 0xa2, 0x9f, 0xb7, 0x1a, 0x97);
@@ -72,12 +72,23 @@ void InitMenu()
mi.hIcolibItem = g_plugin.getIconHandle(IDI_CHECKFEED);
mi.name.w = LPGENW("Check feed");
mi.pszService = MS_NEWSAGGREGATOR_CHECKFEED;
- hService2[5] = Menu_AddContactMenuItem(&mi, MODULENAME);
+ Menu_AddContactMenuItem(&mi, MODULENAME);
SET_UID(mi, 0x41a70fbc, 0x9241, 0x44c0, 0x90, 0x90, 0x87, 0xd2, 0xc5, 0x9f, 0xc9, 0xac);
mi.name.w = LPGENW("Change feed");
mi.pszService = MS_NEWSAGGREGATOR_CHANGEFEED;
- hService2[6] = Menu_AddContactMenuItem(&mi, MODULENAME);
+ Menu_AddContactMenuItem(&mi, MODULENAME);
- Menu_ModifyItem(hService2[0], nullptr, g_plugin.getIconHandle(g_plugin.getByte("AutoUpdate", 1) ? IDI_ENABLED : IDI_DISABLED));
+ Menu_ModifyItem(hmiAutoUpdate, nullptr, g_plugin.getIconHandle(g_plugin.getByte("AutoUpdate", 1) ? IDI_ENABLED : IDI_DISABLED));
+}
+
+void UpdateMenu(bool State)
+{
+ if (!State) // to enable auto-update
+ Menu_ModifyItem(hmiAutoUpdate, LPGENW("Auto Update Enabled"), g_plugin.getIconHandle(IDI_ENABLED));
+ else // to disable auto-update
+ Menu_ModifyItem(hmiAutoUpdate, LPGENW("Auto Update Disabled"), g_plugin.getIconHandle(IDI_DISABLED));
+
+ CallService(MS_TTB_SETBUTTONSTATE, (WPARAM)hTBButton, State ? TTBST_PUSHED : 0);
+ g_plugin.setByte("AutoUpdate", !State);
}
diff --git a/protocols/NewsAggregator/Src/NewsAggregator.cpp b/protocols/NewsAggregator/Src/NewsAggregator.cpp
index e98bb66ae9..420cbd9ec6 100644
--- a/protocols/NewsAggregator/Src/NewsAggregator.cpp
+++ b/protocols/NewsAggregator/Src/NewsAggregator.cpp
@@ -20,12 +20,9 @@ Boston, MA 02111-1307, USA.
#include "stdafx.h"
HANDLE hPrebuildMenuHook = nullptr;
-CDlgBase *pAddFeedDialog = nullptr;
wchar_t tszRoot[MAX_PATH] = {0};
HANDLE hUpdateMutex;
-LIST<CFeedEditor> g_arFeeds(1, PtrKeySortT);
-
CMPlugin g_plugin;
/////////////////////////////////////////////////////////////////////////////////////////
diff --git a/protocols/NewsAggregator/Src/Options.cpp b/protocols/NewsAggregator/Src/Options.cpp
index 763f09dd9f..4caf6ce6eb 100644
--- a/protocols/NewsAggregator/Src/Options.cpp
+++ b/protocols/NewsAggregator/Src/Options.cpp
@@ -42,14 +42,14 @@ public:
{
CreateLink(m_checkonstartup, "StartupRetrieve", DBVT_BYTE, 1);
- m_add.OnClick = Callback(this, &COptionsMain::OnAddButtonClick);
- m_change.OnClick = Callback(this, &COptionsMain::OnChangeButtonClick);
- m_delete.OnClick = Callback(this, &COptionsMain::OnDeleteButtonClick);
- m_import.OnClick = Callback(this, &COptionsMain::OnImportButtonClick);
- m_export.OnClick = Callback(this, &COptionsMain::OnExportButtonClick);
-
- m_feeds.OnItemChanged = Callback(this, &COptionsMain::OnFeedListItemChanged);
- m_feeds.OnDoubleClick = Callback(this, &COptionsMain::OnFeedListDoubleClick);
+ m_add.OnClick = Callback(this, &COptionsMain::onClick_Add);
+ m_change.OnClick = Callback(this, &COptionsMain::onClick_Change);
+ m_delete.OnClick = Callback(this, &COptionsMain::onClick_Delete);
+ m_import.OnClick = Callback(this, &COptionsMain::onClick_Import);
+ m_export.OnClick = Callback(this, &COptionsMain::onClick_Export);
+
+ m_feeds.OnItemChanged = Callback(this, &COptionsMain::ontItemChanged_Feeds);
+ m_feeds.OnDoubleClick = Callback(this, &COptionsMain::onDoubleClick_Feeds);
}
bool OnInitDialog() override
@@ -83,42 +83,21 @@ public:
return true;
}
- void OnAddButtonClick(CCtrlBase *)
+ void onClick_Add(CCtrlBase *)
{
- if (pAddFeedDialog == nullptr) {
- pAddFeedDialog = new CFeedEditor(-1, &m_feeds, NULL);
- pAddFeedDialog->SetParent(m_hwnd);
- pAddFeedDialog->Show();
- }
- else {
- SetForegroundWindow(pAddFeedDialog->GetHwnd());
- SetFocus(pAddFeedDialog->GetHwnd());
- }
+ AddFeed(0, LPARAM(&m_feeds));
}
- void OnChangeButtonClick(CCtrlBase *)
+ void onClick_Change(CCtrlBase *)
{
int isel = m_feeds.GetSelectionMark();
- CFeedEditor *pDlg = nullptr;
- for (auto &it : g_arFeeds) {
- wchar_t nick[MAX_PATH], url[MAX_PATH];
- m_feeds.GetItemText(isel, 0, nick, _countof(nick));
- m_feeds.GetItemText(isel, 1, url, _countof(url));
-
- ptrW dbNick(g_plugin.getWStringA(it->getContact(), "Nick"));
- if ((dbNick == NULL) || (mir_wstrcmp(dbNick, nick) != 0))
- continue;
-
- ptrW dbURL(g_plugin.getWStringA(it->getContact(), "URL"));
- if ((dbURL == NULL) || (mir_wstrcmp(dbURL, url) != 0))
- continue;
-
- pDlg = it;
- }
+ wchar_t nick[MAX_PATH], url[MAX_PATH];
+ m_feeds.GetItemText(isel, 0, nick, _countof(nick));
+ m_feeds.GetItemText(isel, 1, url, _countof(url));
+ auto *pDlg = FindFeedEditor(nick, url);
if (pDlg == nullptr) {
pDlg = new CFeedEditor(isel, &m_feeds, NULL);
- pDlg->SetParent(m_hwnd);
pDlg->Show();
}
else {
@@ -127,7 +106,7 @@ public:
}
}
- void OnDeleteButtonClick(CCtrlBase *)
+ void onClick_Delete(CCtrlBase *)
{
if (MessageBox(m_hwnd, TranslateT("Are you sure?"), TranslateT("Contact deleting"), MB_YESNO | MB_ICONWARNING) == IDYES) {
wchar_t nick[MAX_PATH], url[MAX_PATH];
@@ -155,17 +134,17 @@ public:
}
}
- void OnImportButtonClick(CCtrlBase *)
+ void onClick_Import(CCtrlBase *)
{
ImportFeeds(WPARAM(m_hwnd), 0);
}
- void OnExportButtonClick(CCtrlBase *)
+ void onClick_Export(CCtrlBase *)
{
ExportFeeds(WPARAM(m_hwnd), 0);
}
- void OnFeedListItemChanged(CCtrlListView::TEventInfo *evt)
+ void ontItemChanged_Feeds(CCtrlListView::TEventInfo *evt)
{
int isel = m_feeds.GetSelectionMark();
if (isel == -1) {
@@ -180,12 +159,11 @@ public:
NotifyChange();
}
- void OnFeedListDoubleClick(CCtrlBase *)
+ void onDoubleClick_Feeds(CCtrlBase *)
{
int isel = m_feeds.GetHotItem();
if (isel != -1) {
CFeedEditor *pDlg = new CFeedEditor(isel, &m_feeds, 0);
- pDlg->SetParent(m_hwnd);
pDlg->Show();
}
}
diff --git a/protocols/NewsAggregator/Src/Services.cpp b/protocols/NewsAggregator/Src/Services.cpp
index 138f334005..aa1005d285 100644
--- a/protocols/NewsAggregator/Src/Services.cpp
+++ b/protocols/NewsAggregator/Src/Services.cpp
@@ -138,37 +138,6 @@ INT_PTR CheckAllFeeds(WPARAM, LPARAM lParam)
return 0;
}
-INT_PTR AddFeed(WPARAM, LPARAM)
-{
- if (pAddFeedDialog == nullptr) {
- pAddFeedDialog = new CFeedEditor(-1, nullptr, NULL);
- pAddFeedDialog->Show();
- }
- else {
- SetForegroundWindow(pAddFeedDialog->GetHwnd());
- SetFocus(pAddFeedDialog->GetHwnd());
- }
- return 0;
-}
-
-INT_PTR ChangeFeed(WPARAM hContact, LPARAM)
-{
- CFeedEditor *pDlg = nullptr;
- for (auto &it : g_arFeeds)
- if (it->getContact() == hContact)
- pDlg = it;
-
- if (pDlg == nullptr) {
- pDlg = new CFeedEditor(-1, nullptr, (MCONTACT)hContact);
- pDlg->Show();
- }
- else {
- SetForegroundWindow(pDlg->GetHwnd());
- SetFocus(pDlg->GetHwnd());
- }
- return 0;
-}
-
INT_PTR CheckFeed(WPARAM hContact, LPARAM)
{
if(IsMyContact((MCONTACT)hContact))
@@ -206,17 +175,6 @@ INT_PTR NewsAggrRecvMessage(WPARAM, LPARAM lParam)
return 0;
}
-void UpdateMenu(bool State)
-{
- if (!State) // to enable auto-update
- Menu_ModifyItem(hService2[0], LPGENW("Auto Update Enabled"), g_plugin.getIconHandle(IDI_ENABLED));
- else // to disable auto-update
- Menu_ModifyItem(hService2[0], LPGENW("Auto Update Disabled"), g_plugin.getIconHandle(IDI_DISABLED));
-
- CallService(MS_TTB_SETBUTTONSTATE, (WPARAM)hTBButton, State ? TTBST_PUSHED : 0);
- g_plugin.setByte("AutoUpdate", !State);
-}
-
// update the newsaggregator auto-update menu item when click on it
INT_PTR EnableDisable(WPARAM, LPARAM)
{
diff --git a/protocols/NewsAggregator/Src/stdafx.h b/protocols/NewsAggregator/Src/stdafx.h
index 5432743fc8..388f83ade2 100644
--- a/protocols/NewsAggregator/Src/stdafx.h
+++ b/protocols/NewsAggregator/Src/stdafx.h
@@ -58,10 +58,10 @@ Boston, MA 02111-1307, USA.
#define DEFAULT_AVATARS_FOLDER "NewsAggregator"
#define DEFAULT_UPDATE_TIME 60
-extern CDlgBase *pAddFeedDialog;
extern HNETLIBUSER hNetlibUser;
+extern HANDLE hTBButton;
extern UINT_PTR timerId;
-extern LIST<CFeedEditor> g_arFeeds;
+
// check if Feeds is currently updating
extern bool ThreadRunning;
extern bool UpdateListFlag;
@@ -91,49 +91,51 @@ void UpdateListAdd(MCONTACT hContact);
void UpdateThreadProc(void*);
void DestroyUpdateList(void);
-extern HANDLE hUpdateMutex;
-extern HGENMENU hService2[7];
-
-int NewsAggrInit(WPARAM wParam,LPARAM lParam);
-int OptInit(WPARAM wParam, LPARAM lParam);
-int NewsAggrPreShutdown(WPARAM wParam,LPARAM lParam);
-void NetlibInit();
-void NetlibUnInit();
-void InitMenu();
-void InitIcons();
-
-INT_PTR NewsAggrGetName(WPARAM wParam, LPARAM lParam);
-INT_PTR NewsAggrGetCaps(WPARAM wp, LPARAM lp);
-INT_PTR NewsAggrSetStatus(WPARAM wp, LPARAM /*lp*/);
-INT_PTR NewsAggrGetStatus(WPARAM/* wp*/, LPARAM/* lp*/);
-INT_PTR NewsAggrLoadIcon(WPARAM wParam, LPARAM lParam);
-INT_PTR NewsAggrGetInfo(WPARAM wParam, LPARAM lParam);
-INT_PTR NewsAggrGetAvatarInfo(WPARAM wParam, LPARAM lParam);
-INT_PTR NewsAggrRecvMessage(WPARAM wParam, LPARAM lParam);
-
-INT_PTR CheckAllFeeds(WPARAM wParam, LPARAM lParam);
-INT_PTR AddFeed(WPARAM wParam, LPARAM lParam);
-INT_PTR ChangeFeed(WPARAM wParam, LPARAM lParam);
-INT_PTR ImportFeeds(WPARAM wParam, LPARAM lParam);
-INT_PTR ExportFeeds(WPARAM wParam, LPARAM lParam);
-INT_PTR CheckFeed(WPARAM wParam, LPARAM lParam);
-INT_PTR EnableDisable(WPARAM wParam, LPARAM lParam);
-int OnToolbarLoaded(WPARAM wParam, LPARAM lParam);
-void CALLBACK timerProc(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime);
-void CALLBACK timerProc2(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime);
-
-bool IsMyContact(MCONTACT hContact);
-void GetNewsData(wchar_t *szUrl, char **szData, MCONTACT hContact, CFeedEditor *pEditDlg);
-time_t DateToUnixTime(const char *stamp, bool FeedType);
-void CheckCurrentFeed(MCONTACT hContact);
-void CheckCurrentFeedAvatar(MCONTACT hContact);
-LPCTSTR CheckFeed(wchar_t* tszURL, CFeedEditor *pEditDlg);
-void UpdateMenu(bool State);
-LPCTSTR ClearText(CMStringW &value, const wchar_t *message);
-bool DownloadFile(LPCTSTR tszURL, LPCTSTR tszLocal);
-void CreateAuthString(char *auth, MCONTACT hContact, CFeedEditor *pDlg);
-MCONTACT GetContactByNick(const wchar_t *nick);
-MCONTACT GetContactByURL(const wchar_t *url);
+extern HANDLE hUpdateMutex;
+
+int NewsAggrInit(WPARAM wParam,LPARAM lParam);
+int OptInit(WPARAM wParam, LPARAM lParam);
+int NewsAggrPreShutdown(WPARAM wParam,LPARAM lParam);
+void NetlibInit();
+void NetlibUnInit();
+void InitMenu();
+void InitIcons();
+
+INT_PTR NewsAggrGetName(WPARAM wParam, LPARAM lParam);
+INT_PTR NewsAggrGetCaps(WPARAM wp, LPARAM lp);
+INT_PTR NewsAggrSetStatus(WPARAM wp, LPARAM /*lp*/);
+INT_PTR NewsAggrGetStatus(WPARAM/* wp*/, LPARAM/* lp*/);
+INT_PTR NewsAggrLoadIcon(WPARAM wParam, LPARAM lParam);
+INT_PTR NewsAggrGetInfo(WPARAM wParam, LPARAM lParam);
+INT_PTR NewsAggrGetAvatarInfo(WPARAM wParam, LPARAM lParam);
+INT_PTR NewsAggrRecvMessage(WPARAM wParam, LPARAM lParam);
+
+INT_PTR CheckAllFeeds(WPARAM wParam, LPARAM lParam);
+INT_PTR AddFeed(WPARAM wParam, LPARAM lParam);
+INT_PTR ChangeFeed(WPARAM wParam, LPARAM lParam);
+INT_PTR ImportFeeds(WPARAM wParam, LPARAM lParam);
+INT_PTR ExportFeeds(WPARAM wParam, LPARAM lParam);
+INT_PTR CheckFeed(WPARAM wParam, LPARAM lParam);
+INT_PTR EnableDisable(WPARAM wParam, LPARAM lParam);
+int OnToolbarLoaded(WPARAM wParam, LPARAM lParam);
+CDlgBase* FindFeedEditor(const wchar_t *pwszNick, const wchar_t *pwszUrl);
+
+bool IsMyContact(MCONTACT hContact);
+void GetNewsData(wchar_t *szUrl, char **szData, MCONTACT hContact, CFeedEditor *pEditDlg);
+time_t DateToUnixTime(const char *stamp, bool FeedType);
+void CheckCurrentFeed(MCONTACT hContact);
+void CheckCurrentFeedAvatar(MCONTACT hContact);
+LPCTSTR CheckFeed(wchar_t* tszURL, CFeedEditor *pEditDlg);
+void UpdateMenu(bool State);
+LPCTSTR ClearText(CMStringW &value, const wchar_t *message);
+bool DownloadFile(LPCTSTR tszURL, LPCTSTR tszLocal);
+void CreateAuthString(char *auth, MCONTACT hContact, CFeedEditor *pDlg);
+MCONTACT GetContactByNick(const wchar_t *nick);
+MCONTACT GetContactByURL(const wchar_t *url);
+
+void CALLBACK timerProc(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime);
+void CALLBACK timerProc2(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime);
+
// =============== NewsAggregator SERVICES ================
// Check all Feeds info