diff options
author | George Hazan <george.hazan@gmail.com> | 2012-07-13 09:57:44 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2012-07-13 09:57:44 +0000 |
commit | ba4c710433709974d7bab2a27b5936d15f1ed5ea (patch) | |
tree | 906f3f0100d9a9bf1b29c6bc965f65930ac23b6d /plugins/Clist_modern | |
parent | 3a186e57df86c942c71b60886db3446ed357dab2 (diff) |
patch against hangup on the floating frame's resizing
git-svn-id: http://svn.miranda-ng.org/main/trunk@943 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/Clist_modern')
-rw-r--r-- | plugins/Clist_modern/src/modern_cluiframes.cpp | 145 |
1 files changed, 67 insertions, 78 deletions
diff --git a/plugins/Clist_modern/src/modern_cluiframes.cpp b/plugins/Clist_modern/src/modern_cluiframes.cpp index 4e6940e5e2..9f0edf0a11 100644 --- a/plugins/Clist_modern/src/modern_cluiframes.cpp +++ b/plugins/Clist_modern/src/modern_cluiframes.cpp @@ -1243,145 +1243,136 @@ static int UpdateTBToolTip(int framepos) //hiword(wParam) = frameid,loword(wParam) = flag
static int _us_DoSetFrameOptions(WPARAM wParam,LPARAM lParam)
{
- int pos;
int retval; // value to be returned
BOOL bUnicodeText = (LOWORD(wParam) & FO_UNICODETEXT) != 0;
wParam = MAKEWPARAM((LOWORD(wParam))& ~FO_UNICODETEXT, HIWORD(wParam));
- if (_fCluiFramesModuleNotStarted) return -1;
-
-
- pos = id2pos(HIWORD(wParam));
- if (pos < 0 || pos >= g_nFramesCount) {
-
+ if (_fCluiFramesModuleNotStarted)
return -1;
- }
-
- switch(LOWORD(wParam))
- {
- case FO_FLAGS:{
- int flag = lParam;
- int style;
- g_pfwFrames[pos].dwFlags = flag;
- g_pfwFrames[pos].visible = FALSE;
- if (flag&F_VISIBLE) g_pfwFrames[pos].visible = TRUE;
+ int pos = id2pos(HIWORD(wParam));
+ if (pos < 0 || pos >= g_nFramesCount)
+ return -1;
- g_pfwFrames[pos].collapsed = TRUE;
- if (flag&F_UNCOLLAPSED) g_pfwFrames[pos].collapsed = FALSE;
+ FRAMEWND &fw = g_pfwFrames[pos];
- g_pfwFrames[pos].Locked = FALSE;
- if (flag&F_LOCKED) g_pfwFrames[pos].Locked = TRUE;
+ switch(LOWORD(wParam)) {
+ case FO_FLAGS:
+ fw.dwFlags = lParam;
+ fw.visible = FALSE;
+ if (lParam & F_VISIBLE) fw.visible = TRUE;
- g_pfwFrames[pos].UseBorder = TRUE;
- if (flag&F_NOBORDER) g_pfwFrames[pos].UseBorder = FALSE;
+ fw.collapsed = TRUE;
+ if (lParam & F_UNCOLLAPSED) fw.collapsed = FALSE;
- g_pfwFrames[pos].TitleBar.ShowTitleBar = FALSE;
- if (flag&F_SHOWTB) g_pfwFrames[pos].TitleBar.ShowTitleBar = TRUE;
+ fw.Locked = FALSE;
+ if (lParam & F_LOCKED) fw.Locked = TRUE;
- g_pfwFrames[pos].TitleBar.ShowTitleBarTip = FALSE;
- if (flag&F_SHOWTBTIP) g_pfwFrames[pos].TitleBar.ShowTitleBarTip = TRUE;
+ fw.UseBorder = TRUE;
+ if (lParam & F_NOBORDER) fw.UseBorder = FALSE;
- SendMessageA(g_pfwFrames[pos].TitleBar.hwndTip,TTM_ACTIVATE,(WPARAM)g_pfwFrames[pos].TitleBar.ShowTitleBarTip,0);
+ fw.TitleBar.ShowTitleBar = FALSE;
+ if (lParam & F_SHOWTB) fw.TitleBar.ShowTitleBar = TRUE;
- style = (int)GetWindowLongPtr(g_pfwFrames[pos].hWnd,GWL_STYLE);
- style &= (~WS_BORDER);
+ fw.TitleBar.ShowTitleBarTip = FALSE;
+ if (lParam & F_SHOWTBTIP) fw.TitleBar.ShowTitleBarTip = TRUE;
- if ( !(flag&F_NOBORDER ) && !g_CluiData.fLayered ) style |= WS_BORDER;
+ SendMessageA(fw.TitleBar.hwndTip,TTM_ACTIVATE,(WPARAM)fw.TitleBar.ShowTitleBarTip,0);
+ {
+ int style = (int)GetWindowLongPtr(fw.hWnd,GWL_STYLE);
+ style &= (~WS_BORDER);
+ if ( !(lParam & F_NOBORDER ) && !g_CluiData.fLayered )
+ style |= WS_BORDER;
- SetWindowLongPtr(g_pfwFrames[pos].hWnd,GWL_STYLE,(long)style);
- SetWindowLongPtr(g_pfwFrames[pos].TitleBar.hwnd,GWL_STYLE,(long)style& ~(WS_VSCROLL | WS_HSCROLL));
+ SetWindowLongPtr(fw.hWnd,GWL_STYLE,(long)style);
+ SetWindowLongPtr(fw.TitleBar.hwnd,GWL_STYLE,(long)style& ~(WS_VSCROLL | WS_HSCROLL));
+ }
CLUIFramesOnClistResize((WPARAM)pcli->hwndContactList,(LPARAM)0);
- SetWindowPos(g_pfwFrames[pos].TitleBar.hwnd,0,0,0,0,0,SWP_NOZORDER|SWP_NOMOVE|SWP_NOSIZE|SWP_FRAMECHANGED|SWP_NOACTIVATE);
+ SetWindowPos(fw.TitleBar.hwnd,0,0,0,0,0,SWP_NOZORDER|SWP_NOMOVE|SWP_NOSIZE|SWP_FRAMECHANGED|SWP_NOACTIVATE);
return 0;
- }
case FO_NAME:
if (lParam == (LPARAM)NULL)
return -1;
- mir_free(g_pfwFrames[pos].Name);
- mir_free(g_pfwFrames[pos].szName);
+ mir_free(fw.Name);
+ mir_free(fw.szName);
if (bUnicodeText) {
- g_pfwFrames[pos].Name = mir_tstrdup((LPTSTR)lParam);
- g_pfwFrames[pos].szName = mir_t2a((LPTSTR)lParam);
+ fw.Name = mir_tstrdup((LPTSTR)lParam);
+ fw.szName = mir_t2a((LPTSTR)lParam);
}
else {
- g_pfwFrames[pos].szName = mir_strdup((char*)lParam);
- g_pfwFrames[pos].Name = mir_a2t((char *)lParam);
+ fw.szName = mir_strdup((char*)lParam);
+ fw.Name = mir_a2t((char *)lParam);
}
return 0;
case FO_TBNAME:
if (lParam == (LPARAM)NULL) { return(-1);}
- mir_free(g_pfwFrames[pos].TitleBar.tbname);
- mir_free(g_pfwFrames[pos].TitleBar.sztbname);
+ mir_free(fw.TitleBar.tbname);
+ mir_free(fw.TitleBar.sztbname);
if (bUnicodeText) {
- g_pfwFrames[pos].TitleBar.tbname = mir_tstrdup((LPTSTR)lParam);
- g_pfwFrames[pos].TitleBar.sztbname = mir_t2a((LPTSTR)lParam);
+ fw.TitleBar.tbname = mir_tstrdup((LPTSTR)lParam);
+ fw.TitleBar.sztbname = mir_t2a((LPTSTR)lParam);
}
else {
- g_pfwFrames[pos].TitleBar.sztbname = mir_strdup((char*)lParam);
- g_pfwFrames[pos].TitleBar.tbname = mir_a2t((char*)lParam);
+ fw.TitleBar.sztbname = mir_strdup((char*)lParam);
+ fw.TitleBar.tbname = mir_a2t((char*)lParam);
}
- if (g_pfwFrames[pos].floating && (g_pfwFrames[pos].TitleBar.tbname != NULL))
- SetWindowText(g_pfwFrames[pos].ContainerWnd,g_pfwFrames[pos].TitleBar.tbname);
+ if (fw.floating && (fw.TitleBar.tbname != NULL))
+ SetWindowText(fw.ContainerWnd,fw.TitleBar.tbname);
return 0;
case FO_TBTIPNAME:
if (lParam == (LPARAM)NULL) { return(-1);}
- if (g_pfwFrames[pos].TitleBar.tooltip != NULL) mir_free_and_nil(g_pfwFrames[pos].TitleBar.tooltip);
- if (g_pfwFrames[pos].TitleBar.sztooltip != NULL) mir_free_and_nil(g_pfwFrames[pos].TitleBar.sztooltip);
+ if (fw.TitleBar.tooltip != NULL) mir_free_and_nil(fw.TitleBar.tooltip);
+ if (fw.TitleBar.sztooltip != NULL) mir_free_and_nil(fw.TitleBar.sztooltip);
if (bUnicodeText)
{
- g_pfwFrames[pos].TitleBar.tooltip = mir_tstrdup((LPTSTR)lParam);
- g_pfwFrames[pos].TitleBar.sztooltip = mir_t2a((LPTSTR)lParam);
+ fw.TitleBar.tooltip = mir_tstrdup((LPTSTR)lParam);
+ fw.TitleBar.sztooltip = mir_t2a((LPTSTR)lParam);
}
else
{
- g_pfwFrames[pos].TitleBar.sztooltip = mir_strdup((char*)lParam);
- g_pfwFrames[pos].TitleBar.tooltip = mir_a2t((char*)lParam);
+ fw.TitleBar.sztooltip = mir_strdup((char*)lParam);
+ fw.TitleBar.tooltip = mir_a2t((char*)lParam);
}
UpdateTBToolTip(pos);
-
return 0;
case FO_TBSTYLE:
- SetWindowLongPtr(g_pfwFrames[pos].TitleBar.hwnd,GWL_STYLE,lParam& ~(WS_VSCROLL | WS_HSCROLL));
-
+ SetWindowLongPtr(fw.TitleBar.hwnd,GWL_STYLE,lParam& ~(WS_VSCROLL | WS_HSCROLL));
return 0;
case FO_TBEXSTYLE:
- SetWindowLongPtr(g_pfwFrames[pos].TitleBar.hwnd,GWL_EXSTYLE,lParam);
-
+ SetWindowLongPtr(fw.TitleBar.hwnd,GWL_EXSTYLE,lParam);
return 0;
case FO_ICON:
- g_pfwFrames[pos].TitleBar.hicon = (HICON)lParam;
-
+ fw.TitleBar.hicon = (HICON)lParam;
return 0;
case FO_HEIGHT:
if (lParam < 0) { return -1;}
- if (g_pfwFrames[pos].collapsed)
+ if (fw.collapsed)
{
- int oldHeight = g_pfwFrames[pos].height;
- retval = g_pfwFrames[pos].height;
- g_pfwFrames[pos].height = lParam;
- if ( !CLUIFramesFitInSize()) g_pfwFrames[pos].height = retval;
- retval = g_pfwFrames[pos].height;
- if (g_pfwFrames[pos].height != oldHeight)
+ int oldHeight = fw.height;
+ retval = fw.height;
+ fw.height = lParam;
+ if ( !CLUIFramesFitInSize()) fw.height = retval;
+ retval = fw.height;
+ if (fw.height != oldHeight && !fw.floating)
CLUIFramesOnClistResize((WPARAM)pcli->hwndContactList,(LPARAM)0);
}
else
{
- retval = g_pfwFrames[pos].HeightWhenCollapsed;
- g_pfwFrames[pos].HeightWhenCollapsed = lParam;
- if ( !CLUIFramesFitInSize()) g_pfwFrames[pos].HeightWhenCollapsed = retval;
- retval = g_pfwFrames[pos].HeightWhenCollapsed;
+ retval = fw.HeightWhenCollapsed;
+ fw.HeightWhenCollapsed = lParam;
+ if ( !CLUIFramesFitInSize()) fw.HeightWhenCollapsed = retval;
+ retval = fw.HeightWhenCollapsed;
}
return retval;
@@ -1390,8 +1381,8 @@ static int _us_DoSetFrameOptions(WPARAM wParam,LPARAM lParam) if (lParam < 0) { return -1;}
{
- int id = g_pfwFrames[pos].id;
- g_pfwFrames[pos].floating = !(lParam);
+ int id = fw.id;
+ fw.floating = !(lParam);
CLUIFrames_SetFrameFloat(id,1);//lparam = 1 use stored width and height
@@ -1410,9 +1401,7 @@ static int _us_DoSetFrameOptions(WPARAM wParam,LPARAM lParam) return -1;
}
- g_pfwFrames[pos].align = lParam;
-
-
+ fw.align = lParam;
return(0);
}
|