X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fmenu%2Fcommand%2Fmenu_cmd.qc;h=e727b39e6446acbb10e8745c5b0a5bb93d3fcdea;hb=224f6d8084e73e0e643cb2d9d58c466defa9d134;hp=3f3f72f5753f61a291966d325f64ea0481d53bd3;hpb=125d619e9ab2a307b15b7ee1a2ededed32c7e84d;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/menu/command/menu_cmd.qc b/qcsrc/menu/command/menu_cmd.qc index 3f3f72f57..e727b39e6 100644 --- a/qcsrc/menu/command/menu_cmd.qc +++ b/qcsrc/menu/command/menu_cmd.qc @@ -1,9 +1,11 @@ #include "menu_cmd.qh" #include "../menu.qh" -#include "../oo/classes.qc" +#include "../item.qh" -#include "../../common/command/generic.qh" +#include "../mutators/events.qh" + +#include .entity firstChild, nextSibling; @@ -12,22 +14,22 @@ void _dumptree_open(entity pass, entity me) { string s; s = me.toString(me); - if(s == "") - s = me.classname; - else - s = strcat(me.classname, ": ", s); + if (s == "") s = me.classname; + else s = strcat(me.classname, ": ", s); print(_dumptree_space, etos(me), " (", s, ")"); - if(me.firstChild) + if (me.firstChild) { print(" {\n"); _dumptree_space = strcat(_dumptree_space, " "); } else + { print("\n"); + } } void _dumptree_close(entity pass, entity me) { - if(me.firstChild) + if (me.firstChild) { _dumptree_space = substring(_dumptree_space, 0, strlen(_dumptree_space) - 2); print(_dumptree_space, "}\n"); @@ -38,97 +40,91 @@ float updateConwidths(float width, float height, float pixelheight); void GameCommand(string theCommand) { - float argc; - argc = tokenize_console(theCommand); + int argc = tokenize_console(theCommand); + string ss = strtolower(argv(0)); - if(argv(0) == "help" || argc == 0) + if (argv(0) == "help" || argc == 0) { - print(_("Usage: menu_cmd command..., where possible commands are:\n")); - print(_(" sync - reloads all cvars on the current menu page\n")); - print(_(" directmenu ITEM - select a menu item as main item\n")); + LOG_INFO(_("Usage: menu_cmd command..., where possible commands are:")); + LOG_INFO(_(" sync - reloads all cvars on the current menu page")); + LOG_INFO(_(" directmenu ITEM - select a menu item as main item")); + LOG_INFO(_(" dumptree - dump the state of the menu as a tree to the console")); - print("\nGeneric commands shared by all programs:\n"); + LOG_INFO("Generic commands shared by all programs:"); GenericCommand_macro_help(); return; } - if(GenericCommand(theCommand)) - return; + if (GenericCommand(theCommand)) return; - if(argv(0) == "sync") + if (argv(0) == "sync") { m_sync(); return; } - if(argv(0) == "update_conwidths_before_vid_restart") + if (argv(0) == "update_conwidths_before_vid_restart") { updateConwidths(cvar("vid_width"), cvar("vid_height"), cvar("vid_pixelheight")); return; } - if(argv(0) == "directmenu" || argv(0) == "directpanelhudmenu") + if (argv(0) == "directmenu" || argv(0) == "directpanelhudmenu") { string filter = string_null; - if(argv(0) == "directpanelhudmenu") - filter = strzone("HUD"); + if (argv(0) == "directpanelhudmenu") filter = "HUD"; - if(argc == 1) + if (argc == 1) { - print(_("Available options:\n")); - float i; - entity e; - string s; + LOG_INFO(_("Available options:")); - for(i = 0, e = world; (e = nextent(e)); ) - if(e.classname != "vtbl" && e.name != "") + FOREACH_ENTITY_ORDERED(it.name != "", { + if (it.classname == "vtbl") continue; + string s = it.name; + if (filter) { - 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; + if (!startsWith(s, filter)) continue; + s = substring(s, strlen(filter), strlen(s) - strlen(filter)); } + LOG_INFOF(" %s", s); + }); } - else if(argc == 2 && !isdemo()) // don't allow this command in demos + else if (argc == 2 && !isdemo()) // don't allow this command in demos { m_play_click_sound(MENU_SOUND_OPEN); m_goto(strcat(filter, argv(1))); // switch to a menu item } - if(filter) - strunzone(filter); return; } - if(argv(0) == "skinselect") + if (argv(0) == "skinselect") { m_goto("skinselector"); return; } - if(argv(0) == "languageselect") + if (argv(0) == "languageselect") { m_goto("languageselector"); return; } - if(argv(0) == "videosettings") + if (argv(0) == "videosettings") { m_goto("videosettings"); return; } - if(argv(0) == "dumptree") + if (argv(0) == "dumptree") { _dumptree_space = ""; depthfirst(main, parent, firstChild, nextSibling, _dumptree_open, _dumptree_close, NULL); return; } - print(_("Invalid command. For a list of supported commands, try menu_cmd help.\n")); + if(MUTATOR_CALLHOOK(Menu_ConsoleCommand, ss, argc, theCommand)) // handled by a mutator + return; + + LOG_INFO(_("Invalid command. For a list of supported commands, try menu_cmd help.")); }