quakec/source/server/defs/custom.qc

633 lines
No EOL
14 KiB
C++

/*
server/defs/custom.qc
put custom server-only globals and fields here
Copyright (C) 2021-2024 NZ:P Team
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to:
Free Software Foundation, Inc.
59 Temple Place - Suite 330
Boston, MA 02111-1307, USA
*/
#ifndef STANDARD
#pragma target fte_5768
#endif // STANDARD
#define true 1
#define false 0
#define FL_JUMPRELEASED 4096
#define STR_NOTENOUGHPOINTS "Not Enough Points\n" // To help aid consistency with these..
#define SPAWN_1_CLASS "info_player_1_spawn"
#define SPAWN_2_CLASS "info_player_2_spawn"
#define SPAWN_3_CLASS "info_player_3_spawn"
#define SPAWN_4_CLASS "info_player_4_spawn"
float cheats_have_been_activated;
// Quake assumes these are defined.
string string_null;
.string killtarget;
entity activator;
float framecount;
float music_override;
.float recoil_delay;
.float cur_spread;
#ifndef FTE
void(string com) SV_ParseClientCommand;
.float gravity;
.float mapversion;
.float ammo;
.float frags;
#endif // FTE
// achievement tracking
.float ach_tracker_npnp;
.float ach_tracker_abst;
.float ach_tracker_coll;
float ach_tracker_col2;
float ach_tracker_barr;
float ach_tracker_spin;
float global_trace_damage_multiplier;
.float has_ads_toggle;
.float ads_release;
.float has_doubletap_damage_buff;
.vector oldvelocity;
.float lastsound_time;
.float isspec;
string mappath;
.float ads_toggle;
float player_count;
entity pl1;
.string fog; // used for hacking in changing fog from world.fog for legacy maps
entity local_client;
.float stance;
.float stancereset;
.float changestance;
.vector new_ofs;
//money
.float points;
.float cost;
.float cost2;
//stats
.float score;
.float kills;
.float headshots;
#ifdef FTE
.float facingenemy;
#endif // FTE
//doors
.float state;
#define STATE_TOP 0
#define STATE_BOTTOM 1
#define STATE_UP 2
#define STATE_DOWN 3
.float /*worldtype,*/ delay, wait, lip, /*light_lev,*/ speed, style/*, skill*/;
.float requirespower;
//player funcs
#ifdef FTE
.float zoom;
#endif // FTE
.float damage_timer; // Used for time-based damage infliction such as Traps.
.float speed_penalty; // A multiplier for limiting player speed. Also
// prohibits sprinting.
.float speed_penalty_time; // A timer for how long speed_penalty is applied for.
float sprint_max_time = 4.0;
.float sprinting;
.float weaponskin;
.float stamina;
.float sprint_timer;
.float sprint_duration;
.float sprint_timer_stopped;
.float sprint_start_time;
.float sprint_stop_time;
.float sprint_rest_time;
.float tp_anim_time;
.float tp_anim_type;
void() W_SprintStop;
.float into_sprint;
.float dive;
.float dive_delay;
.vector movement;
.float hunt_count; // How many Hellhounds are hunting a client
//Weaponsystem defines
void GetUp();
void WeaponCore_ClientLogic();
void (float shotcount, float sprd, float Damage, float side) FireTrace;
.float downed;
.float fire_delay;
.float fire_delay2;
.float reload_delay;
.float reload_delay2;
.float switch_delay;
.float health_delay;
.float health_was_very_low;
.float progress_bar;
.float progress_bar_time;
.float progress_bar_percent;
.float weaponbk;
.float currentmag;
.float currentmag2;
.float currentmagbk;
.float currentmagbk2;
.float currentammobk;
.float NeedLoad;
.string weapon2model;
.float weapon2frame;
.float reloadinterupted;
.float hitcount;
#ifdef FTE
.float weapon2modelindex;
#endif // FTE
#define SEMIACTION_FIRE_RIGHT 1
#define SEMIACTION_FIRE_LEFT 2
#define SEMIACTION_USE 4
#define SEMIACTION_GRENADE 8
#define SEMIACTION_MELEE 16
#define SEMIACTION_WAYPOINT 32
#define SEMIACTION_WEAPONSWAP 64
// Semi-automatic actions (requires button release)
.float semi_actions;
#define MAX_PLAYER_WEAPONS 3
#define MULEKICK_WEAPON_SLOT 3
var struct guninventory_struct
{
float weapon_id;
float weapon_magazine;
float weapon_magazine_left;
float weapon_reserve;
float weapon_skin;
float is_mulekick_weapon;
};
.guninventory_struct weapons[MAX_PLAYER_WEAPONS];
.float weapon_count;
//Reviving
.float invoke_revive;
.float reviving;
.float revived;
.float beingrevived;
.float downedloop;
#define S_LEFT 0
#define S_RIGHT 1
#define S_BOTH 2
//Knife
.float knife_delay;
.float bowie;
//Grenades
.float grenades;
.float pri_grenade_state;
.float bk_nade;
.float grenade_delay;
.float secondary_grenades;
.float primary_grenades;
.float throw_delay;
//weapon frames
void Set_W_Frame (float startframe, float endframe, float duration, float funccalledin, float animtype, void(optional float t) endanimfunc, string set_model, float dontstartnew, float side, float lock_viewmodel);
.float weapon_animduration;
.float weapon2_animduration;
.float weapon_anim_type;
.float weapon2_anim_type;
.float anim_weapon_time;
.float anim_weapon2_time;
.float weaponframe_end;
.float weapon2frame_end;
.float callfuncat;
.float callfuncat2;
.float new_anim_stop;
.float new_anim2_stop;
.float anim_reversed;
.float anim2_reversed;
.void() animend;
.void(optional float t) animend2;
string(string path) Compat_ConvertOldAssetPath;
//Null functions
void() SUB_Null = {};
void() SUB_Null2 = {};
#define VEC_HULL_MIN '-16 -16 -36'
#define VEC_HULL_MAX '16 16 36'
#define VEC_HULL2_MIN '-32 -32 -24'
#define VEC_HULL2_MAX '32 32 64'
#define VIEW_OFS_HL '0 0 32'
#define VIEW_OFS_QK '0 0 22'
.string name;
vector trace_plane_normal;
.float dmg;
.float fire_timeout;
//
// AI definitions
// Used for global one-zombie-at-a-time type ai
//
void Do_Zombie_AI();
void Z_ElectroShock();
.float electro_targeted; // Marks Zombie as waiting to die via Electro-Shock
.float death_timer; // A timer that will kill a Zombie when it expires.
.float death_timer_activated; // To prevent Zombies just dying because of this..
.float is_attacking; // Returns true if Zombie is in the middle of an attack.
#ifndef FTE
entity lastzombie; // Used by non-FTE to update zombie AI one ent at a time.
#endif // FTE
.string aistatus;
float zombie_spawn_delay; // time before spawning, in seconds.
float zombie_spawn_timer; // the actual timer for spawn delay
//Other AI definitions
.vector box1, box2, box3;//used for windows and zombies
.vector idlebox;
.vector hop_spot;//used for windows (zombies hop to these)
.vector goalorigin;
.float teslacount; // TODO - Remove this
.float tesla_n_kills; // Player - Number of kills remaining for the current tesla shot
.float tesla_next_arc_time; // Zombie - Time at which zombie should try arcing
.float tesla_arc_num; // Zombie - current arc number
.entity tesla_arc_parent; // Zombie - Track the entity that we arced from
.entity tesla_arc_owner; // Zombie - Player ent that fired the tesla
void(vector pos) tesla_spark;
.float iszomb;
.float onfire;
.entity firer;
float crawler_num;
float zombie_spawn_points;
//==== Reference Vars ====
#define WWINDOW 1
#define WBOX1 2
#define WBOX2 4
#define WBOX3 8
#define WIDLEBOX 16
//========================
// Definitions for the `.dimension_hit` and `.dimension_solid` fields
// Used to let limbs be non-solid to player bbox but still be hit by player tracelines
#define HITBOX_DIM_LIMBS 1
#define HITBOX_DIM_ZOMBIES 2
//we're using usedent for who is currently hopping the window
//Used for windows to keep track of what zombies are at windows
.entity box1owner, box2owner, box3owner;
.entity usedent;
//.float used;//used for the window boxes//not anymore
.float outside;//used for knowing if a zomibe has hopped window yet
.float chase_enemy_time;
.float chase_time;
.float enemy_timeout;
//.float pathing;
.float calc_time; // used as a delay thing (so zombie ai doesn't run
// 100% of the time
.string zappername; // An identifier similar to targetname used to link
// Electric Trap components.
.string target2;
.string target3;
.string target4;
.string target5;
.string target6;
.string target7;
.string target8;
.string wayTarget;
.entity active_door; // Set in waypoint mode
.string targetname; // the name of an entitys
entity lastspawn; // last spawn point used by spawning code
.entity goaldummy; // Used to store the origin of the zombies target
.float goalway; // Used to store the origin of the zombies target
.float walktype; // decides animations and moving speeds for zombies
.float spawn_id; // assigned to spawn point ents, for grabbing one at random.
.void() th_walk;
//.void() th_run;
.void() th_die;
.void() th_melee;
.void() th_idle;
.void() th_windowhop;
.void() th_diewunder;
.void() th_fall;
.void() th_falling;
.void() th_land;
.void() th_jump;
.void() th_grabledge;
.float tries;
.float hop_step;//KEEPS TRACK OF WHERE WE ARE ON THE HOPPING PART
float INACTIVE = 1;
float tracemove(vector start, vector min, vector max, vector end, float nomonsters, entity forent);
.float way_path[40];
.float way_cur;
.float sound_time;
.float s_time;
float sounds_playing;
.float fall;
//.vector lastOrg;//Zombie's last origin, for checking stuckness
//.float OrgStuckCount;
.float crawling;
#define HIT_REGION_HEAD 1
#define HIT_REGION_ARM 2
#define HIT_REGION_TORSO_LOWER 3
#define HIT_REGION_TORSO_UPPER 4
.float washit;
.float hit_region;
.float hitamount;
.float laststep;
void(entity who) makeCrawler;
.float state;//used to delay making a crawler, ex) when zombie is rising from ground or climbing over barrier, turn zombie into a crawler afterwards
void() spawnAllZombEnts;
void() set_z_health;
float() spawn_a_zombieA;
float gotdog;
float dogRound;
float dogWave;
float dog_round_count;
float z_health;
.float bleedingtime;
.float time_to_die;
.float respawn_timer;
.float respawn_iterator;
float crandom();
// Door
.void() think1;
.vector finaldest;
.vector pos1, pos2/*, mangle*/;
.vector finalangle;
.float distance;
.float sequence;
.entity active_door;
.string door_model_target;
.string door_model_name;
//Perk and Power system
#define PERK_QUICKREVIVE_DEFAULT_MODEL "models/machines/quake_scale/quick_revive.mdl"
#define PERK_JUGGERNOG_DEFAULT_MODEL "models/machines/quake_scale/juggernog.mdl"
#define PERK_SPEEDCOLA_DEFAULT_MODEL "models/machines/quake_scale/speed_cola.mdl"
#define PERK_DOUBLETAP_DEFAULT_MODEL "models/machines/quake_scale/double_tap.mdl"
#define PERK_PHDFLOPPER_DEFAULT_MODEL "models/machines/quake_scale/flopper.mdl"
#define PERK_STAMINUP_DEFAULT_MODEL "models/machines/quake_scale/staminup.mdl"
#define PERK_DEADSHOT_DEFAULT_MODEL "models/machines/quake_scale/deadshot.mdl"
#define PERK_MULEKICK_DEFAULT_MODEL "models/machines/quake_scale/mulekick.mdl"
float isPowerOn;
.float isBuying; // naievil -- used for checking if a perk is being consumed, limits glitching
.float perks;
.float perk_delay;
.float perk_purchase_count;
.float perk_purchase_limit_solo;
.float perk_purchase_limit_coop;
.float perk_requires_power_solo;
.float perk_requires_power_coop;
// Mystery Box
#define MAX_BOX_WEAPONS 27
.float boxstatus;
.entity boxweapon;
.float spins;
.float papState;
var struct mbox_struct
{
float weapon_id; // ID for the relevant weapon.
float allowed; // 1 for allowed, 0 for denied.
float rarity; // 0-100 (float) percent change for obtaining. -1 for normal.
float already_obtained; // true if only one allowed and a client already holds it.
} mystery_box_weapons[MAX_BOX_WEAPONS] = {};
float mystery_box_count;
float mystery_box_leave_count;
float mystery_box_cost;
string mystery_box_model;
string mystery_box_glow_model;
string mystery_box_open_sound;
string mystery_box_close_sound;
entity mystery_boxes[16];
vector mystery_box_start_origin;
#ifdef FTE
//powerups
.float x2_icon;
.float insta_icon;
#endif // FTE
.string powerup_vo;
float instakill_finished;
float insta_blink;
float x2_finished;
float x2_blink;
float total_windows_down;
float total_powerup_points;
float powerup_score_threshold;
float powerup_activate;
float carp_powerup_active;
float nuke_powerup_active;
float nuke_powerups_activated;
float nuke_powerup_spawndelay;
//rounds
float roundinit;
float roundtype;
float Current_Zombies;
float Total_Zombies;
float Remaining_Zombies;
float Delay_Time;
float spawn_time;
float round_changetime;
float blink_return;
float delay_at_round;
float spawn_delay;
float totalpowerups;
float sounds_playing;
float barricade_reward_maximum;
.float barricade_reward;
float rounds;
float rounds_change;
//Waypoints
void () Waypoint_Logic;
entity current_way;
float waypoint_mode;
entity active_way;
#define MAX_WAY_TARGETS 10
.string waynum;
.string targets[MAX_WAY_TARGETS];
//pathfinds
#define MAX_WAYPOINTS 256 //max waypoints
void LoadWaypointData();
typedef struct
{
vector org;
float id;
float g, f;
float next, prev;
float step;
float target_id [MAX_WAY_TARGETS]; // Targets array number
string targetdoor; //special tag is required for the closed waypoints
float dist [MAX_WAY_TARGETS]; // Distance to the next waypoints
float set;
} waypoint_ai;
#define SET_NONE 0
#define SET_OPEN 1
#define SET_CLOSED 2
#ifdef FTE
waypoint_ai waypoints[MAX_WAYPOINTS];
#endif // FTE
#define UT_HUD 1
#define UT_ROUNDS_CHANGE 2
#define UT_HM 3
#define UT_ZOOM2 4
#define UT_CROSSHAIR 5
//Misc patch definitions
.string teddyremovetarget;
.float entity_removed;
.float oldz; // used for fall damage that does not truly work correctly
.float sprint_delay;
//soft restart stuff for doors
.string oldmodel;
.vector oldorigin;
.float oldstate;
.float state;
.float isopen;
//world
.string chaptertitle;
.string location;
.string date;
.string person;
.string song;
//altered game elements
float G_STARTPOINTS;
float G_STARTROUND;
float G_PRONEPOINTS;
float G_STARTWEAPON[3];
float G_WORLDTEXT;
float G_PERKS;
float G_PERKPOWER;
.float activated;
//teleporter
.entity tele_target;
.float mode;
.float cooldown;
.float isLinked;
.float waitLink;
.float tpTimer;
.float isTimed;
.entity host;
.entity entities[4];
// GIBBING
.entity larm;
.entity rarm;
.entity head;
.vector bbmins, bbmaxs;
.float currentHitBoxSetup;
.float sprintflag;
// hl stuff
.float rendermode;
.float renderamt;
.vector rendercolor;
#ifdef FTE
.float last_solid;
.float had_solid_modified;
#endif // FTE