X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;ds=sidebyside;f=qcsrc%2Fserver%2Fdefs.qh;h=e60743c51397f2e2eb8fa0fb73f79a4c8a694898;hb=6f94f5de458d2e8f20ca1fb95661ee1d0cd330c9;hp=dd47b86a461e23ad6bf4bc3217164e84e10cbcf7;hpb=724a41faf2cbfd86d41f3ab59ff8326a831a8326;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/defs.qh b/qcsrc/server/defs.qh index dd47b86a4..e60743c51 100644 --- a/qcsrc/server/defs.qh +++ b/qcsrc/server/defs.qh @@ -1,48 +1,17 @@ -#ifndef SERVER_DEFS_H -#define SERVER_DEFS_H +#pragma once -#include "../common/weapons/all.qh" -#include "../common/stats.qh" +float warmup_limit; +#include +#include #define INDEPENDENT_ATTACK_FINISHED 1 -// TODO: deprecated: remove. Replaced by physics.qh PHYS_INPUT_BUTTON_* - -#define BUTTON_ATCK button0 -#define BUTTON_JUMP button2 -#define BUTTON_ATCK2 button3 -#define BUTTON_ZOOM button4 -#define BUTTON_CROUCH button5 -#define BUTTON_HOOK button6 -#define BUTTON_INFO button7 -#define BUTTON_DRAG button8 -#define BUTTON_USE buttonuse -#define BUTTON_CHAT buttonchat -#define BUTTON_PRYDON cursor_active -#define BUTTON_ZOOMSCRIPT button9 -#define BUTTON_JETPACK button10 - // Globals float g_footsteps, g_grappling_hook, g_instagib; -float g_warmup_limit; float g_warmup_allguns; float g_warmup_allow_timeout; float warmup_stage; -PROPERTY(float, g_pickup_respawntime_weapon) -PROPERTY(float, g_pickup_respawntime_superweapon) -PROPERTY(float, g_pickup_respawntime_ammo) -PROPERTY(float, g_pickup_respawntime_short) -PROPERTY(float, g_pickup_respawntime_medium) -PROPERTY(float, g_pickup_respawntime_long) -PROPERTY(float, g_pickup_respawntime_powerup) -PROPERTY(float, g_pickup_respawntimejitter_weapon) -PROPERTY(float, g_pickup_respawntimejitter_superweapon) -PROPERTY(float, g_pickup_respawntimejitter_ammo) -PROPERTY(float, g_pickup_respawntimejitter_short) -PROPERTY(float, g_pickup_respawntimejitter_medium) -PROPERTY(float, g_pickup_respawntimejitter_long) -PROPERTY(float, g_pickup_respawntimejitter_powerup) float g_jetpack; float sv_clones; @@ -52,7 +21,7 @@ float player_count; float currentbots; float bots_would_leave; -void UpdateFrags(entity player, float f); +void UpdateFrags(entity player, int f); .float totalfrags; float team1_score, team2_score, team3_score, team4_score; @@ -72,7 +41,7 @@ float server_is_dedicated; .float inactive; // Clientwall disappears when inactive .float alpha_max, alpha_min; .float fade_start, fade_end, fade_vertical_offset; -.float default_solid; // Variable to store default self.solid for clientwalls +.float default_solid; // Variable to store default .solid for clientwalls .float pain_finished; //Added by Supajoe .float pain_frame; //" @@ -94,7 +63,7 @@ float server_is_dedicated; .float fade_time; .float fade_rate; -void() player_setupanimsformodel; +void player_setupanimsformodel(entity this); .string mdl; @@ -106,6 +75,7 @@ void() player_setupanimsformodel; .float scheduledrespawntime; .float respawntime; .float respawntimejitter; +.float respawntimestart; //.float chasecam; .float damageforcescale; @@ -146,7 +116,7 @@ const float MAX_DAMAGEEXTRARADIUS = 16; // WEAPONTODO .float autoswitch; -bool client_hasweapon(entity cl, Weapon wpn, float andammo, bool complain); +bool client_hasweapon(entity this, Weapon wpn, .entity weaponentity, float andammo, bool complain); void w_clear(Weapon thiswep, entity actor, .entity weaponentity, int fire); void w_ready(Weapon thiswep, entity actor, .entity weaponentity, int fire); // VorteX: standalone think for weapons, so normal think on weaponentity can be reserved by weaponflashes (which needs update even player dies) @@ -171,7 +141,7 @@ float alreadychangedlevel; float blockSpectators; //if set, new or existing spectators or observers will be removed unless they become a player within g_maxplayers_spectator_blocktime seconds .float spectatortime; //point in time since the client is spectating or observing -void checkSpectatorBlock(); +void checkSpectatorBlock(entity this); float game_completion_ratio; // 0 at start, 1 near end .float winning; @@ -187,7 +157,6 @@ bool nJoinAllowed(entity this, entity ignore); .entity flagcarried; .int playerid; -float playerid_last; .float noalign; // if set to 1, the item or spawnpoint won't be dropped to the floor .vector death_origin; @@ -196,7 +165,6 @@ float playerid_last; float default_player_alpha; float default_weapon_alpha; -.float() customizeentityforclient; .float cvar_cl_handicap; .float cvar_cl_clippedspectating; .float cvar_cl_autoscreenshot; @@ -230,7 +198,6 @@ void FixClientCvars(entity e); WepSet weaponsInMap; #define weapons _STAT(WEAPONS) -#define weaponsinmap _STAT(WEAPONSINMAP) .float respawn_countdown; // next number to count @@ -243,7 +210,7 @@ float bot_waypoints_for_items; #else #define ATTACK_FINISHED_FOR(ent, w, slot) ((ent).attack_finished_single[slot]) #endif -#define ATTACK_FINISHED(ent, slot) ATTACK_FINISHED_FOR(ent, PS(ent).m_weapon.m_id, slot) +#define ATTACK_FINISHED(ent, slot) ATTACK_FINISHED_FOR(ent, ent.(weaponentity).m_weapon.m_id, slot) // assault game mode: Which team is attacking in this round? float assault_attacker_team; @@ -272,6 +239,8 @@ float lockteams; .float parm_idlesince; float sv_maxidle; float sv_maxidle_spectatorsareidle; +int sv_maxidle_slots; +bool sv_maxidle_slots_countbots; float tracebox_hits_trigger_hurt(vector start, vector mi, vector ma, vector end); @@ -302,8 +271,6 @@ float cvar_purechanges_count; float game_starttime; //point in time when the countdown to game start is over float round_starttime; //point in time when the countdown to round start is over -.float stat_game_starttime = _STAT(GAMESTARTTIME); -.float stat_round_starttime = _STAT(ROUNDSTARTTIME); void W_Porto_Remove (entity p); @@ -311,8 +278,6 @@ void W_Porto_Remove (entity p); .string message2; -.bool stat_allow_oldvortexbeam = _STAT(ALLOW_OLDVORTEXBEAM); - // reset to 0 on weapon switch // may be useful to all weapons .float bulletcounter; @@ -321,11 +286,11 @@ void W_Porto_Remove (entity p); .entity ballcarried; // Also used for keepaway float g_nexball_meter_period; -void SUB_DontUseTargets(); -void SUB_UseTargets(); +void SUB_DontUseTargets(entity this, entity actor, entity trigger); +void SUB_UseTargets(entity this, entity actor, entity trigger); .void(entity this) reset; // if set, an entity is reset using this -.void() reset2; // if set, an entity is reset using this (after calling ALL the reset functions for other entities) +.void(entity this) reset2; // if set, an entity is reset using this (after calling ALL the reset functions for other entities) void ClientData_Touch(entity e); @@ -359,8 +324,6 @@ string matchid; .float damage_dealt_total = _STAT(DAMAGE_DEALT_TOTAL); -.float stat_leadlimit = _STAT(LEADLIMIT); - bool radar_showennemies; #ifdef PROFILING @@ -395,7 +358,7 @@ float client_cefc_accumulatortime; string deathmessage; -.float just_joined; +.bool just_joined; .float cvar_cl_weaponimpulsemode; .float selectweapon; // last selected weapon of the player @@ -408,7 +371,7 @@ const float ACTIVE_IDLE = 2; const float ACTIVE_BUSY = 2; const float ACTIVE_TOGGLE = 3; .float active; -.void (float act_state) setactive; +.void (entity this, int act_state) setactive; .entity realowner; //float serverflags; @@ -418,7 +381,6 @@ const float ACTIVE_TOGGLE = 3; .float player_blocked; .float weapon_blocked; // weapon use disabled -.float frozen = _STAT(FROZEN); // for freeze attacks .float revive_progress = _STAT(REVIVE_PROGRESS); .float revival_time; // time at which player was last revived .float revive_speed; // NOTE: multiplier (anything above 1 is instaheal) @@ -430,9 +392,9 @@ const float ACTIVE_TOGGLE = 3; .float stat_respawn_time = _STAT(RESPAWN_TIME); // shows respawn time, and is negative when awaiting respawn -void PlayerUseKey(); +void PlayerUseKey(entity this); -typedef vector(entity player, entity spot, vector current) spawn_evalfunc_t; +USING(spawn_evalfunc_t, vector(entity this, entity player, entity spot, vector current)); .spawn_evalfunc_t spawn_evalfunc; string modname; @@ -454,7 +416,6 @@ const int MIF_GUIDED_CONFUSABLE = MIF_GUIDED_HEAT | MIF_GUIDED_AI; #define MISSILE_IS_GUIDED(m) ((m.missile_flags & MIF_GUIDED_ALL) ? true : false) #define MISSILE_IS_TRACKING(m) ((m.missile_flags & MIF_GUIDED_TRACKING) ? true : false) - //// .entity player_stats; @@ -465,7 +426,49 @@ const int MIF_GUIDED_CONFUSABLE = MIF_GUIDED_HEAT | MIF_GUIDED_AI; .string cvar_cl_physics; -.float init_for_player_needed; -.void(entity) init_for_player; +.void(entity this, entity player) init_for_player; -#endif +IntrusiveList g_monsters; +STATIC_INIT(g_monsters) { g_monsters = IL_NEW(); } + +IntrusiveList g_waypoints; +STATIC_INIT(g_waypoints) { g_waypoints = IL_NEW(); } + +IntrusiveList g_vehicles; +STATIC_INIT(g_vehicles) { g_vehicles = IL_NEW(); } + +IntrusiveList g_turrets; +STATIC_INIT(g_turrets) { g_turrets = IL_NEW(); } + +IntrusiveList g_mines; +STATIC_INIT(g_mines) { g_mines = IL_NEW(); } + +IntrusiveList g_projectiles; +STATIC_INIT(g_projectiles) { g_projectiles = IL_NEW(); } + +IntrusiveList g_items; +STATIC_INIT(g_items) { g_items = IL_NEW(); } + +IntrusiveList g_initforplayer; +STATIC_INIT(g_initforplayer) { g_initforplayer = IL_NEW(); } + +IntrusiveList g_clones; +STATIC_INIT(g_clones) { g_clones = IL_NEW(); } + +IntrusiveList g_assault_destructibles; +STATIC_INIT(g_assault_destructibles) { g_assault_destructibles = IL_NEW(); } + +IntrusiveList g_assault_objectivedecreasers; +STATIC_INIT(g_assault_objectivedecreasers) { g_assault_objectivedecreasers = IL_NEW(); } + +IntrusiveList g_assault_objectives; +STATIC_INIT(g_assault_objectives) { g_assault_objectives = IL_NEW(); } + +IntrusiveList g_spawnpoints; +STATIC_INIT(g_spawnpoints) { g_spawnpoints = IL_NEW(); } + +IntrusiveList g_bot_targets; +STATIC_INIT(g_bot_targets) { g_bot_targets = IL_NEW(); } + +IntrusiveList g_bot_dodge; +STATIC_INIT(g_bot_dodge) { g_bot_dodge = IL_NEW(); }