X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;ds=sidebyside;f=progs.h;h=cd692f51dd33640cc3cbcb5c16ff8a438f56c2bb;hb=46bc5afbbd658c6f3d85a73a101bbedc15c46176;hp=a8a5f3b7d0320ed07f1db3a391abae9bc9df7756;hpb=b29b9e54dee7965354aede860e187c6f6276a758;p=xonotic%2Fdarkplaces.git diff --git a/progs.h b/progs.h index a8a5f3b7..cd692f51 100644 --- a/progs.h +++ b/progs.h @@ -37,37 +37,49 @@ typedef union eval_s typedef struct link_s { + int entitynumber; struct link_s *prev, *next; } link_t; -// the entire server entity structure -typedef struct edict_s +#define ENTITYGRIDAREAS 16 + +typedef struct edict_engineprivate_s { // true if this edict is unused qboolean free; - // physics area this edict is linked into - link_t area; + // sv.time when the object was freed (to prevent early reuse which could + // mess up client interpolation or obscure severe QuakeC bugs) + float freetime; + + // physics grid areas this edict is linked into + link_t areagrid[ENTITYGRIDAREAS]; + // since the areagrid can have multiple references to one entity, + // we should avoid extensive checking on entities already encountered + int areagridmarknumber; - // old entity protocol, not used -#ifdef QUAKEENTITIES + // PROTOCOL_QUAKE // baseline values entity_state_t baseline; - // LordHavoc: previous frame - entity_state_t deltabaseline; -#endif // LordHavoc: gross hack to make floating items still work int suspendedinairflag; - // sv.time when the object was freed (to prevent early reuse which could - // mess up client interpolation or obscure severe QuakeC bugs) - float freetime; // used by PushMove to keep track of where objects were before they were // moved, in case they need to be moved back vec3_t moved_from; vec3_t moved_fromangles; - // edict fields (stored in another array) +} +edict_engineprivate_t; + +// the entire server entity structure +// NOTE: keep this small! priv and v are dynamic but this struct is not! +typedef struct edict_s +{ + // engine-private fields (stored in dynamically resized array) + edict_engineprivate_t *e; + // QuakeC fields (stored in dynamically resized array) entvars_t *v; -} edict_t; +} +edict_t; // LordHavoc: in an effort to eliminate time wasted on GetEdictFieldValue... see pr_edict.c for the functions which use these. extern int eval_gravity; @@ -77,6 +89,8 @@ extern int eval_button5; extern int eval_button6; extern int eval_button7; extern int eval_button8; +extern int eval_buttonuse; +extern int eval_buttonchat; extern int eval_glow_size; extern int eval_glow_trail; extern int eval_glow_color; @@ -104,17 +118,34 @@ extern int eval_movement; extern int eval_pmodel; extern int eval_punchvector; extern int eval_viewzoom; +extern int eval_clientcolors; +extern int eval_tag_entity; +extern int eval_tag_index; +extern int eval_light_lev; +extern int eval_color; +extern int eval_style; +extern int eval_pflags; +extern int eval_cursor_active; +extern int eval_cursor_screen; +extern int eval_cursor_trace_start; +extern int eval_cursor_trace_endpos; +extern int eval_cursor_trace_ent; +extern int eval_colormod; +extern int eval_playermodel; +extern int eval_playerskin; #define GETEDICTFIELDVALUE(ed, fieldoffset) (fieldoffset ? (eval_t *)((qbyte *)ed->v + fieldoffset) : NULL) -extern dfunction_t *SV_PlayerPhysicsQC; -extern dfunction_t *EndFrameQC; +extern mfunction_t *SV_PlayerPhysicsQC; +extern mfunction_t *EndFrameQC; +//KrimZon - SERVER COMMANDS IN QUAKEC +extern mfunction_t *SV_ParseClientCommandQC; //============================================================================ extern dprograms_t *progs; -extern dfunction_t *pr_functions; +extern mfunction_t *pr_functions; extern char *pr_strings; extern ddef_t *pr_globaldefs; extern ddef_t *pr_fielddefs; @@ -128,38 +159,52 @@ extern int pr_edictareasize; // LordHavoc: for bounds checking //============================================================================ void PR_Init (void); +void PR_Shutdown (void); void PR_ExecuteProgram (func_t fnum, const char *errormessage); -void PR_LoadProgs (void); +void PR_LoadProgs (const char *progsname); + +void *PR_Alloc (size_t buffersize); +void PR_Free (void *buffer); +void PR_FreeAll (void); void PR_Profile_f (void); +void PR_PrintState(void); void PR_Crash (void); +void SV_IncreaseEdicts(void); + edict_t *ED_Alloc (void); void ED_Free (edict_t *ed); +void ED_ClearEdict (edict_t *e); char *ED_NewString (const char *string); // returns a copy of the string allocated from the server's string heap -void ED_Print (edict_t *ed); -void ED_Write (QFile *f, edict_t *ed); +void ED_Print(edict_t *ed); +void ED_Write (qfile_t *f, edict_t *ed); const char *ED_ParseEdict (const char *data, edict_t *ent); -void ED_WriteGlobals (QFile *f); +void ED_WriteGlobals (qfile_t *f); void ED_ParseGlobals (const char *data); void ED_LoadFromFile (const char *data); -edict_t *EDICT_NUM_ERROR(int n); -#define EDICT_NUM(n) ((n >= 0 && n < sv.max_edicts) ? sv.edictstable[(n)] : EDICT_NUM_ERROR(n)) +edict_t *EDICT_NUM_ERROR(int n, char *filename, int fileline); +#define EDICT_NUM(n) (((n) >= 0 && (n) < sv.max_edicts) ? sv.edicts + (n) : EDICT_NUM_ERROR(n, __FILE__, __LINE__)) +#define EDICT_NUM_UNSIGNED(n) (((n) < sv.max_edicts) ? sv.edicts + (n) : EDICT_NUM_ERROR(n, __FILE__, __LINE__)) -int NUM_FOR_EDICT(edict_t *e); +//int NUM_FOR_EDICT_ERROR(edict_t *e); +#define NUM_FOR_EDICT(e) ((int)((edict_t *)(e) - sv.edicts)) +//int NUM_FOR_EDICT(edict_t *e); #define NEXT_EDICT(e) ((e) + 1) -int EDICT_TO_PROG(edict_t *e); -edict_t *PROG_TO_EDICT(int n); +#define EDICT_TO_PROG(e) (NUM_FOR_EDICT(e)) +//int EDICT_TO_PROG(edict_t *e); +#define PROG_TO_EDICT(n) (EDICT_NUM(n)) +//edict_t *PROG_TO_EDICT(int n); //============================================================================ @@ -186,7 +231,7 @@ extern int pr_numbuiltins; extern int pr_argc; extern int pr_trace; -extern dfunction_t *pr_xfunction; +extern mfunction_t *pr_xfunction; extern int pr_xstatement; extern unsigned short pr_crc; @@ -197,7 +242,7 @@ void ED_PrintEdicts (void); void ED_PrintNum (int ent); #define PR_GetString(num) (pr_strings + num) -#define PR_SetString(s) ((int) (s - pr_strings)) +#define PR_SetString(s) ((s) != NULL ? (int) (s - pr_strings) : 0) #endif