diff options
author | George Hazan <ghazan@miranda.im> | 2018-02-21 18:36:45 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2018-02-21 18:40:14 +0300 |
commit | e8f69d4e566a3e73ff656beebcae9916e9148589 (patch) | |
tree | 1609c337a76dd79d198fecfdfa5d3acfbd2c45cf | |
parent | 6e96535fdbb886dcad1a3396659b368283922e64 (diff) |
MSN: C++'11 iterators
-rw-r--r-- | protocols/MSN/src/msn_avatar.cpp | 4 | ||||
-rw-r--r-- | protocols/MSN/src/msn_chat.cpp | 32 | ||||
-rw-r--r-- | protocols/MSN/src/msn_commands.cpp | 3 | ||||
-rw-r--r-- | protocols/MSN/src/msn_links.cpp | 12 | ||||
-rw-r--r-- | protocols/MSN/src/msn_lists.cpp | 23 | ||||
-rw-r--r-- | protocols/MSN/src/msn_menu.cpp | 6 | ||||
-rw-r--r-- | protocols/MSN/src/msn_srv.cpp | 7 | ||||
-rw-r--r-- | protocols/MSN/src/msn_threads.cpp | 28 |
8 files changed, 51 insertions, 64 deletions
diff --git a/protocols/MSN/src/msn_avatar.cpp b/protocols/MSN/src/msn_avatar.cpp index 83dce488a8..cf520027a7 100644 --- a/protocols/MSN/src/msn_avatar.cpp +++ b/protocols/MSN/src/msn_avatar.cpp @@ -39,8 +39,8 @@ void CMsnProto::pushAvatarRequest(MCONTACT hContact, LPCSTR pszUrl) if (pszUrl != nullptr && *pszUrl != 0) {
mir_cslock lck(csAvatarQueue);
- for (int i = 0; i < lsAvatarQueue.getCount(); i++)
- if (lsAvatarQueue[i]->hContact == hContact)
+ for (auto &it : lsAvatarQueue)
+ if (it->hContact == hContact)
return;
lsAvatarQueue.insert(new AvatarQueueEntry(hContact, pszUrl));
diff --git a/protocols/MSN/src/msn_chat.cpp b/protocols/MSN/src/msn_chat.cpp index e8f8b87265..2ed9979947 100644 --- a/protocols/MSN/src/msn_chat.cpp +++ b/protocols/MSN/src/msn_chat.cpp @@ -96,12 +96,12 @@ void CMsnProto::MSN_ChatStart(ezxml_t xmli) const char *role = ezxml_txt(ezxml_child(memb, "role"));
GCUserItem *gcu = nullptr;
- for (int j = 0; j < info->mJoinedContacts.getCount(); j++) {
- if (!mir_strcmp(info->mJoinedContacts[j]->WLID, mri)) {
- gcu = info->mJoinedContacts[j];
+ for (auto &it : info->mJoinedContacts)
+ if (!mir_strcmp(it->WLID, mri)) {
+ gcu = it;
break;
}
- }
+
if (!gcu) {
gcu = new GCUserItem;
info->mJoinedContacts.insert(gcu);
@@ -244,8 +244,7 @@ void CMsnProto::MSN_GCRefreshThreadsInfo(void) MCONTACT hContact;
int nThreads = 0;
- for (hContact = db_find_first(m_szModuleName); hContact;
- hContact = db_find_next(hContact, m_szModuleName)) {
+ for (hContact = db_find_first(m_szModuleName); hContact; hContact = db_find_next(hContact, m_szModuleName)) {
if (isChatRoom(hContact) != 0) {
DBVARIANT dbv;
if (getString(hContact, "ChatRoomID", &dbv) == 0) {
@@ -281,12 +280,11 @@ void CMsnProto::MSN_GCAddMessage(wchar_t *mChatID, MCONTACT hContact, char *emai static void ChatInviteUser(ThreadData *thread, GCThreadData* info, const char* wlid)
{
- if (info->mJoinedContacts.getCount()) {
- for (int j = 0; j < info->mJoinedContacts.getCount(); j++) {
- if (_stricmp(info->mJoinedContacts[j]->WLID, wlid) == 0)
+ if (info->mJoinedContacts.getCount())
+ for (auto &it : info->mJoinedContacts)
+ if (!_stricmp(it->WLID, wlid))
return;
- }
- }
+
thread->sendPacketPayload("PUT", "MSGR\\THREAD",
"<thread><id>%d:%s</id><members><member><mri>%s</mri><role>user</role></member></members></thread>",
info->netId, info->szEmail, wlid);
@@ -424,8 +422,8 @@ INT_PTR CALLBACK DlgInviteToChat(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM l ChatInviteSend(nullptr, hwndList, *cont, param->ppro);
if (info) {
- for (int i = 0; i < cont->getCount(); ++i)
- ChatInviteUser(param->ppro->msnNsThread, info, (*cont)[i]);
+ for (auto &it : *cont)
+ ChatInviteUser(param->ppro->msnNsThread, info, it);
delete cont;
}
else {
@@ -433,9 +431,9 @@ INT_PTR CALLBACK DlgInviteToChat(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM l CMStringA buf;
buf.AppendFormat("<thread><id></id><members><member><mri>%d:%s</mri><role>admin</role></member>",
NETID_SKYPE, param->ppro->GetMyUsername(NETID_SKYPE));
- for (int i = 0; i < cont->getCount(); ++i) {
+ for (auto &it : *cont) {
// TODO: Add support for assigning role in invite dialog maybe?
- buf.AppendFormat("<member><mri>%s</mri><role>user</role></member>", (*cont)[i]);
+ buf.AppendFormat("<member><mri>%s</mri><role>user</role></member>", it);
}
buf.Append("</members></thread>");
param->ppro->msnNsThread->sendPacketPayload("PUT", "MSGR\\THREAD", buf);
@@ -462,8 +460,8 @@ int CMsnProto::MSN_GCEventHook(WPARAM, LPARAM lParam) GCThreadData* thread = MSN_GetThreadByChatId(gch->ptszID);
if (thread != nullptr) {
m_arGCThreads.remove(thread);
- for (int i = 0; i < thread->mJoinedContacts.getCount(); i++)
- delete thread->mJoinedContacts[i];
+ for (auto &it : thread->mJoinedContacts)
+ delete it;
delete thread;
}
}
diff --git a/protocols/MSN/src/msn_commands.cpp b/protocols/MSN/src/msn_commands.cpp index 97bd3e71a9..d9c64ed438 100644 --- a/protocols/MSN/src/msn_commands.cpp +++ b/protocols/MSN/src/msn_commands.cpp @@ -946,8 +946,7 @@ LBL_InvalidCommand: /* We have to traverse the list in reverse order as newest events are on top (which is the opposite direction of Groupchat) */
LIST<ezxml> msgs(10,PtrKeySortT);
for (ezxml_t msg = ezxml_get(xmli, "messages", 0, "message", -1); msg != nullptr; msg = ezxml_next(msg)) msgs.insert(msg, 0);
- for (int i=0; i<msgs.getCount(); i++) {
- ezxml_t msg = msgs[i];
+ for (auto &msg : msgs) {
ezxml_t arrtime = ezxml_child(msg, "originalarrivaltime"), from = ezxml_child(msg, "from"),
msgtype = ezxml_child(msg, "messagetype"), content = ezxml_child(msg, "content");
time_t ts;
diff --git a/protocols/MSN/src/msn_links.cpp b/protocols/MSN/src/msn_links.cpp index 8cc32eaad6..efbc79408b 100644 --- a/protocols/MSN/src/msn_links.cpp +++ b/protocols/MSN/src/msn_links.cpp @@ -71,14 +71,14 @@ static INT_PTR ServiceParseMsnimLink(WPARAM, LPARAM lParam) if (g_Instances.getCount() == 0) return 0;
CMsnProto *proto = &g_Instances[0];
- for (int i = 0; i < g_Instances.getCount(); ++i) {
- if (g_Instances[i].m_iStatus > ID_STATUS_OFFLINE) {
- proto = &g_Instances[i];
+ for (auto &it : g_Instances)
+ if (it->m_iStatus > ID_STATUS_OFFLINE) {
+ proto = it;
break;
}
- }
- if (proto == nullptr) return 1;
-
+
+ if (proto == nullptr)
+ return 1;
/* add a contact to the list */
if (wcsnicmp(arg, L"add?", 4) == 0) {
diff --git a/protocols/MSN/src/msn_lists.cpp b/protocols/MSN/src/msn_lists.cpp index f0773df159..0953685dde 100644 --- a/protocols/MSN/src/msn_lists.cpp +++ b/protocols/MSN/src/msn_lists.cpp @@ -59,9 +59,9 @@ MsnContact* CMsnProto::Lists_Get(MCONTACT hContact) {
mir_cslock lck(m_csLists);
- for (int i = 0; i < m_arContacts.getCount(); ++i)
- if (m_arContacts[i].hContact == hContact)
- return &m_arContacts[i];
+ for (auto &it : m_arContacts)
+ if (it->hContact == hContact)
+ return it;
return nullptr;
}
@@ -346,17 +346,16 @@ static void AddPrivacyListEntries(HWND hwndList, CMsnProto *proto) }
// Add new info
- for (int i = 0; i < proto->m_arContacts.getCount(); ++i) {
- MsnContact &cont = proto->m_arContacts[i];
- if (!(cont.list & (LIST_FL | LIST_LL))) {
- cii.pszText = (wchar_t*)cont.email;
+ for (auto &cont : proto->m_arContacts) {
+ if (!(cont->list & (LIST_FL | LIST_LL))) {
+ cii.pszText = (wchar_t*)cont->email;
hItem = (HANDLE)SendMessage(hwndList, CLM_ADDINFOITEMA, 0, (LPARAM)&cii);
- SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(0, (cont.list & LIST_LL) ? 1 : 0));
- SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(1, (cont.list & LIST_FL) ? 2 : 0));
- SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(2, (cont.list & LIST_AL) ? 3 : 0));
- SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(3, (cont.list & LIST_BL) ? 4 : 0));
- SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(4, (cont.list & LIST_RL) ? 5 : 0));
+ SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(0, (cont->list & LIST_LL) ? 1 : 0));
+ SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(1, (cont->list & LIST_FL) ? 2 : 0));
+ SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(2, (cont->list & LIST_AL) ? 3 : 0));
+ SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(3, (cont->list & LIST_BL) ? 4 : 0));
+ SendMessage(hwndList, CLM_SETEXTRAIMAGE, (WPARAM)hItem, MAKELPARAM(4, (cont->list & LIST_RL) ? 5 : 0));
}
}
}
diff --git a/protocols/MSN/src/msn_menu.cpp b/protocols/MSN/src/msn_menu.cpp index 9112c3fec0..65807adcc6 100644 --- a/protocols/MSN/src/msn_menu.cpp +++ b/protocols/MSN/src/msn_menu.cpp @@ -192,9 +192,9 @@ static CMsnProto* GetProtoInstanceByHContact(MCONTACT hContact) if (szProto == nullptr)
return nullptr;
- for (int i = 0; i < g_Instances.getCount(); i++)
- if (!mir_strcmp(szProto, g_Instances[i].m_szModuleName))
- return &g_Instances[i];
+ for (auto &it : g_Instances)
+ if (!mir_strcmp(szProto, it->m_szModuleName))
+ return it;
return nullptr;
}
diff --git a/protocols/MSN/src/msn_srv.cpp b/protocols/MSN/src/msn_srv.cpp index 4d4a239c52..a3e5181f73 100644 --- a/protocols/MSN/src/msn_srv.cpp +++ b/protocols/MSN/src/msn_srv.cpp @@ -84,8 +84,7 @@ void CMsnProto::MSN_DeleteServerGroup(LPCSTR szId) void CMsnProto::MSN_FreeGroups(void)
{
- for (int i = 0; i < m_arGroups.getCount(); i++) {
- ServerGroupItem* p = m_arGroups[i];
+ for (auto &p : m_arGroups) {
mir_free(p->id);
mir_free(p->name);
mir_free(p);
@@ -107,11 +106,9 @@ LPCSTR CMsnProto::MSN_GetGroupById(const char* pId) LPCSTR CMsnProto::MSN_GetGroupByName(const char* pName)
{
- for (int i = 0; i < m_arGroups.getCount(); i++) {
- const ServerGroupItem* p = m_arGroups[i];
+ for (auto &p : m_arGroups)
if (mir_strcmp(p->name, pName) == 0)
return p->id;
- }
return nullptr;
}
diff --git a/protocols/MSN/src/msn_threads.cpp b/protocols/MSN/src/msn_threads.cpp index ff4e6a7915..c75e4b643c 100644 --- a/protocols/MSN/src/msn_threads.cpp +++ b/protocols/MSN/src/msn_threads.cpp @@ -294,16 +294,14 @@ void CMsnProto::MSN_CloseConnections(void) NETLIBSELECTEX nls = {};
- for (int i = 0; i < m_arThreads.getCount(); i++) {
- ThreadData &T = m_arThreads[i];
-
- switch (T.mType) {
+ for (auto &it : m_arThreads) {
+ switch (it->mType) {
case SERVER_NOTIFICATION:
- if (T.s != nullptr && !T.sessionClosed && !T.termPending) {
- nls.hReadConns[0] = T.s;
+ if (it->s != nullptr && !it->sessionClosed && !it->termPending) {
+ nls.hReadConns[0] = it->s;
int res = Netlib_SelectEx(&nls);
if (res >= 0 || nls.hReadStatus[0] == 0)
- T.sendTerminate();
+ it->sendTerminate();
}
break;
}
@@ -327,11 +325,9 @@ GCThreadData* CMsnProto::MSN_GetThreadByChatId(const wchar_t* chatId) return nullptr;
mir_cslock lck(m_csThreads);
- for (int i = 0; i < m_arGCThreads.getCount(); i++) {
- GCThreadData *T = m_arGCThreads[i];
- if (mir_wstrcmpi(T->mChatID, chatId) == 0)
- return T;
- }
+ for (auto &it : m_arGCThreads)
+ if (mir_wstrcmpi(it->mChatID, chatId) == 0)
+ return it;
return nullptr;
}
@@ -340,11 +336,9 @@ ThreadData* CMsnProto::MSN_GetThreadByConnection(HANDLE s) {
mir_cslock lck(m_csThreads);
- for (int i = 0; i < m_arThreads.getCount(); i++) {
- ThreadData &T = m_arThreads[i];
- if (T.s == s)
- return &T;
- }
+ for (auto &it : m_arThreads)
+ if (it->s == s)
+ return it;
return nullptr;
}
|