summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/m_message.h7
-rw-r--r--src/mir_app/src/srmm_toolbar.cpp79
2 files changed, 39 insertions, 47 deletions
diff --git a/include/m_message.h b/include/m_message.h
index b2bbf34070..e1dfd41ed7 100644
--- a/include/m_message.h
+++ b/include/m_message.h
@@ -320,10 +320,10 @@ struct CustomButtonData : public MZeroedObject
DWORD m_dwPosition; // default order pos of button, counted from window edge (left or right)
- DWORD m_dwButtonOrigID; // id of button used while button creation and to store button info in DB
- ptrA m_pszModuleName; // module name without spaces and underline symbols (e.g. "tabsrmm")
+ DWORD m_dwButtonID; // id of button used while button creation and to store button info in DB
+ ptrA m_pszModuleName; // module name without spaces and underline symbols (e.g. "tabsrmm")
- DWORD m_dwButtonCID;
+ DWORD m_dwButtonCID; // button's control id
DWORD m_dwArrowCID; // only use with BBBF_ISARROWBUTTON flag
ptrW m_pwszText; // button's text
@@ -337,6 +337,7 @@ struct CustomButtonData : public MZeroedObject
bool m_bRSided;
BYTE m_opFlags;
int m_hLangpack;
+ DWORD m_dwOrigPosition;
struct THotkeyItem *m_hotkey;
};
diff --git a/src/mir_app/src/srmm_toolbar.cpp b/src/mir_app/src/srmm_toolbar.cpp
index e7f1c5e1bd..b3d3f933ce 100644
--- a/src/mir_app/src/srmm_toolbar.cpp
+++ b/src/mir_app/src/srmm_toolbar.cpp
@@ -72,33 +72,6 @@ static void CB_RegisterSeparators()
}
}
-static void CB_GetButtonSettings(MCONTACT hContact, CustomButtonData *cbd)
-{
- DBVARIANT dbv = { 0 };
- char SettingName[1024];
- char* token = nullptr;
-
- // modulename_buttonID, position_inIM_inCHAT_isLSide_isRSide_CanBeHidden
-
- mir_snprintf(SettingName, "%s_%d", cbd->m_pszModuleName, cbd->m_dwButtonOrigID);
-
- if (!db_get_s(hContact, MODULENAME, SettingName, &dbv)) {
- token = strtok(dbv.pszVal, "_");
- cbd->m_dwPosition = (DWORD)atoi(token);
- token = strtok(nullptr, "_");
- cbd->m_bIMButton = atoi(token) != 0;
- token = strtok(nullptr, "_");
- cbd->m_bChatButton = atoi(token) != 0;
- token = strtok(nullptr, "_");
- token = strtok(nullptr, "_");
- cbd->m_bRSided = atoi(token) != 0;
- token = strtok(nullptr, "_");
- cbd->m_bCanBeHidden = atoi(token) != 0;
-
- db_free(&dbv);
- }
-}
-
MIR_APP_DLL(CustomButtonData*) Srmm_GetNthButton(int i)
{
return arButtonsList[i];
@@ -124,9 +97,9 @@ MIR_APP_DLL(int) Srmm_AddButton(const BBButton *bbdi, int _hLang)
cbd->m_pwszText = mir_wstrdup(bbdi->pwszText);
cbd->m_pwszTooltip = mir_wstrdup(bbdi->pwszTooltip);
- cbd->m_dwButtonOrigID = bbdi->dwButtonID;
+ cbd->m_dwButtonID = bbdi->dwButtonID;
cbd->m_hIcon = bbdi->hIcon;
- cbd->m_dwPosition = bbdi->dwDefPos;
+ cbd->m_dwPosition = cbd->m_dwOrigPosition = bbdi->dwDefPos;
cbd->m_dwButtonCID = (bbdi->bbbFlags & BBBF_CREATEBYID) ? bbdi->dwButtonID : LastCID;
cbd->m_dwArrowCID = (bbdi->bbbFlags & BBBF_ISARROWBUTTON) ? cbd->m_dwButtonCID + 1 : 0;
cbd->m_bHidden = (bbdi->bbbFlags & BBBF_HIDDEN) != 0;
@@ -150,11 +123,30 @@ MIR_APP_DLL(int) Srmm_AddButton(const BBButton *bbdi, int _hLang)
}
// download database settings
- CB_GetButtonSettings(0, cbd);
+ char SettingName[1024];
+ mir_snprintf(SettingName, "%s_%d", cbd->m_pszModuleName, cbd->m_dwButtonID);
+
+ DBVARIANT dbv = { 0 };
+ if (!db_get_s(0, MODULENAME, SettingName, &dbv)) {
+ // modulename_buttonID, position_inIM_inCHAT_isLSide_isRSide_CanBeHidden
+ char *token = strtok(dbv.pszVal, "_");
+ cbd->m_dwPosition = (DWORD)atoi(token);
+ token = strtok(nullptr, "_");
+ cbd->m_bIMButton = atoi(token) != 0;
+ token = strtok(nullptr, "_");
+ cbd->m_bChatButton = atoi(token) != 0;
+ token = strtok(nullptr, "_");
+ token = strtok(nullptr, "_");
+ cbd->m_bRSided = atoi(token) != 0;
+ token = strtok(nullptr, "_");
+ cbd->m_bCanBeHidden = atoi(token) != 0;
+
+ db_free(&dbv);
+ }
arButtonsList.insert(cbd);
- if (cbd->m_dwButtonCID != cbd->m_dwButtonOrigID)
+ if (cbd->m_dwButtonCID != cbd->m_dwButtonID)
LastCID++;
if (cbd->m_dwArrowCID == LastCID)
LastCID++;
@@ -172,7 +164,7 @@ MIR_APP_DLL(int) Srmm_GetButtonState(HWND hwndDlg, BBButton *bbdi)
bbdi->bbbFlags = 0;
for (int i = 0; i < arButtonsList.getCount(); i++) {
CustomButtonData *cbd = arButtonsList[i];
- if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonOrigID == bbdi->dwButtonID)) {
+ if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonID == bbdi->dwButtonID)) {
tempCID = cbd->m_dwButtonCID;
break;
}
@@ -193,7 +185,7 @@ MIR_APP_DLL(int) Srmm_SetButtonState(MCONTACT hContact, BBButton *bbdi)
DWORD tempCID = 0;
for (int i = 0; i < arButtonsList.getCount(); i++) {
CustomButtonData *cbd = arButtonsList[i];
- if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonOrigID == bbdi->dwButtonID)) {
+ if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonID == bbdi->dwButtonID)) {
tempCID = cbd->m_dwButtonCID;
break;
}
@@ -234,7 +226,7 @@ MIR_APP_DLL(int) Srmm_RemoveButton(BBButton *bbdi)
for (int i = arButtonsList.getCount() - 1; i >= 0; i--) {
CustomButtonData *cbd = arButtonsList[i];
- if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && cbd->m_dwButtonOrigID == bbdi->dwButtonID) {
+ if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && cbd->m_dwButtonID == bbdi->dwButtonID) {
pFound = cbd;
arButtonsList.remove(i);
}
@@ -260,7 +252,7 @@ MIR_APP_DLL(int) Srmm_ModifyButton(BBButton *bbdi)
for (int i = 0; i < arButtonsList.getCount(); i++) {
cbd = arButtonsList[i];
- if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonOrigID == bbdi->dwButtonID)) {
+ if (!mir_strcmp(cbd->m_pszModuleName, bbdi->pszModuleName) && (cbd->m_dwButtonID == bbdi->dwButtonID)) {
bFound = true;
break;
}
@@ -298,13 +290,13 @@ MIR_APP_DLL(void) Srmm_ClickToolbarIcon(MCONTACT hContact, DWORD idFrom, HWND hw
CustomButtonData *cbd = arButtonsList[i];
if (cbd->m_dwButtonCID == idFrom) {
cbcd.pszModule = cbd->m_pszModuleName;
- cbcd.dwButtonId = cbd->m_dwButtonOrigID;
+ cbcd.dwButtonId = cbd->m_dwButtonID;
hwndFrom = GetDlgItem(hwndDlg, idFrom);
}
else if (cbd->m_dwArrowCID == idFrom) {
bFromArrow = true;
cbcd.pszModule = cbd->m_pszModuleName;
- cbcd.dwButtonId = cbd->m_dwButtonOrigID;
+ cbcd.dwButtonId = cbd->m_dwButtonID;
hwndFrom = GetDlgItem(hwndDlg, idFrom-1);
}
}
@@ -337,7 +329,7 @@ void Srmm_ProcessToolbarHotkey(MCONTACT hContact, INT_PTR iButtonFrom, HWND hwnd
if (cbd->m_hotkey->lParam == iButtonFrom) {
cbcd.pszModule = cbd->m_pszModuleName;
- cbcd.dwButtonId = cbd->m_dwButtonOrigID;
+ cbcd.dwButtonId = cbd->m_dwButtonID;
hwndFrom = GetDlgItem(hwndDlg, cbd->m_dwButtonCID);
break;
}
@@ -360,11 +352,10 @@ void Srmm_ProcessToolbarHotkey(MCONTACT hContact, INT_PTR iButtonFrom, HWND hwnd
MIR_APP_DLL(void) Srmm_ResetToolbar()
{
- { mir_cslock lck(csToolBar);
- wipeList(arButtonsList);
+ for (int i = 0; i < arButtonsList.getCount(); i++) {
+ auto *bb = arButtonsList[i];
+ bb->m_dwPosition = bb->m_dwOrigPosition;
}
- LastCID = MIN_CBUTTONID;
- dwSepCount = 0;
}
void Srmm_CreateToolbarIcons(HWND hwndDlg, int flags)
@@ -465,7 +456,7 @@ static void CB_WriteButtonSettings(MCONTACT hContact, CustomButtonData *cbd)
//modulename_buttonID, position_inIM_inCHAT_isLSide_isRSide_CanBeHidden
- mir_snprintf(SettingName, "%s_%d", cbd->m_pszModuleName, cbd->m_dwButtonOrigID);
+ mir_snprintf(SettingName, "%s_%d", cbd->m_pszModuleName, cbd->m_dwButtonID);
mir_snprintf(SettingParameter, "%d_%u_%u_%u_%u_%u", cbd->m_dwPosition, cbd->m_bIMButton, cbd->m_bChatButton, 0, cbd->m_bRSided, cbd->m_bCanBeHidden);
if (!(cbd->m_opFlags & BBSF_NTBDESTRUCT))
db_set_s(hContact, MODULENAME, SettingName, SettingParameter);
@@ -706,7 +697,7 @@ public:
CustomButtonData *cbd = new CustomButtonData();
cbd->m_bSeparator = cbd->m_bHidden = cbd->m_bIMButton = true;
- cbd->m_dwButtonOrigID = ++dwSepCount;
+ cbd->m_dwButtonID = ++dwSepCount;
cbd->m_pszModuleName = "Tabsrmm_sep";
cbd->m_iButtonWidth = 22;
cbd->m_opFlags = BBSF_NTBDESTRUCT;