#include "menu_cmd.qh"
#include "../menu.qh"
-#include "../oo/classes.qc"
+#include "../item.qh"
-#include "../../common/command/generic.qh"
+#include <menu/mutators/_mod.qh>
+
+#include <common/command/_mod.qh>
.entity firstChild, nextSibling;
s = me.toString(me);
if (s == "") s = me.classname;
else s = strcat(me.classname, ": ", s);
- LOG_INFO(_dumptree_space, etos(me), " (", s, ")");
+ print(_dumptree_space, etos(me), " (", s, ")");
if (me.firstChild)
{
- LOG_INFO(" {\n");
+ print(" {\n");
_dumptree_space = strcat(_dumptree_space, " ");
}
else
{
- LOG_INFO("\n");
+ print("\n");
}
}
void _dumptree_close(entity pass, entity me)
if (me.firstChild)
{
_dumptree_space = substring(_dumptree_space, 0, strlen(_dumptree_space) - 2);
- LOG_INFO(_dumptree_space, "}\n");
+ print(_dumptree_space, "}\n");
}
}
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)
{
- LOG_INFO(_("Usage: menu_cmd command..., where possible commands are:\n"));
- LOG_INFO(_(" sync - reloads all cvars on the current menu page\n"));
- LOG_INFO(_(" 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"));
+ LOG_INFO("\n");
- LOG_INFO("\nGeneric commands shared by all programs:\n");
+ LOG_INFO("Generic commands shared by all programs:");
GenericCommand_macro_help();
return;
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)
{
- LOG_INFO(_("Available options:\n"));
- float i;
- entity e;
- string s;
+ LOG_INFO(_("Available options:"));
- for (i = 0, e = NULL; (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_INFO(" ", s);
+ });
}
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;
}
return;
}
- LOG_INFO(_("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."));
}