summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2016-02-10 11:42:00 +0000
committerGeorge Hazan <george.hazan@gmail.com>2016-02-10 11:42:00 +0000
commitf1c735f22c3f3d6317d86d890ad74d63f0bbf558 (patch)
tree303cf55f88a028797fe18a1a3db359b6987bdd64
parent4932221e81ccb89f1ac2acde300c1e9efb988f8a (diff)
wrong ME_AV_AVATARCHANGED hook could hang popups
git-svn-id: http://svn.miranda-ng.org/main/trunk@16260 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r--plugins/Popup/src/avatars.h4
-rw-r--r--plugins/Popup/src/popup_thread.cpp18
-rw-r--r--plugins/Popup/src/popup_wnd2.cpp55
-rw-r--r--plugins/Popup/src/popup_wnd2.h1
-rw-r--r--plugins/Popup/src/version.h2
5 files changed, 41 insertions, 39 deletions
diff --git a/plugins/Popup/src/avatars.h b/plugins/Popup/src/avatars.h
index f2a6492fb5..52b708ca92 100644
--- a/plugins/Popup/src/avatars.h
+++ b/plugins/Popup/src/avatars.h
@@ -24,6 +24,10 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#ifndef __avatars_h__
#define __avatars_h__
+#define UM_AVATARCHANGED (WM_USER+0x300)
+#define UM_MENUDONE (WM_USER+0x301)
+#define UM_SHOWMENU (WM_USER+0x302)
+
class PopupAvatar
{
protected:
diff --git a/plugins/Popup/src/popup_thread.cpp b/plugins/Popup/src/popup_thread.cpp
index af86019a3a..eff60a4523 100644
--- a/plugins/Popup/src/popup_thread.cpp
+++ b/plugins/Popup/src/popup_thread.cpp
@@ -46,7 +46,8 @@ enum
UTM_REQUEST_IDLE,
UTM_LOCK_QUEUE,
UTM_UNLOCK_QUEUE,
- UTM_REQUEST_REMOVE
+ UTM_REQUEST_REMOVE,
+ UTM_AVATAR_CHANGED
};
bool UpdatePopupPosition(PopupWnd2 *prev, PopupWnd2 *wnd)
@@ -196,6 +197,13 @@ static LRESULT CALLBACK PopupThreadManagerWndProc(HWND hwnd, UINT message, WPARA
gLockCount = 0;
break;
+ case UTM_AVATAR_CHANGED:
+ for (int i = 0; i < popupList.getCount(); i++) {
+ PopupWnd2 *p = popupList[i];
+ if (p->getContact() == wParam)
+ SendMessage(p->getHwnd(), UM_AVATARCHANGED, 0, 0);
+ }
+ break;
}
return DefWindowProc(hwnd, message, wParam, lParam);
}
@@ -242,10 +250,18 @@ static unsigned __stdcall PopupThread(void *)
/////////////////////////////////////////////////////////////////////////////////////////
// interface
+static int sttAvatarChanged(WPARAM wParam, LPARAM)
+{
+ PostMessage(gHwndManager, UTM_AVATAR_CHANGED, wParam, 0);
+ return 0;
+}
+
void LoadPopupThread()
{
unsigned threadId;
hThread = mir_forkthreadex(PopupThread, NULL, &threadId);
+
+ HookEvent(ME_AV_AVATARCHANGED, sttAvatarChanged);
}
void StopPopupThread()
diff --git a/plugins/Popup/src/popup_wnd2.cpp b/plugins/Popup/src/popup_wnd2.cpp
index e8d6b71a71..d48670cef7 100644
--- a/plugins/Popup/src/popup_wnd2.cpp
+++ b/plugins/Popup/src/popup_wnd2.cpp
@@ -38,10 +38,6 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#define AVATAR_TIMER 1608
#define CURSOR_TIMER 1609
-#define UM_AVATARCHANGED (WM_USER+0x300)
-#define UM_MENUDONE (WM_USER+0x301)
-#define UM_SHOWMENU (WM_USER+0x302)
-
HWND ghwndMenuHost = NULL;
void WindowThread(void *arg);
@@ -81,19 +77,8 @@ bool LoadPopupWnd2()
if (!g_wndClass.cPopupEditBox) {
TCHAR msg[2048];
mir_sntprintf(msg, TranslateT("Failed to register custom edit box window class.\r\n\r\ncbSize: %i\r\nstyle: %p\r\nlpfnWndProc: %i\r\ncbClsExtra: %i\r\ncbWndExtra: %i\r\nhInstance: %i\r\nhIcon: %i\r\nhCursor: %i\r\nhbrBackground: %i\r\nlpszMenuName: %s\r\nlpszClassName: %s\r\nhIconSm: %i\r\n"),
- wclw.cbSize, // UINT cbSize;
- wclw.style, // UINT style;
- wclw.lpfnWndProc, // WNDPROC lpfnWndProc;
- wclw.cbClsExtra, // int cbClsExtra;
- wclw.cbWndExtra, // int cbWndExtra;
- wclw.hInstance, // HINSTANCE hInstance;
- wclw.hIcon, // HICON hIcon;
- wclw.hCursor, // HCURSOR hCursor;
- wclw.hbrBackground, // HBRUSH hbrBackground;
- wclw.lpszMenuName, // LPCWSTR lpszMenuName;
- wclw.lpszClassName, // LPCWSTR lpszClassName;
- wclw.hIconSm // HICON hIconSm;
- );
+ wclw.cbSize, wclw.style, wclw.lpfnWndProc, wclw.cbClsExtra, wclw.cbWndExtra, wclw.hInstance, wclw.hIcon, wclw.hCursor,
+ wclw.hbrBackground, wclw.lpszMenuName, wclw.lpszClassName, wclw.hIconSm);
MSGERROR(msg);
}
@@ -399,9 +384,9 @@ void PopupWnd2::show()
}
if (m_bSlide)
SetWindowPos(m_hwnd, 0,
- (int)m_ptPosition0.x + ((int)m_ptPosition1.x - (int)m_ptPosition0.x) * int(dwTime - dwTime0) / (int)m_options->FadeIn,
- (int)m_ptPosition0.y + ((int)m_ptPosition1.y - (int)m_ptPosition0.y) * int(dwTime - dwTime0) / (int)m_options->FadeIn,
- 0, 0, SWP_NOZORDER | SWP_NOSIZE | SWP_NOACTIVATE | SWP_DEFERERASE | SWP_NOSENDCHANGING | SWP_SHOWWINDOW);
+ (int)m_ptPosition0.x + ((int)m_ptPosition1.x - (int)m_ptPosition0.x) * int(dwTime - dwTime0) / (int)m_options->FadeIn,
+ (int)m_ptPosition0.y + ((int)m_ptPosition1.y - (int)m_ptPosition0.y) * int(dwTime - dwTime0) / (int)m_options->FadeIn,
+ 0, 0, SWP_NOZORDER | SWP_NOSIZE | SWP_NOACTIVATE | SWP_DEFERERASE | SWP_NOSENDCHANGING | SWP_SHOWWINDOW);
UpdateWindow(m_hwnd);
Sleep(1);
}
@@ -480,9 +465,9 @@ void PopupWnd2::hide()
}
if (m_bSlide)
SetWindowPos(m_hwnd, 0,
- (int)m_ptPosition0.x + ((int)m_ptPosition1.x - (int)m_ptPosition0.x) * int(dwTime - dwTime0) / (int)m_options->FadeOut,
- (int)m_ptPosition0.y + ((int)m_ptPosition1.y - (int)m_ptPosition0.y) * int(dwTime - dwTime0) / (int)m_options->FadeOut,
- 0, 0, SWP_NOZORDER | SWP_NOSIZE | SWP_NOACTIVATE | SWP_DEFERERASE | SWP_NOSENDCHANGING | SWP_SHOWWINDOW);
+ (int)m_ptPosition0.x + ((int)m_ptPosition1.x - (int)m_ptPosition0.x) * int(dwTime - dwTime0) / (int)m_options->FadeOut,
+ (int)m_ptPosition0.y + ((int)m_ptPosition1.y - (int)m_ptPosition0.y) * int(dwTime - dwTime0) / (int)m_options->FadeOut,
+ 0, 0, SWP_NOZORDER | SWP_NOSIZE | SWP_NOACTIVATE | SWP_DEFERERASE | SWP_NOSENDCHANGING | SWP_SHOWWINDOW);
UpdateWindow(m_hwnd);
Sleep(1);
}
@@ -893,16 +878,17 @@ LRESULT CALLBACK PopupWnd2::WindowProc(UINT message, WPARAM wParam, LPARAM lPara
return DefWindowProc(m_hwnd, message, wParam, lParam);
case UM_INITPOPUP:
- if (!m_customPopup) PopupThreadAddWindow(this);
- if (m_iTimeout > 0) SetTimer(m_hwnd, POPUP_TIMER, m_iTimeout * 1000, 0);
- if (m_hContact && !m_hbmAvatar && PopupOptions.EnableAvatarUpdates)
- m_hhkAvatarChanged = HookEventMessage(ME_AV_AVATARCHANGED, m_hwnd, UM_AVATARCHANGED);
- if (m_avatar->activeFrameDelay() > 0) SetTimer(m_hwnd, AVATAR_TIMER, m_avatar->activeFrameDelay(), 0);
+ if (!m_customPopup)
+ PopupThreadAddWindow(this);
+ if (m_iTimeout > 0)
+ SetTimer(m_hwnd, POPUP_TIMER, m_iTimeout * 1000, 0);
+
+ if (m_avatar->activeFrameDelay() > 0)
+ SetTimer(m_hwnd, AVATAR_TIMER, m_avatar->activeFrameDelay(), 0);
// prevent unwanted clicks, but allow wanted :)
GetCursorPos(&m_ptPrevCursor);
SetTimer(m_hwnd, CURSOR_TIMER, 500, NULL);
-
break;
case UM_POPUPSHOW:
@@ -912,11 +898,10 @@ LRESULT CALLBACK PopupWnd2::WindowProc(UINT message, WPARAM wParam, LPARAM lPara
break;
case UM_AVATARCHANGED:
- if (wParam == m_hContact) {
- m_avatar->invalidate();
- update();
- if (m_avatar->activeFrameDelay() > 0) SetTimer(m_hwnd, AVATAR_TIMER, m_avatar->activeFrameDelay(), 0);
- }
+ m_avatar->invalidate();
+ update();
+ if (m_avatar->activeFrameDelay() > 0)
+ SetTimer(m_hwnd, AVATAR_TIMER, m_avatar->activeFrameDelay(), 0);
break;
case UM_POPUPACTION:
@@ -1226,8 +1211,6 @@ LRESULT CALLBACK PopupWnd2::WindowProc(UINT message, WPARAM wParam, LPARAM lPara
if (!m_customPopup) PopupThreadUnlock();
m_bIsHovered = false;
}
- if (m_hhkAvatarChanged)
- Popup_UnhookEventAsync((WPARAM)m_hwnd, (LPARAM)m_hhkAvatarChanged);
SendMessage(m_hwnd, UM_FREEPLUGINDATA, 0, 0);
SetWindowLongPtr(m_hwnd, GWLP_USERDATA, 0);
m_hwnd = 0;
diff --git a/plugins/Popup/src/popup_wnd2.h b/plugins/Popup/src/popup_wnd2.h
index a0c6d20c06..7e0af55bd4 100644
--- a/plugins/Popup/src/popup_wnd2.h
+++ b/plugins/Popup/src/popup_wnd2.h
@@ -82,7 +82,6 @@ private:
PopupAvatar*m_avatar;
int m_avatarFrameDelay;
bool m_bReshapeWindow;
- HANDLE m_hhkAvatarChanged;
bool m_bIsPinned;
// show & hide
diff --git a/plugins/Popup/src/version.h b/plugins/Popup/src/version.h
index 64b2503cdc..8f5cd3103e 100644
--- a/plugins/Popup/src/version.h
+++ b/plugins/Popup/src/version.h
@@ -1,7 +1,7 @@
#define __MAJOR_VERSION 2
#define __MINOR_VERSION 1
#define __RELEASE_NUM 1
-#define __BUILD_NUM 11
+#define __BUILD_NUM 12
#include <stdver.h>