]> icculus.org git repositories - divverent/nexuiz.git/blob - data/qcsrc/common/mapinfo.qh
no-operation change to pave the way for fuel and jetpack pickups
[divverent/nexuiz.git] / data / qcsrc / common / mapinfo.qh
1 float MAPINFO_TYPE_CTF                          = 1;
2 float MAPINFO_TYPE_ASSAULT                      = 2;
3 float MAPINFO_TYPE_ONSLAUGHT            = 4;
4 float MAPINFO_TYPE_RACE                         = 8;
5 float MAPINFO_TYPE_DEATHMATCH           = 16;
6 float MAPINFO_TYPE_TEAM_DEATHMATCH      = 32;
7 float MAPINFO_TYPE_DOMINATION           = 64;
8 float MAPINFO_TYPE_RUNEMATCH            = 128;
9 float MAPINFO_TYPE_LMS                          = 256;
10 float MAPINFO_TYPE_ARENA                        = 512;
11 float MAPINFO_TYPE_KEYHUNT                      = 1024;
12 float MAPINFO_TYPE_ALL              = 65535; // this has to include all above bits
13
14 float MAPINFO_FEATURE_WEAPONS       = 1; // not defined for minstagib-only maps
15
16 float MAPINFO_FLAG_HIDDEN           = 1; // not in lsmaps/menu/vcall/etc., can just be changed to manually
17 float MAPINFO_FLAG_FORBIDDEN        = 2; // don't even allow the map by a cvar setting that allows hidden maps
18
19 float MapInfo_count;
20
21 // info about a map that MapInfo loads
22 string MapInfo_Map_bspname;
23 string MapInfo_Map_title;
24 string MapInfo_Map_description;
25 string MapInfo_Map_author;
26 string MapInfo_Map_clientstuff; // not in cache, only for map load
27 string MapInfo_Map_fog; // not in cache, only for map load
28 float MapInfo_Map_supportedGametypes;
29 float MapInfo_Map_supportedFeatures;
30 float MapInfo_Map_flags;
31 vector MapInfo_Map_mins; // these are '0 0 0' if not supported!
32 vector MapInfo_Map_maxs; // these are '0 0 0' if not specified!
33
34 // load MapInfo_count; generate mapinfo for maps that miss them, and clear the
35 // cache; you need to call MapInfo_FilterGametype afterwards!
36 void MapInfo_Enumerate();
37
38 // filter the info by game type mask (updates MapInfo_count)
39 float MapInfo_progress;
40 float MapInfo_FilterGametype(float gametype, float features, float pFlagsRequired, float pFlagsForbidden, float pAbortOnGenerate); // 1 on success, 0 on temporary failure (call it again next frame then; use MapInfo_progress as progress indicator)
41 float MapInfo_CurrentFeatures(); // retrieves currently required features from cvars
42 float MapInfo_CurrentGametype(); // retrieves current gametype from cvars
43
44 // load info about the i-th map into the MapInfo_Map_* globals
45 float MapInfo_Get_ByID(float i); // 1 on success, 0 on failure
46 string MapInfo_BSPName_ByID(float i);
47
48 // load info about a map by name into the MapInfo_Map_* globals
49 float MapInfo_Get_ByName(string s, float allowGenerate, float gametypeToSet); // 1 on success, 0 on failure, 2 if it autogenerated a mapinfo file
50
51 // look for a map by a prefix, returns the actual map name on success, string_null on failure or ambigous match
52 string MapInfo_FindName_match; // the name of the map that was found
53 float MapInfo_FindName_firstResult; // -1 if none were found, index of first one if not unique but found (FindName then returns -1)
54 float MapInfo_FindName(string s);
55 string MapInfo_FixName(string s);
56
57 // play a map
58 float MapInfo_CheckMap(string s); // returns 0 if the map can't be played with the current settings
59 void MapInfo_LoadMap(string s);
60
61 // list all maps for the current game type
62 string MapInfo_ListAllowedMaps(float pFlagsRequired, float pFlagsForbidden);
63
64 // gets a gametype from a string
65 float MapInfo_Type_FromString(string t);
66 string MapInfo_GetGameTypeCvar(float t);
67 void MapInfo_SwitchGameType(float t);
68
69 // to be called from worldspawn to set up cvars
70 void MapInfo_LoadMapSettings(string s);
71
72 void MapInfo_Cache_Destroy(); // disable caching
73 void MapInfo_Cache_Create(); // enable caching
74 void MapInfo_Cache_Invalidate(); // delete cache if any, but keep enabled
75
76 void MapInfo_ClearTemps(); // call this when done with mapinfo for this frame
77
78 void MapInfo_Shutdown(); // call this in the shutdown handler