]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blobdiff - qcsrc/menu/command/menu_cmd.qc
When possible use simpler LOG_* macros instead of LOG_*F
[xonotic/xonotic-data.pk3dir.git] / qcsrc / menu / command / menu_cmd.qc
index 179dc1949bad8c371ab1c0c2c901d6b6befbbb20..93deaff332aae873c8bfaa2a1e3d741a9b484a4c 100644 (file)
@@ -1,9 +1,11 @@
 #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;
 
@@ -12,25 +14,25 @@ void _dumptree_open(entity pass, entity me)
 {
        string s;
        s = me.toString(me);
-       if(s == "")
-               s = me.classname;
-       else
-               s = strcat(me.classname, ": ", s);
-       LOG_INFO(_dumptree_space, etos(me), " (", s, ")");
-       if(me.firstChild)
+       if (s == "") s = me.classname;
+       else s = strcat(me.classname, ": ", 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)
+       if (me.firstChild)
        {
                _dumptree_space = substring(_dumptree_space, 0, strlen(_dumptree_space) - 2);
-               LOG_INFO(_dumptree_space, "}\n");
+               print(_dumptree_space, "}\n");
        }
 }
 
@@ -38,97 +40,92 @@ 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"));
-               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(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;
+                       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
+               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;
        }
 
-       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."));
 }