int sententitiesmark;
int sententities[MAX_EDICTS];
int sententitiesconsideration[MAX_EDICTS];
+
+ // legacy support for self.Version based csqc entity networking
+ unsigned char csqcentityversion[MAX_EDICTS]; // legacy
} server_t;
+#define NUM_CSQCENTITIES_PER_FRAME 1024
+typedef struct csqcentityframedb_s
+{
+ int framenum;
+ int num;
+ unsigned short entno[NUM_CSQCENTITIES_PER_FRAME];
+ int sendflags[NUM_CSQCENTITIES_PER_FRAME];
+} csqcentityframedb_t;
+
// if defined this does ping smoothing, otherwise it does not
//#define NUM_PING_TIMES 16
// visibility state
float visibletime[MAX_EDICTS];
- // version number of csqc-based entity to decide whether to send it
- unsigned char csqcentityversion[MAX_EDICTS];
+ // scope is whether an entity is currently being networked to this client
+ // sendflags is what properties have changed on the entity since the last
+ // update that was sent
+ int csqcnumedicts;
+ unsigned char csqcentityscope[MAX_EDICTS];
+ unsigned int csqcentitysendflags[MAX_EDICTS];
+
+#define NUM_CSQCENTITYDB_FRAMES 64
+ unsigned char csqcentityglobalhistory[MAX_EDICTS]; // set to 1 if the entity was ever csqc networked to the client, and never reset back to 0
+ csqcentityframedb_t csqcentityframehistory[NUM_CSQCENTITYDB_FRAMES];
+ int csqcentityframehistory_next;
// prevent animated names
float nametime;
char weaponmodel[MAX_QPATH];
int weaponmodelindex;
+ // clientcamera (entity to use as camera)
+ int clientcamera;
+
entityframe_database_t *entitydatabase;
entityframe4_database_t *entitydatabase4;
entityframe5_database_t *entitydatabase5;
extern cvar_t sv_gameplayfix_blowupfallenzombies;
extern cvar_t sv_gameplayfix_delayprojectiles;
extern cvar_t sv_gameplayfix_droptofloorstartsolid;
+extern cvar_t sv_gameplayfix_droptofloorstartsolid_nudgetocorrect;
+extern cvar_t sv_gameplayfix_easierwaterjump;
extern cvar_t sv_gameplayfix_findradiusdistancetobox;
extern cvar_t sv_gameplayfix_grenadebouncedownslopes;
extern cvar_t sv_gameplayfix_multiplethinksperframe;
extern cvar_t sv_gameplayfix_noairborncorpse;
-extern cvar_t sv_gameplayfix_qwplayerphysics;
extern cvar_t sv_gameplayfix_setmodelrealbox;
extern cvar_t sv_gameplayfix_stepdown;
extern cvar_t sv_gameplayfix_stepwhilejumping;
// if touchtriggers, calls prog functions for the intersected triggers
void SV_LinkEdict (prvm_edict_t *ent, qboolean touch_triggers);
+// move an entity that is stuck by small amounts in various directions to try to nudge it back into the collision hull
+// returns true if it found a better place
+qboolean SV_UnstickEntity (prvm_edict_t *ent);
+
// calculates hitsupercontentsmask for a generic qc entity
int SV_GenericHitSuperContentsMask(const prvm_edict_t *edict);
// traces a box move against worldmodel and all entities in the specified area
trace_t SV_Move(const vec3_t start, const vec3_t mins, const vec3_t maxs, const vec3_t end, int type, prvm_edict_t *passedict, int hitsupercontentsmask);
-#define SV_PointSuperContents(point) (SV_Move((point), vec3_origin, vec3_origin, (point), sv_gameplayfix_swiminbmodels.integer ? MOVE_NOMONSTERS : MOVE_WORLDONLY, NULL, 0).startsupercontents)
+int SV_PointSuperContents(const vec3_t point);
void SV_FlushBroadcastMessages(void);
void SV_WriteClientdataToMessage (client_t *client, prvm_edict_t *ent, sizebuf_t *msg, int *stats);