From: terencehill Date: Sun, 29 Jan 2012 15:13:40 +0000 (+0100) Subject: Show the list of available options for menu_cmd directmenu and menu_cmd directpanelhu... X-Git-Tag: xonotic-v0.7.0~193^2~3 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=e7e342a0ee00dc5d00d22baf0a1f3f8f0c34564a;p=xonotic%2Fxonotic-data.pk3dir.git Show the list of available options for menu_cmd directmenu and menu_cmd directpanelhudmenu (menu_showhudoptions alias) if ran without further arguments --- diff --git a/qcsrc/menu/command/menu_cmd.qc b/qcsrc/menu/command/menu_cmd.qc index 3be6edc662..aa68f2c1bc 100644 --- a/qcsrc/menu/command/menu_cmd.qc +++ b/qcsrc/menu/command/menu_cmd.qc @@ -77,18 +77,37 @@ void GameCommand(string theCommand) return; } - if(argv(0) == "directmenu") if(argc == 2) + if(argv(0) == "directmenu" || argv(0) == "directpanelhudmenu") { - // switch to a menu item - if(!isdemo()) // don't allow this command in demos - m_goto(argv(1)); - return; - } + string filter; + if(argv(0) == "directpanelhudmenu") + filter = strzone("HUD"); - if(argv(0) == "directpanelhudmenu") - { - // switch to a menu item - m_goto(strcat("HUD", argv(1))); + if(argc == 1) + { + print(_("Available options:\n")); + float i; + entity e; + string s; + + for(i = 0, e = world; (e = nextent(e)); ) + if(e.classname != "vtbl" && e.name != "") + { + s = e.name; + if(filter) + { + if(substring(s, 0, strlen(filter)) != filter) + continue; + s = substring(s, strlen(filter), strlen(s) - strlen(filter)); + } + print(strcat(" ", s ,"\n")); + ++i; + } + } + else if(argc == 2 && !isdemo()) // don't allow this command in demos + m_goto(strcat(filter, argv(1))); // switch to a menu item + if(filter) + strunzone(filter); return; }