diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/mir_app/src/menu_options.cpp | 74 | ||||
-rw-r--r-- | src/mir_app/src/menu_utils.cpp | 94 |
2 files changed, 108 insertions, 60 deletions
diff --git a/src/mir_app/src/menu_options.cpp b/src/mir_app/src/menu_options.cpp index 2b7fafaa97..b67cf8c99b 100644 --- a/src/mir_app/src/menu_options.cpp +++ b/src/mir_app/src/menu_options.cpp @@ -24,6 +24,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #include "stdafx.h" #include "genmenu.h" +#include "plugins.h"
#define STR_SEPARATOR _T("-----------------------------------") @@ -79,23 +80,23 @@ class CGenMenuOptionsPage : public CDlgBase while (tvi.hItem != NULL) { m_menuItems.GetItem(&tvi); MenuItemOptData *iod = (MenuItemOptData*)tvi.lParam; - if (iod->pimi) { - char menuItemName[256], DBString[300]; - GetMenuItemName(iod->pimi, menuItemName, sizeof(menuItemName)); - - mir_snprintf(DBString, "%s_visible", menuItemName); - db_set_b(NULL, szModule, DBString, tvi.iImage != 0); - - mir_snprintf(DBString, "%s_pos", menuItemName); - db_set_dw(NULL, szModule, DBString, runtimepos); - - mir_snprintf(DBString, "%s_name", menuItemName); - if (iod->name != NULL && iod->defname != NULL && mir_tstrcmp(iod->name, iod->defname) != 0) - db_set_ts(NULL, szModule, DBString, iod->name); - else - db_unset(NULL, szModule, DBString); - - if (iod->pimi->submenu.first != NULL) + if (TMO_IntMenuItem *pimi = iod->pimi) { + if (!equalUUID(pimi->mi.uid, MIID_LAST)) { + char menuItemName[256]; + bin2hex(&pimi->mi.uid, sizeof(pimi->mi.uid), menuItemName); + + int visible = tvi.iImage != 0; + TCHAR *ptszCustomName; + if (iod->name != NULL && iod->defname != NULL && mir_tstrcmp(iod->name, iod->defname) != 0) + ptszCustomName = iod->name; + else + ptszCustomName = _T(""); + + CMString tszValue(FORMAT, _T("%d;%d;%s"), visible, pimi->mi.position, ptszCustomName);
+ db_set_ts(NULL, (char*)szModule, menuItemName, tszValue);
+ } + + if (pimi->submenu.first != NULL) SaveTreeInternal(m_menuItems.GetChild(tvi.hItem), szModule); runtimepos += 100; @@ -123,6 +124,7 @@ class CGenMenuOptionsPage : public CDlgBase mir_snprintf(szModule, "%s_Items", pmo->pszName); CallService(MS_DB_MODULE_DELETE, NULL, (LPARAM)szModule); SaveTreeInternal(m_menuItems.GetRoot(), szModule); + db_set_b(NULL, szModule, "MenuFormat", 1); } void FreeTreeData() @@ -155,33 +157,35 @@ class CGenMenuOptionsPage : public CDlgBase for (TMO_IntMenuItem *p = pFirst; p != NULL; p = p->next) { // filter out items whose presence & position might not be changed - if (p->mi.flags & CMIF_SYSTEM) + if (p->mi.flags & CMIF_SYSTEM)
continue; - char menuItemName[256]; - GetMenuItemName(p, menuItemName, _countof(menuItemName)); + TCHAR customName[201]; customName[0] = 0; + int visible = 1, pos = 0; + if (!equalUUID(p->mi.uid, MIID_LAST)) { + char menuItemName[256]; + bin2hex(&p->mi.uid, sizeof(p->mi.uid), menuItemName); + ptrT tszSettings(db_get_tsa(NULL, pszModule, menuItemName)); + if (tszSettings == NULL) + continue; + + if (_stscanf(tszSettings, _T("%d;%d;%200s"), &visible, &pos, customName) < 2) + continue; + } MenuItemOptData *PD = new MenuItemOptData(); - - char buf[256]; - mir_snprintf(buf, "%s_name", menuItemName); - ptrT tszName(db_get_tsa(NULL, pszModule, buf)); - if (tszName != 0) - PD->name = tszName.detach(); + if (customName[0] != 0) + PD->name = mir_tstrdup(customName); else PD->name = mir_tstrdup(GetMenuItemText(p)); PD->pimi = p; PD->defname = mir_tstrdup(GetMenuItemText(p)); - - mir_snprintf(buf, "%s_visible", menuItemName); - PD->bShow = db_get_b(NULL, pszModule, buf, 1) != 0; - - if (bReread) { - mir_snprintf(buf, "%s_pos", menuItemName); - PD->pos = db_get_dw(NULL, pszModule, buf, 1); - } - else PD->pos = (PD->pimi) ? PD->pimi->originalPosition : 0; + PD->bShow = visible != 0; + if (bReread) + PD->pos = pos; + else + PD->pos = (PD->pimi) ? PD->pimi->originalPosition : 0; PD->id = p->iCommand; diff --git a/src/mir_app/src/menu_utils.cpp b/src/mir_app/src/menu_utils.cpp index 28d0934878..a91876d1ff 100644 --- a/src/mir_app/src/menu_utils.cpp +++ b/src/mir_app/src/menu_utils.cpp @@ -24,6 +24,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #include "stdafx.h"
#include "genmenu.h"
+#include "plugins.h"
static bool bIsGenMenuInited;
bool bIconsDisabled;
@@ -851,12 +852,33 @@ void GetMenuItemName(TMO_IntMenuItem *pMenuItem, char* pszDest, size_t cbDestSiz mir_snprintf(pszDest, cbDestSize, "{%s}", pMenuItem->mi.name.t);
}
+static int sttDumpItem(TMO_IntMenuItem *pmi, void *szModule)
+{
+ if (!equalUUID(pmi->mi.uid, MIID_LAST)) {
+ char menuItemName[200];
+ bin2hex(&pmi->mi.uid, sizeof(pmi->mi.uid), menuItemName);
+
+ int visible = (pmi->mi.flags & CMIF_HIDDEN) == 0;
+ TCHAR *ptszName = (pmi->CustomName != NULL) ? pmi->CustomName : _T("");
+
+ CMString szNewValue(FORMAT, _T("%d;%d;%s"), visible, pmi->mi.position, ptszName);
+ db_set_ts(NULL, (char*)szModule, menuItemName, szNewValue);
+
+ Netlib_Logf(NULL, "MENU[%s] => %s, %d, %d", menuItemName, pmi->UniqName, visible, pmi->mi.position);
+ }
+ return 0;
+}
+
static HMENU BuildRecursiveMenu(HMENU hMenu, TMO_IntMenuItem *pRootMenu, WPARAM wParam, LPARAM lParam)
{
if (pRootMenu == NULL)
return NULL;
+ char szModule[256];
TIntMenuObject *pmo = pRootMenu->parent;
+ mir_snprintf(szModule, "%s_Items", pmo->pszName);
+
+ bool bOldMenuFormat = db_get_b(NULL, szModule, "MenuFormat", false) == 0;
if (pRootMenu->mi.root == NULL)
while (GetMenuItemCount(hMenu) > 0)
@@ -879,33 +901,47 @@ static HMENU BuildRecursiveMenu(HMENU hMenu, TMO_IntMenuItem *pRootMenu, WPARAM // if we have to check & apply database settings
if (!(mi->flags & CMIF_SYSTEM) && pmo->m_bUseUserDefinedItems) {
- char szModule[256], szSetting[256];
- mir_snprintf(szModule, "%s_Items", pmo->pszName);
-
- char menuItemName[256];
- GetMenuItemName(pmi, menuItemName, sizeof(menuItemName));
-
- // check if it visible
- mir_snprintf(szSetting, "%s_visible", menuItemName);
- if (!db_get_b(NULL, szModule, szSetting, 1))
- continue;
-
- // mi.name.t
- mir_snprintf(szSetting, "%s_name", menuItemName);
- TCHAR *tszCustomName = db_get_tsa(NULL, szModule, szSetting);
- if (tszCustomName != NULL) {
- mir_free(pmi->CustomName);
- pmi->CustomName = tszCustomName;
+ char szSetting[256], menuItemName[256];
+ int visible = 0, pos = 0;
+ if (bOldMenuFormat) {
+ GetMenuItemName(pmi, menuItemName, sizeof(menuItemName));
+
+ // check if it visible
+ mir_snprintf(szSetting, "%s_visible", menuItemName);
+ visible = db_get_b(NULL, szModule, szSetting, 1);
+
+ // mi.name.t
+ mir_snprintf(szSetting, "%s_name", menuItemName);
+ TCHAR *tszCustomName = db_get_tsa(NULL, szModule, szSetting);
+ if (tszCustomName != NULL) {
+ mir_free(pmi->CustomName);
+ pmi->CustomName = tszCustomName;
+ }
+
+ mir_snprintf(szSetting, "%s_pos", menuItemName);
+ pos = db_get_dw(NULL, szModule, szSetting, -1);
+ if (pos == -1) {
+ if (pmi->submenu.first)
+ mi->position = 0;
+ }
+ else mi->position = pos;
}
-
- mir_snprintf(szSetting, "%s_pos", menuItemName);
- int pos = db_get_dw(NULL, szModule, szSetting, -1);
- if (pos == -1) {
- db_set_dw(NULL, szModule, szSetting, mi->position);
- if (pmi->submenu.first)
- mi->position = 0;
+ else {
+ if (!equalUUID(mi->uid, MIID_LAST)) {
+ bin2hex(&mi->uid, sizeof(mi->uid), menuItemName);
+ ptrT szValue(db_get_tsa(NULL, szModule, menuItemName));
+ if (szValue != NULL) {
+ TCHAR tszCustomName[201]; tszCustomName[0] = 0;
+ _stscanf(szValue, _T("%d;%d;%200s"), &visible, &pos, tszCustomName);
+ if (tszCustomName[0])
+ replaceStrT(pmi->CustomName, tszCustomName);
+ }
+ }
+ else if (pmi->submenu.first != NULL)
+ visible = 1;
}
- else mi->position = pos;
+ if (!visible)
+ continue;
}
int i = WhereToPlace(hMenu, mi);
@@ -967,6 +1003,14 @@ static HMENU BuildRecursiveMenu(HMENU hMenu, TMO_IntMenuItem *pRootMenu, WPARAM }
}
+ if (bOldMenuFormat && pRootMenu->mi.root == NULL && pmo->m_bUseUserDefinedItems) {
+ // wipe out old trash, write new data & compatibility flag
+ CallService(MS_DB_MODULE_DELETE, 0, (LPARAM)szModule);
+ db_set_b(NULL, szModule, "MenuFormat", true);
+
+ MO_RecursiveWalkMenu(pmo->m_items.first, sttDumpItem, szModule);
+ }
+
return hMenu;
}
|