diff options
author | George Hazan <george.hazan@gmail.com> | 2014-01-20 19:41:41 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2014-01-20 19:41:41 +0000 |
commit | 7df5b961c9a40259a5766b88b9acc8f0e9a67799 (patch) | |
tree | ad1469b56637ddfde0110190cf57e5c974774c0e /plugins/TabSRMM/src/chat/tools.cpp | |
parent | 1c8d1e0b8ec71f7a28db457cf77a99614ccfc758 (diff) |
fixes $531 (ability to highlight messages by a role)
git-svn-id: http://svn.miranda-ng.org/main/trunk@7803 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/TabSRMM/src/chat/tools.cpp')
-rw-r--r-- | plugins/TabSRMM/src/chat/tools.cpp | 38 |
1 files changed, 35 insertions, 3 deletions
diff --git a/plugins/TabSRMM/src/chat/tools.cpp b/plugins/TabSRMM/src/chat/tools.cpp index 77a5a4d70d..a70018736a 100644 --- a/plugins/TabSRMM/src/chat/tools.cpp +++ b/plugins/TabSRMM/src/chat/tools.cpp @@ -666,13 +666,45 @@ void Chat_SetFilters(SESSION_INFO *si) si->bFilterEnabled = 0;
}
+char GetIndicator(SESSION_INFO *si, LPCTSTR ptszNick, int *iNickIndex)
+{
+ if (iNickIndex)
+ *iNickIndex = 0;
+
+ for (USERINFO *ui = si->pUsers; ui; ui = ui->next) {
+ if (!lstrcmp(ui->pszNick, ptszNick)) {
+ STATUSINFO *ti = pci->TM_FindStatus(si->pStatuses, pci->TM_WordToString(si->pStatuses, ui->Status));
+ if (ti && (int)ti->hIcon < si->iStatusCount) {
+ if (iNickIndex)
+ *iNickIndex = si->iStatusCount - (int)ti->hIcon; // color table's index is not zero-based
+ return szIndicators[(int)ti->hIcon];
+ }
+ break;
+ }
+ }
+ return 0;
+}
+
BOOL IsHighlighted(SESSION_INFO *si, GCEVENT *gce)
{
if (!g_Settings.bHighlightEnabled || !gce || gce->bIsMe)
return FALSE;
+ GCEVENT evTmp = *gce;
+
int dwMask = 0;
- if (gce->ptszText != NULL) dwMask |= CMUCHighlight::MATCH_TEXT;
- if (gce->ptszNick != NULL) dwMask |= CMUCHighlight::MATCH_NICKNAME;
- return g_Settings.Highlight->match(gce, si, dwMask);
+ if (gce->ptszText != NULL)
+ dwMask |= CMUCHighlight::MATCH_TEXT;
+
+ if (gce->ptszNick != NULL) {
+ dwMask |= CMUCHighlight::MATCH_NICKNAME;
+ if (si && g_Settings.bLogClassicIndicators) {
+ size_t len = _tcslen(gce->ptszNick) + 1;
+ TCHAR *tmp = (TCHAR*)_alloca(sizeof(TCHAR)*(len + 1));
+ *tmp = GetIndicator(si, gce->ptszNick, 0);
+ _tcscpy(tmp + 1, gce->ptszNick);
+ evTmp.ptszNick = tmp;
+ }
+ }
+ return g_Settings.Highlight->match(&evTmp, si, dwMask);
}
|