From 06b0e8f8e4fa296832c7e053ac74ea4d790bd26e Mon Sep 17 00:00:00 2001 From: Kirill Volinsky Date: Thu, 30 Apr 2015 07:11:16 +0000 Subject: minus critical section git-svn-id: http://svn.miranda-ng.org/main/trunk@13279 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/NotifyAnything/src/main.cpp | 71 +++++++++++-------------------------- 1 file changed, 21 insertions(+), 50 deletions(-) (limited to 'plugins/NotifyAnything/src/main.cpp') diff --git a/plugins/NotifyAnything/src/main.cpp b/plugins/NotifyAnything/src/main.cpp index a35a757462..ee521e7550 100644 --- a/plugins/NotifyAnything/src/main.cpp +++ b/plugins/NotifyAnything/src/main.cpp @@ -1,8 +1,5 @@ #include "common.h" -#define EnterCS(cs) EnterCriticalSection(cs) -#define LeaveCS(cs) LeaveCriticalSection(cs) - void cslog(const TCHAR *what, const TCHAR *file, int line) { if (g_settings.log_to_file) { @@ -21,25 +18,11 @@ void cslog(const TCHAR *what, const TCHAR *file, int line) } } -void EnterCSHelper(CRITICAL_SECTION *cs, const TCHAR *file, int line) -{ - cslog(_T(">enter"), file, line); - EnterCriticalSection(cs); - cslog(_T("leave"), file, line); - LeaveCriticalSection(cs); - cslog(_T(" popups_t; typedef std::set anon_popups_t; popups_t g_popups; anon_popups_t g_anon_popups; -CRITICAL_SECTION g_popups_cs; +mir_cs g_popups_cs; std::tstring strip(std::tstring str) { @@ -319,9 +302,9 @@ void getAll(std::vector &out, std::tstring &in, TCHAR sep, bool un std::tstring arg; while (getNext(arg, in, sep)) if (!arg.empty()) { - if (unquote_) - arg = unquote(arg); - out.push_back(arg); + if (unquote_) + arg = unquote(arg); + out.push_back(arg); } } @@ -441,11 +424,10 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA switch (message) { case WM_COMMAND: { - EnterCS(&g_popups_cs); + mir_cslock lck(g_popups_cs); std::tstring left; if (pd) left = pd->left; - LeaveCS(&g_popups_cs); if (left.empty()) PUDeletePopup(hWnd); @@ -456,15 +438,14 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA PUDeletePopup(hWnd); } } - return TRUE; + return TRUE; case WM_CONTEXTMENU: { - EnterCS(&g_popups_cs); + mir_cslock lck(g_popups_cs); std::tstring right; if (pd) right = pd->right; - LeaveCS(&g_popups_cs); if (right.empty()) PUDeletePopup(hWnd); @@ -475,16 +456,18 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA PUDeletePopup(hWnd); } } - return TRUE; + return TRUE; case UM_INITPOPUP: - EnterCS(&g_popups_cs); + { + mir_cslock lck(g_popups_cs); pd->hwnd = hWnd; - LeaveCS(&g_popups_cs); - return TRUE; + } + return TRUE; case UM_FREEPLUGINDATA: - EnterCS(&g_popups_cs); + { + mir_cslock lck(g_popups_cs); std::tstring closed; if (pd) closed = pd->closed; @@ -492,14 +475,13 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA g_popups.erase(pd->id); g_anon_popups.erase(pd); delete pd; - LeaveCS(&g_popups_cs); if (!closed.empty()) { bool closeflag = false; processAction(closed, closeflag); } - - return TRUE; + } + return TRUE; } return DefWindowProc(hWnd, message, wParam, lParam); } @@ -515,7 +497,7 @@ int showMessage(const popup_t &msg) ppd.PluginWindowProc = PopupDlgProc; ppd.iSeconds = msg.delay; - EnterCS(&g_popups_cs); + mir_cslock lck(g_popups_cs); popup_t *msgp = new popup_t(msg); @@ -524,14 +506,12 @@ int showMessage(const popup_t &msg) g_anon_popups.insert(msgp); ppd.PluginData = msgp; - LeaveCS(&g_popups_cs); - return PUAddPopupT(&ppd); } void replaceMessage(const popup_t &msg) { - EnterCS(&g_popups_cs); + mir_cslock lck(g_popups_cs); popups_t::iterator i = g_popups.find(msg.id); if (i != g_popups.end()) { @@ -559,14 +539,11 @@ void replaceMessage(const popup_t &msg) if (!msg.closed.empty()) nmsg.closed = msg.closed; - LeaveCS(&g_popups_cs); - PUChangeTextT(i->second->hwnd, strip(i->second->message).c_str()); return; } } - LeaveCS(&g_popups_cs); } inline int dehex(int c) { @@ -854,7 +831,7 @@ void processMessage(std::tstring buf) void initWinsock() { - EnterCS(&g_wsocklock); + mir_cslock lck(g_wsocklock); if (g_firstrun) { // probably not needed, but just in case... // give Popup a second to sort itself out @@ -866,7 +843,6 @@ void initWinsock() if (err) throw "WSAStartup failed"; } - LeaveCS(&g_wsocklock); } DWORD WINAPI udptcpThreadFunc(LPVOID useUdp) @@ -981,7 +957,7 @@ void start_threads() { g_exit_threads = false; DWORD id; - g_udp_thread = CreateThread(NULL, 0, udptcpThreadFunc, (void *) 1, 0, &id); + g_udp_thread = CreateThread(NULL, 0, udptcpThreadFunc, (void *)1, 0, &id); g_tcp_thread = CreateThread(NULL, 0, udptcpThreadFunc, NULL, 0, &id); } @@ -1010,9 +986,6 @@ extern "C" int __declspec(dllexport) Load() _tcscpy(buf, _T(".")); g_mirandaDir = _tgetcwd(buf, MAX_PATH); - InitializeCriticalSection(&g_popups_cs); - InitializeCriticalSection(&g_wsocklock); - registerSound(_T("Notice")); registerSound(_T("Message")); registerSound(_T("Error")); @@ -1030,7 +1003,5 @@ extern "C" int __declspec(dllexport) Unload(void) stop_threads(); WSACleanup(); - DeleteCriticalSection(&g_popups_cs); - DeleteCriticalSection(&g_wsocklock); return 0; } -- cgit v1.2.3