mirror of
https://github.com/Shpoike/Quakespasm.git
synced 2024-11-10 15:31:39 +00:00
1f4fbfe833
d_ifacea.h, draw.h, gl_texmgr.h, glquake.h, image.h, input.h, keys.h, mathlib.h, menu.h, modelgen.h, net.h, net_dgrm.h, net_loop.h, net_sdlnet.h, net_udp.h, net_wins.h, platform.h, pr_comp.h, progdefs.h, progs.h, protocol.h, quakedef.h, render.h, resource.h, sbar.h, screen.h, server.h, sound.h, spritegn.h, sys.h, vid.h, view.h, wad.h, world.h, zone.h: added include guards to the headers. git-svn-id: http://svn.code.sf.net/p/quakespasm/code/trunk/quakespasm@84 af15c1b1-3010-417e-b628-4374ebc0bcbd
138 lines
4 KiB
C
138 lines
4 KiB
C
/*
|
|
Copyright (C) 1996-2001 Id Software, Inc.
|
|
Copyright (C) 2002-2009 John Fitzgibbons and others
|
|
|
|
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 the Free Software
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
#ifndef _QUAKE_PROGS_H
|
|
#define _QUAKE_PROGS_H
|
|
|
|
#include "pr_comp.h" // defs shared with qcc
|
|
#include "progdefs.h" // generated by program cdefs
|
|
|
|
typedef union eval_s
|
|
{
|
|
string_t string;
|
|
float _float;
|
|
float vector[3];
|
|
func_t function;
|
|
int _int;
|
|
int edict;
|
|
} eval_t;
|
|
|
|
#define MAX_ENT_LEAFS 16
|
|
typedef struct edict_s
|
|
{
|
|
qboolean free;
|
|
link_t area; // linked to a division node or leaf
|
|
int num_leafs;
|
|
short leafnums[MAX_ENT_LEAFS];
|
|
entity_state_t baseline;
|
|
unsigned char alpha; // johnfitz -- hack to support alpha since it's not part of entvars_t
|
|
qboolean sendinterval; // johnfitz -- send time until nextthink to client for better lerp timing
|
|
float freetime; // sv.time when the object was freed
|
|
entvars_t v; // C exported fields from progs
|
|
// other fields from progs come immediately after
|
|
} edict_t;
|
|
#define EDICT_FROM_AREA(l) STRUCT_FROM_LINK(l,edict_t,area)
|
|
|
|
//============================================================================
|
|
|
|
extern dprograms_t *progs;
|
|
extern dfunction_t *pr_functions;
|
|
extern char *pr_strings;
|
|
extern dstatement_t *pr_statements;
|
|
extern globalvars_t *pr_global_struct;
|
|
extern float *pr_globals; // same as pr_global_struct
|
|
|
|
extern int pr_edict_size; // in bytes
|
|
|
|
//============================================================================
|
|
|
|
void PR_Init (void);
|
|
|
|
void PR_ExecuteProgram (func_t fnum);
|
|
void PR_LoadProgs (void);
|
|
|
|
void PR_Profile_f (void);
|
|
|
|
char *PR_GetString (int num);
|
|
int PR_SetEngineString (char *s);
|
|
int PR_AllocString (int bufferlength, char **ptr);
|
|
|
|
edict_t *ED_Alloc (void);
|
|
void ED_Free (edict_t *ed);
|
|
|
|
void ED_Print (edict_t *ed);
|
|
void ED_Write (FILE *f, edict_t *ed);
|
|
char *ED_ParseEdict (char *data, edict_t *ent);
|
|
|
|
void ED_WriteGlobals (FILE *f);
|
|
void ED_ParseGlobals (char *data);
|
|
|
|
void ED_LoadFromFile (char *data);
|
|
|
|
//define EDICT_NUM(n) ((edict_t *)(sv.edicts+ (n)*pr_edict_size))
|
|
//define NUM_FOR_EDICT(e) (((byte *)(e) - sv.edicts)/pr_edict_size)
|
|
|
|
edict_t *EDICT_NUM(int n);
|
|
int NUM_FOR_EDICT(edict_t *e);
|
|
|
|
#define NEXT_EDICT(e) ((edict_t *)( (byte *)e + pr_edict_size))
|
|
|
|
#define EDICT_TO_PROG(e) ((byte *)e - (byte *)sv.edicts)
|
|
#define PROG_TO_EDICT(e) ((edict_t *)((byte *)sv.edicts + e))
|
|
|
|
//============================================================================
|
|
|
|
#define G_FLOAT(o) (pr_globals[o])
|
|
#define G_INT(o) (*(int *)&pr_globals[o])
|
|
#define G_EDICT(o) ((edict_t *)((byte *)sv.edicts+ *(int *)&pr_globals[o]))
|
|
#define G_EDICTNUM(o) NUM_FOR_EDICT(G_EDICT(o))
|
|
#define G_VECTOR(o) (&pr_globals[o])
|
|
#define G_STRING(o) (PR_GetString(*(string_t *)&pr_globals[o]))
|
|
#define G_FUNCTION(o) (*(func_t *)&pr_globals[o])
|
|
|
|
#define E_FLOAT(e,o) (((float*)&e->v)[o])
|
|
#define E_INT(e,o) (*(int *)&((float*)&e->v)[o])
|
|
#define E_VECTOR(e,o) (&((float*)&e->v)[o])
|
|
#define E_STRING(e,o) (PR_GetString(*(string_t *)&((float*)&e->v)[o]))
|
|
|
|
extern int type_size[8];
|
|
|
|
typedef void (*builtin_t) (void);
|
|
extern builtin_t *pr_builtins;
|
|
extern int pr_numbuiltins;
|
|
|
|
extern int pr_argc;
|
|
|
|
extern qboolean pr_trace;
|
|
extern dfunction_t *pr_xfunction;
|
|
extern int pr_xstatement;
|
|
|
|
extern unsigned short pr_crc;
|
|
|
|
void PR_RunError (char *error, ...);
|
|
|
|
void ED_PrintEdicts (void);
|
|
void ED_PrintNum (int ent);
|
|
|
|
eval_t *GetEdictFieldValue(edict_t *ed, char *field);
|
|
|
|
#endif /* _QUAKE_PROGS_H */
|
|
|