diff options
-rw-r--r-- | include/m_genmenu.h | 1 | ||||
-rw-r--r-- | src/mir_app/src/menu_options.cpp | 23 |
2 files changed, 19 insertions, 5 deletions
diff --git a/include/m_genmenu.h b/include/m_genmenu.h index 8dc27bfbfb..15a7ded349 100644 --- a/include/m_genmenu.h +++ b/include/m_genmenu.h @@ -39,6 +39,7 @@ #endif
#define CMIF_KEEPUNTRANSLATED 0x0400 // don't translate a menu item
+#define CMIF_CUSTOM 0x0800 // custom menu item. doesn't exist in a code
#define CMIF_DEFAULT 0x1000 // this menu item is the default one
struct TMO_MenuItem
diff --git a/src/mir_app/src/menu_options.cpp b/src/mir_app/src/menu_options.cpp index 1a3b2f0b5e..f3c89cf9ad 100644 --- a/src/mir_app/src/menu_options.cpp +++ b/src/mir_app/src/menu_options.cpp @@ -73,7 +73,7 @@ class CGenMenuOptionsPage : public CDlgBase tvi.mask = TVIF_TEXT | TVIF_PARAM | TVIF_HANDLE | TVIF_IMAGE; tvi.pszText = idstr; - int count = 0; + int count = 0, customOrder = 0; int runtimepos = 100; while (tvi.hItem != NULL) { @@ -91,8 +91,11 @@ class CGenMenuOptionsPage : public CDlgBase else ptszCustomName = _T(""); - CMString tszValue(FORMAT, _T("%d;%d;%s"), visible, pimi->mi.position, ptszCustomName); - db_set_ts(NULL, (char*)szModule, menuItemName, tszValue); + CMString tszValue(FORMAT, _T("%d;%d;%s"), visible, runtimepos, ptszCustomName); + db_set_ts(NULL, szModule, menuItemName, tszValue); + + if (pimi->mi.flags & CMIF_CUSTOM) + db_set_s(NULL, szModule, CMStringA(FORMAT, "Custom%d", customOrder++), menuItemName); } if (pimi->submenu.first != NULL) @@ -401,10 +404,20 @@ public: if (!m_menuItems.GetItem(&tvi)) return; + MenuItemOptData *curData = (MenuItemOptData*)tvi.lParam; + + TMO_MenuItem mi = {}; + UuidCreate((UUID*)&mi.uid); + mi.flags = CMIF_CUSTOM; + mi.name.a = LPGEN("New submenu"); + mi.position = curData->pos - 1; + TMO_IntMenuItem *pimi = Menu_AddItem(curData->pimi->parent->id, &mi, NULL); + MenuItemOptData *PD = new MenuItemOptData(); PD->id = -1; - PD->name = TranslateT("New submenu"); - PD->pos = ((MenuItemOptData *)tvi.lParam)->pos - 1; + PD->name = mir_tstrdup(pimi->mi.name.t); + PD->pos = pimi->mi.position; + PD->pimi = pimi; TVINSERTSTRUCT tvis = { 0 }; tvis.item.lParam = (LPARAM)PD; |