X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fcommon%2Fminigames%2Fsv_minigames.qh;h=e36d690d9bc743247aabbc104a3f7971e6e24b5a;hb=21307f327df5609b82d90496c1c6156d636d1c8d;hp=246440d39e5d0f84f03f06c0353033f03f5f4967;hpb=7bae88d09fbd53cce732e31633aea92671b43699;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/common/minigames/sv_minigames.qh b/qcsrc/common/minigames/sv_minigames.qh index 246440d39..e36d690d9 100644 --- a/qcsrc/common/minigames/sv_minigames.qh +++ b/qcsrc/common/minigames/sv_minigames.qh @@ -1,9 +1,6 @@ #ifndef SV_MINIGAMES_H #define SV_MINIGAMES_H -/// Initialize the minigame system -void initialize_minigames(); - /// Create a new minigame session /// \return minigame session entity entity start_minigame(entity player, string minigame ); @@ -47,6 +44,19 @@ entity minigame_find_player(entity client); entity minigame_sessions; -bool minigame_SendEntity(entity to, int sf); +bool minigame_SendEntity(entity this, entity to, int sf); + +REGISTRY(Minigames, BIT(3)) +REGISTER_REGISTRY(RegisterMinigames) +#define REGISTER_MINIGAME(name,nicename) \ + REGISTER(RegisterMinigames, MINIGAME, Minigames, name, m_id, spawn()); \ + int name##_server_event(entity, string, ...); \ + REGISTER_INIT_POST(MINIGAME, name) { \ + this.classname = "minigame_descriptor"; \ + this.netname = strzone(strtolower(#name)); \ + this.message = nicename; \ + this.minigame_event = name##_server_event; \ + } \ + REGISTER_INIT(MINIGAME, name) #endif