]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/common/command/reg.qh
Merge branch 'terencehill/spectate_player' into 'master'
[xonotic/xonotic-data.pk3dir.git] / qcsrc / common / command / reg.qh
1 #pragma once
2
3 #include "command.qh"
4 REGISTRY(GENERIC_COMMANDS, BITS(7))
5 #define GENERIC_COMMANDS_from(i) _GENERIC_COMMANDS_from(i, NULL)
6 REGISTER_REGISTRY(GENERIC_COMMANDS)
7 REGISTRY_SORT(GENERIC_COMMANDS)
8
9 .bool m_menubased; // switch to tell whether this alias should be registered as a menu or client based command
10
11 #define GENERIC_COMMAND(id, description, menubased) \
12         CLASS(genericcommand_##id, Command) \
13                 ATTRIB(genericcommand_##id, m_name, string, #id); \
14         ATTRIB(genericcommand_##id, m_description, string, description); \
15         ATTRIB(genericcommand_##id, m_menubased, bool, menubased); \
16         ENDCLASS(genericcommand_##id) \
17     REGISTER(GENERIC_COMMANDS, CMD_G, id, m_id, NEW(genericcommand_##id)); \
18         METHOD(genericcommand_##id, m_invokecmd, void(genericcommand_##id this, int request, entity caller, int arguments, string command))
19
20 STATIC_INIT(GENERIC_COMMANDS_aliases) {
21         FOREACH(GENERIC_COMMANDS, true, localcmd(sprintf("alias %1$s \"%2$s %1$s ${* ?}\"\n", it.m_name, ((it.m_menubased) ? "qc_cmd_svmenu" : "qc_cmd_svcl"))));
22 }