diff options
-rw-r--r-- | plugins/MirLua/docs/examples/menus.lua | 56 | ||||
-rw-r--r-- | plugins/MirLua/src/m_genmenu.cpp | 76 |
2 files changed, 93 insertions, 39 deletions
diff --git a/plugins/MirLua/docs/examples/menus.lua b/plugins/MirLua/docs/examples/menus.lua index 50e7e75cde..ee1ca258a8 100644 --- a/plugins/MirLua/docs/examples/menus.lua +++ b/plugins/MirLua/docs/examples/menus.lua @@ -3,39 +3,53 @@ local genmenu = require('m_genmenu') --- include m_icolib module local icolib = require('m_icolib') +local menuItem = +{ + -- required field + Name = "Menu item", + Flags = 0, + Position = 0, + Icon = nil, + Service = nil, + Parent = nil +} + --- Add icon for menu items local hIcon = icolib.AddIcon('testMenuIcon', 'Lua icon for menus') --- Add menu item to main menu --- @param name The name of menu item --- @param flags The flugs that determine behaviour of menu item (default 0) --- @param position The position of menu item in main menu (default 0) --- @param icon The handle of icon of menu item (default NULL) --- @param service The name of service which will be called (default '') --- @param hParentMenu The handle of parent menu (default 0) --- @return handle of menu item -genmenu.AddMainMenuItem('Main menu item', 0, 0, hIcon, 'Srv/MMI') +menuItem.Name = "Main menu item" +menuItem.Icon = hIcon +menuItem.Service = "Srv/MMI" +genmenu.AddMainMenuItem(menuItem) --- Add menu item to contact menu --- @param name The name of menu item --- @param flags The flugs that determine behaviour of menu item (default 0) --- @param position The position of menu item in main menu (default 0) --- @param icon The handle of icon of menu item (default NULL) --- @param service The name of service which will be called (default '') --- @param hParentMenu The handle of parent menu (default 0) --- @return handle of menu item -genmenu.AddContactMenuItem('Contact menu item', 0, 0, hIcon, 'Srv/CMI') +menuItem.Name = "Contact menu item" +menuItem.Service = "Srv/CMI" +genmenu.AddContactMenuItem(menuItem) --- Create the contact menu item which will be deleted below -local hMenuItem = genmenu.AddContactMenuItem('testRemove', 0, 0, 0, 'Srv/TestRemove') +menuItem.Name = "testRemove" +menuItem.Service = "Srv/TestRemove" +local hMenuItem = genmenu.AddContactMenuItem(menuItem) --- Remove menu item from parent menu --- @param handle The handle of menu item --- @return 0 on success genmenu.RemoveMenuItem(hMenuItem) --- Add root menu item local CMIF_ROOTHANDLE = 384 -local hRoot = genmenu.AddMainMenuItem('Main menu root', CMIF_ROOTHANDLE) +local hRoot = genmenu.AddMainMenuItem({ Name = "Main menu root", Flags = CMIF_ROOTHANDLE }) + +--- Add child menu item +menuItem.Name = "Main menu child" +menuItem.Flags = CMIF_ROOTHANDLE +menuItem.Service = 'Srv/SMI' +menuItem.Parent = hRoot +genmenu.AddMainMenuItem(menuItem) + --- Add child menu item -genmenu.AddMainMenuItem('Main menu child', CMIF_ROOTHANDLE, 0, nil, 'Srv/CMI', hRoot) +menuItem.Name = "Main menu child 2" +menuItem.Flags = CMIF_ROOTHANDLE +menuItem.Service = 'Srv/SMI' +menuItem.Parent = "&Help" +genmenu.AddMainMenuItem(menuItem) diff --git a/plugins/MirLua/src/m_genmenu.cpp b/plugins/MirLua/src/m_genmenu.cpp index 064758da2e..43e1b2a36f 100644 --- a/plugins/MirLua/src/m_genmenu.cpp +++ b/plugins/MirLua/src/m_genmenu.cpp @@ -1,16 +1,52 @@ #include "stdafx.h"
+static CLISTMENUITEM* MakeMenuItem(lua_State *L)
+{
+ CLISTMENUITEM *pmi = (CLISTMENUITEM*)mir_calloc(sizeof(CLISTMENUITEM));
+ pmi->cbSize = sizeof(CLISTMENUITEM);
+
+ lua_getfield(L, 1, "Name");
+ pmi->pszName = LPGEN((char*)luaL_checkstring(L, -1));
+ lua_pop(L, 1);
+
+ lua_getfield(L, 1, "Flags");
+ pmi->flags = lua_tointeger(L, -1);
+ lua_pop(L, 1);
+
+ lua_getfield(L, 1, "Position");
+ pmi->position = lua_tointeger(L, -1);
+ lua_pop(L, 1);
+
+ lua_getfield(L, 1, "Icon");
+ pmi->icolibItem = (HANDLE)lua_touserdata(L, -1);
+ lua_pop(L, 1);
+
+ lua_getfield(L, 1, "Service");
+ pmi->pszService = (char*)lua_tostring(L, -1);
+ lua_pop(L, 1);
+
+ lua_getfield(L, 1, "Parent");
+ pmi->hParentMenu = (HGENMENU)lua_touserdata(L, -1);
+ lua_pop(L, 1);
+
+ return pmi;
+}
+
static int lua_AddMainMenuItem(lua_State *L)
{
- CLISTMENUITEM mi = { sizeof(mi) };
- mi.pszName = LPGEN((char*)luaL_checkstring(L, 1));
- mi.flags = lua_tointeger(L, 2);
- mi.position = lua_tointeger(L, 3);
- mi.icolibItem = (HANDLE)lua_touserdata(L, 4);
- mi.pszService = (char*)lua_tostring(L, 5);
- mi.hParentMenu = (HGENMENU)lua_touserdata(L, 6);
-
- HGENMENU res = ::Menu_AddMainMenuItem(&mi);
+ if (lua_type(L, 1) != LUA_TTABLE)
+ {
+ lua_pushlightuserdata(L, 0);
+ return 1;
+ }
+
+ lua_settop(L, 1);
+
+ mir_ptr<CLISTMENUITEM> pmi(MakeMenuItem(L));
+
+ lua_pop(L, 1);
+
+ HGENMENU res = ::Menu_AddMainMenuItem(pmi);
lua_pushlightuserdata(L, res);
return 1;
@@ -18,15 +54,19 @@ static int lua_AddMainMenuItem(lua_State *L) static int lua_AddContactMenuItem(lua_State *L)
{
- CLISTMENUITEM mi = { sizeof(mi) };
- mi.pszName = LPGEN((char*)luaL_checkstring(L, 1));
- mi.flags = lua_tointeger(L, 2);
- mi.position = lua_tointeger(L, 3);
- mi.icolibItem = (HANDLE)lua_touserdata(L, 4);
- mi.pszService = (char*)lua_tostring(L, 5);
- mi.hParentMenu = (HGENMENU)lua_touserdata(L, 6);
-
- HGENMENU res = ::Menu_AddContactMenuItem(&mi);
+ if (lua_type(L, 1) != LUA_TTABLE)
+ {
+ lua_pushlightuserdata(L, 0);
+ return 1;
+ }
+
+ lua_settop(L, 1);
+
+ mir_ptr<CLISTMENUITEM> pmi(MakeMenuItem(L));
+
+ lua_pop(L, 1);
+
+ HGENMENU res = ::Menu_AddContactMenuItem(pmi);
lua_pushlightuserdata(L, res);
return 1;
|