summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/m_genmenu.h1
-rw-r--r--src/mir_app/src/menu_options.cpp23
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;