X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fmenu%2Fcommand%2Fmenu_cmd.qc;h=0f87cbb0959cb38df039f1cac70f796cabd0185b;hb=6585b5a8ef2ce4ee66826df826a6c759bd815cb8;hp=8b12a7b7ddbe6289b0f722ed661ab468a954a9ea;hpb=9e6de751aaa2a918708f80735a006a03e84f2fcf;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/menu/command/menu_cmd.qc b/qcsrc/menu/command/menu_cmd.qc index 8b12a7b7d..0f87cbb09 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); LOG_INFO(_dumptree_space, etos(me), " (", s, ")"); - if(me.firstChild) + if (me.firstChild) { LOG_INFO(" {\n"); _dumptree_space = strcat(_dumptree_space, " "); } else + { LOG_INFO("\n"); + } } void _dumptree_close(entity pass, entity me) { - if(me.firstChild) + if (me.firstChild) { _dumptree_space = substring(_dumptree_space, 0, strlen(_dumptree_space) - 2); LOG_INFO(_dumptree_space, "}\n"); @@ -38,10 +40,10 @@ 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) { LOG_INFO(_("Usage: menu_cmd command..., where possible commands are:\n")); LOG_INFO(_(" sync - reloads all cvars on the current menu page\n")); @@ -53,82 +55,75 @@ void GameCommand(string theCommand) 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) { LOG_INFO(_("Available options:\n")); - float i; - entity e; - string s; - 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)); - } - LOG_INFO(strcat(" ", s ,"\n")); - ++i; + if (!startsWith(s, filter)) continue; + s = substring(s, strlen(filter), strlen(s) - strlen(filter)); } + LOG_INFOF(" %s\n", 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; } + 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.\n")); }