From 1e7b2b400a5ac674c00c2c0ad01f51646edd2de3 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Tue, 21 Mar 2017 13:41:54 +0300 Subject: Scriver: standardizing file names --- plugins/Scriver/src/chat_manager.cpp | 86 ++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 plugins/Scriver/src/chat_manager.cpp (limited to 'plugins/Scriver/src/chat_manager.cpp') diff --git a/plugins/Scriver/src/chat_manager.cpp b/plugins/Scriver/src/chat_manager.cpp new file mode 100644 index 0000000000..f86764560a --- /dev/null +++ b/plugins/Scriver/src/chat_manager.cpp @@ -0,0 +1,86 @@ +/* +Chat module plugin for Miranda IM + +Copyright (C) 2003 Jörgen Persson +Copyright 2003-2009 Miranda ICQ/IM project, + +This program is free software; you can redistribute it and/or +modify it under the terms of the GNU General Public License +as published by the Free Software Foundation; either version 2 +of the License, or (at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program; if not, write to the Free Software +Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +*/ + +#include "stdafx.h" + +HWND SM_FindWindowByContact(MCONTACT hContact) +{ + for (int i = 0; i < pci->arSessions.getCount(); i++) { + SESSION_INFO *si = pci->arSessions[i]; + if (si->hContact == hContact) + return (si->pDlg) ? si->pDlg->GetHwnd() : nullptr; + } + return nullptr; +} + +SESSION_INFO* SM_FindSessionAutoComplete(const char* pszModule, SESSION_INFO *currSession, SESSION_INFO *prevSession, const wchar_t *pszOriginal, const wchar_t *pszCurrent) +{ + SESSION_INFO* pResult = nullptr; + if (prevSession == nullptr && my_strstri(currSession->ptszName, pszOriginal) == currSession->ptszName) + pResult = currSession; + else { + wchar_t* pszName = nullptr; + if (currSession == prevSession) + pszCurrent = pszOriginal; + + for (int i = 0; i < pci->arSessions.getCount(); i++) { + SESSION_INFO *si = pci->arSessions[i]; + if (si != currSession && !mir_strcmpi(pszModule, si->pszModule)) { + if (my_strstri(si->ptszName, pszOriginal) == si->ptszName) { + if (prevSession != si && mir_wstrcmpi(si->ptszName, pszCurrent) > 0 && (!pszName || mir_wstrcmpi(si->ptszName, pszName) < 0)) { + pResult = si; + pszName = si->ptszName; + } + } + } + } + } + return pResult; +} + +char SM_GetStatusIndicator(SESSION_INFO *si, USERINFO *ui) +{ + STATUSINFO * ti; + if (!ui || !si) + return '\0'; + + ti = pci->TM_FindStatus(si->pStatuses, pci->TM_WordToString(si->pStatuses, ui->Status)); + if (ti) { + if ((INT_PTR)ti->hIcon < STATUSICONCOUNT) { + INT_PTR id = si->iStatusCount - (INT_PTR)ti->hIcon - 1; + if (id == 0) + return '\0'; + if (id == 1) + return '+'; + if (id == 2) + return '%'; + if (id == 3) + return '@'; + if (id == 4) + return '!'; + if (id == 5) + return '*'; + } + else + return '\0'; + } + return '\0'; +} -- cgit v1.2.3