summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2016-12-19 14:52:57 +0300
committerGeorge Hazan <ghazan@miranda.im>2016-12-19 14:52:57 +0300
commit8938b3ee67fb60553864a019fdb2f22d734f3120 (patch)
tree8a5ba4d6b717d3a037649a8315523787878075f9 /src/core
parent63f6579e56af870fa9ad7289a1a71cd5a27f5d76 (diff)
- fix for a dialog blinking on start;
- crash fix
Diffstat (limited to 'src/core')
-rw-r--r--src/core/stdmsg/src/chat_util.cpp31
-rw-r--r--src/core/stdmsg/src/chat_window.cpp4
-rw-r--r--src/core/stdmsg/src/stdafx.h2
-rw-r--r--src/core/stdmsg/src/tabs.cpp81
4 files changed, 51 insertions, 67 deletions
diff --git a/src/core/stdmsg/src/chat_util.cpp b/src/core/stdmsg/src/chat_util.cpp
index 4b8317b9e6..fb1837beb5 100644
--- a/src/core/stdmsg/src/chat_util.cpp
+++ b/src/core/stdmsg/src/chat_util.cpp
@@ -388,30 +388,19 @@ void ValidateFilename(wchar_t *filename)
}
}
-int RestoreWindowPosition(HWND hwnd, MCONTACT hContact, char *szModule, char *szNamePrefix, UINT showCmd)
+int RestoreWindowPosition(HWND hwnd, MCONTACT hContact, bool bHide)
{
- char szSettingName[64];
- mir_snprintf(szSettingName, "%sx", szNamePrefix);
- int x = db_get_dw(hContact, szModule, szSettingName, -1);
+ int x = db_get_dw(hContact, CHAT_MODULE, "roomx", -1);
if (x == -1)
return 0;
- mir_snprintf(szSettingName, "%sy", szNamePrefix);
- int y = (int)db_get_dw(hContact, szModule, szSettingName, -1);
- mir_snprintf(szSettingName, "%swidth", szNamePrefix);
- int width = db_get_dw(hContact, szModule, szSettingName, -1);
- mir_snprintf(szSettingName, "%sheight", szNamePrefix);
- int height = db_get_dw(hContact, szModule, szSettingName, -1);
-
- WINDOWPLACEMENT wp;
- wp.length = sizeof(wp);
- GetWindowPlacement(hwnd, &wp);
-
- wp.rcNormalPosition.left = x;
- wp.rcNormalPosition.top = y;
- wp.rcNormalPosition.right = wp.rcNormalPosition.left + width;
- wp.rcNormalPosition.bottom = wp.rcNormalPosition.top + height;
- wp.showCmd = showCmd;
- SetWindowPlacement(hwnd, &wp);
+ int y = (int)db_get_dw(hContact, CHAT_MODULE, "roomy", -1);
+ int width = db_get_dw(hContact, CHAT_MODULE, "roomwidth", -1);
+ int height = db_get_dw(hContact, CHAT_MODULE, "roomheight", -1);
+
+ DWORD dwFlags = SWP_NOACTIVATE | SWP_NOZORDER;
+ if (bHide)
+ dwFlags |= SWP_HIDEWINDOW;
+ SetWindowPos(hwnd, NULL, x, y, width, height, dwFlags);
return 1;
}
diff --git a/src/core/stdmsg/src/chat_window.cpp b/src/core/stdmsg/src/chat_window.cpp
index 241e230c70..febbeb7a60 100644
--- a/src/core/stdmsg/src/chat_window.cpp
+++ b/src/core/stdmsg/src/chat_window.cpp
@@ -1143,8 +1143,10 @@ void CChatRoomDlg::SetWindowPosition()
}
if (db_get_b(NULL, CHAT_MODULE, "SavePosition", 0)) {
- if (RestoreWindowPosition(m_hwnd, m_si->hContact, CHAT_MODULE, "room", SW_HIDE))
+ if (RestoreWindowPosition(m_hwnd, m_si->hContact, true)) {
+ ShowWindow(m_hwnd, SW_HIDE);
return;
+ }
SetWindowPos(m_hwnd, 0, (screen.right - screen.left) / 2 - (550) / 2, (screen.bottom - screen.top) / 2 - (400) / 2, (550), (400), SWP_NOZORDER | SWP_HIDEWINDOW | SWP_NOACTIVATE);
}
else SetWindowPos(m_hwnd, 0, (screen.right - screen.left) / 2 - (550) / 2, (screen.bottom - screen.top) / 2 - (400) / 2, (550), (400), SWP_NOZORDER | SWP_HIDEWINDOW | SWP_NOACTIVATE);
diff --git a/src/core/stdmsg/src/stdafx.h b/src/core/stdmsg/src/stdafx.h
index 09d77d8a83..7fb974d23c 100644
--- a/src/core/stdmsg/src/stdafx.h
+++ b/src/core/stdmsg/src/stdafx.h
@@ -149,7 +149,7 @@ UINT CreateGCMenu(HWND hwndDlg, HMENU *hMenu, int iIndex, POINT pt, SESSION_INFO
void DestroyGCMenu(HMENU *hMenu, int iIndex);
bool LoadMessageFont(LOGFONT *lf, COLORREF *colour);
void SetButtonsPos(HWND hwndDlg, bool bIsChat);
-int RestoreWindowPosition(HWND hwnd, MCONTACT hContact, char *szModule, char *szNamePrefix, UINT showCmd);
+int RestoreWindowPosition(HWND hwnd, MCONTACT hContact, bool bHide);
// message.cpp
diff --git a/src/core/stdmsg/src/tabs.cpp b/src/core/stdmsg/src/tabs.cpp
index 136b512fef..6eb59da245 100644
--- a/src/core/stdmsg/src/tabs.cpp
+++ b/src/core/stdmsg/src/tabs.cpp
@@ -182,7 +182,7 @@ void CTabbedWindow::OnInitDialog()
mir_subclassWindow(m_tab.GetHwnd(), TabSubclassProc);
if (db_get_b(NULL, CHAT_MODULE, "SavePosition", 0))
- RestoreWindowPosition(m_hwnd, NULL, CHAT_MODULE, "room", SW_NORMAL);
+ RestoreWindowPosition(m_hwnd, NULL, false);
LONG_PTR mask = GetWindowLongPtr(m_tab.GetHwnd(), GWL_STYLE);
if (g_Settings.bTabsAtBottom)
@@ -268,22 +268,24 @@ INT_PTR CTabbedWindow::DlgProc(UINT msg, WPARAM wParam, LPARAM lParam)
case GC_FIXTABICONS:
if (CChatRoomDlg *pDlg = (CChatRoomDlg*)lParam) {
int idx = m_tab.GetDlgIndex(pDlg);
- if (idx != -1) {
- int image = 0;
- if (!(pDlg->m_si->wState & GC_EVENT_HIGHLIGHT)) {
- MODULEINFO *mi = pci->MM_FindModule(pDlg->m_si->pszModule);
- image = (pDlg->m_si->wStatus == ID_STATUS_ONLINE) ? mi->OnlineIconIndex : mi->OfflineIconIndex;
- if (pDlg->m_si->wState & STATE_TALK)
- image++;
- }
+ if (idx == -1)
+ break;
- TCITEM tci = {};
- tci.mask = TCIF_IMAGE;
- TabCtrl_GetItem(m_tab.GetHwnd(), idx, &tci);
- if (tci.iImage != image) {
- tci.iImage = image;
- TabCtrl_SetItem(m_tab.GetHwnd(), idx, &tci);
- }
+ SESSION_INFO *si = pDlg->m_si;
+ int image = 0;
+ if (!(si->wState & GC_EVENT_HIGHLIGHT)) {
+ MODULEINFO *mi = pci->MM_FindModule(si->pszModule);
+ image = (si->wStatus == ID_STATUS_ONLINE) ? mi->OnlineIconIndex : mi->OfflineIconIndex;
+ if (si->wState & STATE_TALK)
+ image++;
+ }
+
+ TCITEM tci = {};
+ tci.mask = TCIF_IMAGE;
+ TabCtrl_GetItem(m_tab.GetHwnd(), idx, &tci);
+ if (tci.iImage != image) {
+ tci.iImage = image;
+ TabCtrl_SetItem(m_tab.GetHwnd(), idx, &tci);
}
}
else RedrawWindow(m_tab.GetHwnd(), NULL, NULL, RDW_INVALIDATE);
@@ -437,17 +439,14 @@ INT_PTR CTabbedWindow::DlgProc(UINT msg, WPARAM wParam, LPARAM lParam)
if ((i = TabCtrl_HitTest(((LPNMHDR)lParam)->hwndFrom, &tci)) == -1)
break;
- TCITEM id = {};
- id.mask = TCIF_PARAM;
- TabCtrl_GetItem(GetDlgItem(m_hwnd, IDC_TAB), i, &id);
+ SESSION_INFO *si = ((CChatRoomDlg*)m_tab.GetNthPage(i))->m_si;
ClientToScreen(GetDlgItem(m_hwnd, IDC_TAB), &tci.pt);
HMENU hSubMenu = GetSubMenu(g_hMenu, 5);
TranslateMenu(hSubMenu);
- SESSION_INFO *s = (SESSION_INFO*)id.lParam;
- if (s) {
- WORD w = db_get_w(s->hContact, s->pszModule, "TabPosition", 0);
+ if (si) {
+ WORD w = db_get_w(si->hContact, si->pszModule, "TabPosition", 0);
if (w == 0)
CheckMenuItem(hSubMenu, ID_LOCKPOSITION, MF_BYCOMMAND | MF_UNCHECKED);
else
@@ -457,35 +456,29 @@ INT_PTR CTabbedWindow::DlgProc(UINT msg, WPARAM wParam, LPARAM lParam)
switch (TrackPopupMenu(hSubMenu, TPM_RETURNCMD, tci.pt.x, tci.pt.y, 0, m_hwnd, NULL)) {
case ID_CLOSE:
- if (TabCtrl_GetCurSel(GetDlgItem(m_hwnd, IDC_TAB)) == i)
- PostMessage(m_hwnd, GC_CLOSEWINDOW, 0, 0);
- else
- m_tab.RemovePage(i);
+ SendMessage(m_hwnd, GC_REMOVETAB, 0, (LPARAM)m_tab.GetNthPage(i));
break;
- case ID_CLOSEOTHER:
- {
- int tabCount = m_tab.GetCount()-1;
- if (tabCount > 0) {
- for (tabCount; tabCount >= 0; tabCount--) {
- if (tabCount == i)
- continue;
-
- m_tab.RemovePage(tabCount);
- }
- m_tab.ActivatePage(0);
+ case ID_LOCKPOSITION:
+ if (si != 0) {
+ if (!(GetMenuState(hSubMenu, ID_LOCKPOSITION, MF_BYCOMMAND)&MF_CHECKED)) {
+ if (si->hContact)
+ db_set_w(si->hContact, si->pszModule, "TabPosition", (WORD)(i + 1));
}
+ else db_unset(si->hContact, si->pszModule, "TabPosition");
}
break;
- case ID_LOCKPOSITION:
- TabCtrl_GetItem(GetDlgItem(m_hwnd, IDC_TAB), i, &id);
- if (s != 0) {
- if (!(GetMenuState(hSubMenu, ID_LOCKPOSITION, MF_BYCOMMAND)&MF_CHECKED)) {
- if (s->hContact)
- db_set_w(s->hContact, s->pszModule, "TabPosition", (WORD)(i + 1));
+ case ID_CLOSEOTHER:
+ int tabCount = m_tab.GetCount() - 1;
+ if (tabCount > 0) {
+ for (tabCount; tabCount >= 0; tabCount--) {
+ if (tabCount == i)
+ continue;
+
+ m_tab.RemovePage(tabCount);
}
- else db_unset(s->hContact, s->pszModule, "TabPosition");
+ m_tab.ActivatePage(0);
}
break;
}