X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fcommon%2Fmapinfo.qh;h=10a35ee470a7e3cfbdfc70792dcf4b628977a3da;hb=58b8eafbf5e2ff9147477e115292246458c4c5eb;hp=4de17c92430cfe20f2b0173b6113a20c5e748b09;hpb=8f4d064a1d62a040e788fc0634baf93e888ba2f6;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/common/mapinfo.qh b/qcsrc/common/mapinfo.qh index 4de17c924..10a35ee47 100644 --- a/qcsrc/common/mapinfo.qh +++ b/qcsrc/common/mapinfo.qh @@ -1,20 +1,82 @@ -float MAPINFO_TYPE_DEATHMATCH = 1; -float MAPINFO_TYPE_LMS = 2; -float MAPINFO_TYPE_ARENA = 4; -float MAPINFO_TYPE_RUNEMATCH = 8; -float MAPINFO_TYPE_RACE = 16; -float MAPINFO_TYPE_CTS = 32; -float MAPINFO_TYPE_TEAM_DEATHMATCH = 64; -float MAPINFO_TYPE_CTF = 128; -float MAPINFO_TYPE_CA = 256; -float MAPINFO_TYPE_DOMINATION = 512; -float MAPINFO_TYPE_KEYHUNT = 1024; -float MAPINFO_TYPE_ASSAULT = 2048; -float MAPINFO_TYPE_ONSLAUGHT = 4096; -float MAPINFO_TYPE_NEXBALL = 8192; -float MAPINFO_TYPE_FREEZETAG = 16384; -float MAPINFO_TYPE_KEEPAWAY = 32768; -float MAPINFO_TYPE_ALL = 65535; // this has to include all above bits +float MAPINFO_TYPE_ALL; +entity MapInfo_Type_first; +entity MapInfo_Type_last; +.entity enemy; // internal next pointer + +.float items; // game type ID +.string netname; // game type name as in cvar (with g_ prefix) +.string mdl; // game type short name +.string message; // human readable name +.string model2; // game type defaults + +#define REGISTER_GAMETYPE(hname,sname,g_name,NAME,defaults) \ + var float MAPINFO_TYPE_##NAME; \ + var entity MapInfo_Type##g_name; \ + void RegisterGametypes_##g_name() \ + { \ + MAPINFO_TYPE_##NAME = MAPINFO_TYPE_ALL + 1; \ + MAPINFO_TYPE_ALL |= MAPINFO_TYPE_##NAME; \ + MapInfo_Type##g_name = spawn(); \ + MapInfo_Type##g_name.items = MAPINFO_TYPE_##NAME; \ + MapInfo_Type##g_name.netname = #g_name; \ + MapInfo_Type##g_name.mdl = #sname; \ + MapInfo_Type##g_name.message = hname; \ + MapInfo_Type##g_name.model2 = defaults; \ + if(!MapInfo_Type_first) \ + MapInfo_Type_first = MapInfo_Type##g_name; \ + if(MapInfo_Type_last) \ + MapInfo_Type_last.enemy = MapInfo_Type##g_name; \ + MapInfo_Type_last = MapInfo_Type##g_name; \ + } \ + ACCUMULATE_FUNCTION(RegisterGametypes, RegisterGametypes_##g_name) + +#define IS_GAMETYPE(NAME) \ + (MapInfo_LoadedGametype == MAPINFO_TYPE_##NAME) + +REGISTER_GAMETYPE(_("Deathmatch"),dm,g_dm,DEATHMATCH,"timelimit=20 pointlimit=30 leadlimit=0") +#define g_dm IS_GAMETYPE(DEATHMATCH) + +REGISTER_GAMETYPE(_("Last Man Standing"),lms,g_lms,LMS,"timelimit=20 lives=9 leadlimit=0") +#define g_lms IS_GAMETYPE(LMS) + +REGISTER_GAMETYPE(_("Arena"),arena,g_arena,ARENA,"timelimit=20 pointlimit=10 leadlimit=0") +#define g_arena IS_GAMETYPE(ARENA) + +REGISTER_GAMETYPE(_("Race"),rc,g_race,RACE,"timelimit=20 qualifying_timelimit=5 laplimit=7 teamlaplimit=15 leadlimit=0") +#define g_race IS_GAMETYPE(RACE) + +REGISTER_GAMETYPE(_("Race CTS"),cts,g_cts,CTS,"timelimit=20 skill=-1") +#define g_cts IS_GAMETYPE(CTS) + +REGISTER_GAMETYPE(_("Team Deathmatch"),tdm,g_tdm,TEAM_DEATHMATCH,"timelimit=20 pointlimit=50 teams=2 leadlimit=0") +#define g_tdm IS_GAMETYPE(TEAM_DEATHMATCH) + +REGISTER_GAMETYPE(_("Capture the Flag"),ctf,g_ctf,CTF,"timelimit=20 caplimit=10 leadlimit=0") +#define g_ctf IS_GAMETYPE(CTF) + +REGISTER_GAMETYPE(_("Clan Arena"),ca,g_ca,CA,"timelimit=20 pointlimit=10 leadlimit=0") +#define g_ca IS_GAMETYPE(CA) + +REGISTER_GAMETYPE(_("Domination"),dom,g_domination,DOMINATION,"timelimit=20 pointlimit=200 teams=2 leadlimit=0") +#define g_domination IS_GAMETYPE(DOMINATION) + +REGISTER_GAMETYPE(_("Key Hunt"),kh,g_keyhunt,KEYHUNT,"timelimit=20 pointlimit=1000 teams=3 leadlimit=0") +#define g_keyhunt IS_GAMETYPE(KEYHUNT) + +REGISTER_GAMETYPE(_("Assault"),as,g_assault,ASSAULT,"timelimit=20") +#define g_assault IS_GAMETYPE(ASSAULT) + +REGISTER_GAMETYPE(_("Onslaught"),ons,g_onslaught,ONSLAUGHT,"timelimit=20") +#define g_onslaught IS_GAMETYPE(ONSLAUGHT) + +REGISTER_GAMETYPE(_("Nexball"),nb,g_nexball,NEXBALL,"timelimit=20 pointlimit=5 leadlimit=0") +#define g_nexball IS_GAMETYPE(NEXBALL) + +REGISTER_GAMETYPE(_("Freeze Tag"),ft,g_freezetag,FREEZETAG,"timelimit=20 pointlimit=10 teams=2 leadlimit=0") +#define g_freezetag IS_GAMETYPE(FREEZETAG) + +REGISTER_GAMETYPE(_("Keepaway"),ka,g_keepaway,KEEPAWAY,"timelimit=20 pointlimit=30") +#define g_keepaway IS_GAMETYPE(KEEPAWAY) float MAPINFO_FEATURE_WEAPONS = 1; // not defined for minstagib-only maps float MAPINFO_FEATURE_VEHICLES = 2; @@ -75,13 +137,15 @@ string MapInfo_ListAllowedMaps(float pFlagsRequired, float pFlagsForbidden); string MapInfo_ListAllAllowedMaps(float pFlagsRequired, float pFlagsForbidden); // gets a gametype from a string +string _MapInfo_GetDefaultEx(float t); float MapInfo_Type_FromString(string t); string MapInfo_Type_ToString(float t); -string MapInfo_GetGameTypeCvar(float t); +string MapInfo_Type_ToText(float t); void MapInfo_SwitchGameType(float t); // to be called from worldspawn to set up cvars void MapInfo_LoadMapSettings(string s); +float MapInfo_LoadedGametype; // game type that was active during map load void MapInfo_Cache_Destroy(); // disable caching void MapInfo_Cache_Create(); // enable caching @@ -92,4 +156,4 @@ void MapInfo_ClearTemps(); // call this when done with mapinfo for this frame void MapInfo_Shutdown(); // call this in the shutdown handler #define MAPINFO_SETTEMP_ACL_USER cvar_string("g_mapinfo_settemp_acl") -#define MAPINFO_SETTEMP_ACL_SYSTEM "-g_mapinfo_* -rcon_* -settemp_* -_* -g_ban* +*" +#define MAPINFO_SETTEMP_ACL_SYSTEM "-g_mapinfo_* -rcon_* -_* -g_ban* +*"