diff reduction and maybe a couple speedups

This commit is contained in:
Bill Currie 2003-05-29 04:49:34 +00:00
parent 1c1e6e17c4
commit 016743c3ab
4 changed files with 286 additions and 224 deletions

View file

@ -74,7 +74,7 @@ typedef struct
const char *model_precache[MAX_MODELS]; // NULL terminated const char *model_precache[MAX_MODELS]; // NULL terminated
struct model_s *models[MAX_MODELS]; struct model_s *models[MAX_MODELS];
const char *sound_precache[MAX_SOUNDS]; // NULL terminated const char *sound_precache[MAX_SOUNDS]; // NULL terminated
char *lightstyles[MAX_LIGHTSTYLES]; const char *lightstyles[MAX_LIGHTSTYLES];
int num_edicts; int num_edicts;
int max_edicts; int max_edicts;
edict_t *edicts; // can NOT be array indexed, because edict_t *edicts; // can NOT be array indexed, because

View file

@ -583,10 +583,12 @@ Host_Loadgame_f (void)
// load the light styles // load the light styles
for (i = 0; i < MAX_LIGHTSTYLES; i++) { for (i = 0; i < MAX_LIGHTSTYLES; i++) {
char *s;
Qgets (f, buf, sizeof (buf)); Qgets (f, buf, sizeof (buf));
sscanf (buf, "%s\n", str); sscanf (buf, "%s\n", str);
sv.lightstyles[i] = Hunk_Alloc (strlen (str) + 1); s = Hunk_Alloc (strlen (str) + 1);
strcpy (sv.lightstyles[i], str); strcpy (s, str);
sv.lightstyles[i] = s;
} }
// load the edicts out of the savegame file // load the edicts out of the savegame file

View file

@ -1,7 +1,7 @@
/* /*
pr->pr_cmds.c sv_pr_cmds.c
@description@ (description)
Copyright (C) 1996-1997 Id Software, Inc. Copyright (C) 1996-1997 Id Software, Inc.
@ -53,8 +53,8 @@ static __attribute__ ((unused)) const char rcsid[] =
#include "sv_progs.h" #include "sv_progs.h"
#include "world.h" #include "world.h"
/* BUILT-IN FUNCTIONS */
// BUILT-IN FUNCTIONS =========================================================
/* /*
PF_error PF_error
@ -72,7 +72,7 @@ PF_error (progs_t *pr)
s = PF_VarString (pr, 0); s = PF_VarString (pr, 0);
Con_Printf ("======SERVER ERROR in %s:\n%s\n", Con_Printf ("======SERVER ERROR in %s:\n%s\n",
PR_GetString (&sv_pr_state, pr->pr_xfunction->s_name), s); PR_GetString (pr, pr->pr_xfunction->s_name), s);
ed = PROG_TO_EDICT (pr, *sv_globals.self); ed = PROG_TO_EDICT (pr, *sv_globals.self);
ED_Print (pr, ed); ED_Print (pr, ed);
@ -95,7 +95,7 @@ PF_objerror (progs_t *pr)
s = PF_VarString (pr, 0); s = PF_VarString (pr, 0);
Con_Printf ("======OBJECT ERROR in %s:\n%s\n", Con_Printf ("======OBJECT ERROR in %s:\n%s\n",
PR_GetString (&sv_pr_state, pr->pr_xfunction->s_name), s); PR_GetString (pr, pr->pr_xfunction->s_name), s);
ed = PROG_TO_EDICT (pr, *sv_globals.self); ed = PROG_TO_EDICT (pr, *sv_globals.self);
ED_Print (pr, ed); ED_Print (pr, ed);
ED_Free (pr, ed); ED_Free (pr, ed);
@ -238,13 +238,13 @@ PF_setmodel (progs_t *pr)
{ {
edict_t *e; edict_t *e;
const char *m, **check; const char *m, **check;
model_t *mod;
int i; int i;
model_t *mod;
e = P_EDICT (pr, 0); e = P_EDICT (pr, 0);
m = P_GSTRING (pr, 1); m = P_GSTRING (pr, 1);
// check to see if model was properly precached // check to see if model was properly precached
for (i = 0, check = sv.model_precache; *check; i++, check++) for (i = 0, check = sv.model_precache; *check; i++, check++)
if (!strcmp (*check, m)) if (!strcmp (*check, m))
break; break;
@ -252,7 +252,6 @@ PF_setmodel (progs_t *pr)
if (!*check) if (!*check)
PR_RunError (pr, "no precache: %s\n", m); PR_RunError (pr, "no precache: %s\n", m);
SVstring (e, model) = PR_SetString (pr, m); SVstring (e, model) = PR_SetString (pr, m);
SVfloat (e, modelindex) = i; // SV_ModelIndex (m); SVfloat (e, modelindex) = i; // SV_ModelIndex (m);
@ -319,7 +318,7 @@ void
PF_centerprint (progs_t *pr) PF_centerprint (progs_t *pr)
{ {
const char *s; const char *s;
client_t *client; client_t *cl;
int entnum; int entnum;
entnum = P_EDICTNUM (pr, 0); entnum = P_EDICTNUM (pr, 0);
@ -330,17 +329,12 @@ PF_centerprint (progs_t *pr)
return; return;
} }
client = &svs.clients[entnum - 1]; cl = &svs.clients[entnum - 1];
MSG_WriteByte (&client->message, svc_centerprint); MSG_WriteByte (&cl->message, svc_centerprint);
MSG_WriteString (&client->message, s); MSG_WriteString (&cl->message, s);
} }
/*
PF_particle
particle (origin, color, count)
*/
void void
PF_particle (progs_t *pr) PF_particle (progs_t *pr)
{ {
@ -355,14 +349,17 @@ PF_particle (progs_t *pr)
SV_StartParticle (org, dir, color, count); SV_StartParticle (org, dir, color, count);
} }
/*
PF_ambientsound
*/
void void
PF_ambientsound (progs_t *pr) PF_ambientsound (progs_t *pr)
{ {
const char **check; const char **check;
const char *samp; const char *samp;
float *pos; float *pos;
float vol, attenuation; float vol, attenuation;
int soundnum; int soundnum;
pos = P_VECTOR (pr, 0); pos = P_VECTOR (pr, 0);
samp = P_GSTRING (pr, 1); samp = P_GSTRING (pr, 1);
@ -404,9 +401,9 @@ void
PF_sound (progs_t *pr) PF_sound (progs_t *pr)
{ {
const char *sample; const char *sample;
float attenuation;
int channel, volume;
edict_t *entity; edict_t *entity;
float attenuation;
int channel, volume;
entity = P_EDICT (pr, 0); entity = P_EDICT (pr, 0);
channel = P_FLOAT (pr, 1); channel = P_FLOAT (pr, 1);
@ -424,7 +421,6 @@ PF_sound (progs_t *pr)
SV_StartSound (entity, channel, sample, volume, attenuation); SV_StartSound (entity, channel, sample, volume, attenuation);
} }
/* /*
PF_traceline PF_traceline
@ -438,8 +434,8 @@ void
PF_traceline (progs_t *pr) PF_traceline (progs_t *pr)
{ {
float *v1, *v2; float *v1, *v2;
int nomonsters;
edict_t *ent; edict_t *ent;
int nomonsters;
trace_t trace; trace_t trace;
v1 = P_VECTOR (pr, 0); v1 = P_VECTOR (pr, 0);
@ -477,21 +473,18 @@ PF_checkpos (progs_t *pr)
{ {
} }
// ============================================================================
byte checkpvs[MAX_MAP_LEAFS / 8]; byte checkpvs[MAX_MAP_LEAFS / 8];
int int
PF_newcheckclient (progs_t *pr, int check) PF_newcheckclient (progs_t *pr, int check)
{ {
int i;
byte *pvs; byte *pvs;
edict_t *ent; edict_t *ent;
int i;
mleaf_t *leaf; mleaf_t *leaf;
vec3_t org; vec3_t org;
// cycle to the next one // cycle to the next one
if (check < 1) if (check < 1)
check = 1; check = 1;
if (check > svs.maxclients) if (check > svs.maxclients)
@ -510,6 +503,7 @@ PF_newcheckclient (progs_t *pr, int check)
if (i == check) if (i == check)
break; // didn't find anything else break; // didn't find anything else
if (ent->free) if (ent->free)
continue; continue;
if (SVfloat (ent, health) <= 0) if (SVfloat (ent, health) <= 0)
@ -520,7 +514,7 @@ PF_newcheckclient (progs_t *pr, int check)
break; break;
} }
// get the PVS for the entity // get the PVS for the entity
VectorAdd (SVvector (ent, origin), SVvector (ent, view_ofs), org); VectorAdd (SVvector (ent, origin), SVvector (ent, view_ofs), org);
leaf = Mod_PointInLeaf (org, sv.worldmodel); leaf = Mod_PointInLeaf (org, sv.worldmodel);
pvs = Mod_LeafPVS (leaf, sv.worldmodel); pvs = Mod_LeafPVS (leaf, sv.worldmodel);
@ -530,7 +524,7 @@ PF_newcheckclient (progs_t *pr, int check)
} }
#define MAX_CHECK 16 #define MAX_CHECK 16
int c_invis, c_notvis; int c_invis, c_notvis;
/* /*
PF_checkclient PF_checkclient
@ -553,18 +547,18 @@ PF_checkclient (progs_t *pr)
mleaf_t *leaf; mleaf_t *leaf;
vec3_t view; vec3_t view;
// find a new check if on a new frame // find a new check if on a new frame
if (sv.time - sv.lastchecktime >= 0.1) { if (sv.time - sv.lastchecktime >= 0.1) {
sv.lastcheck = PF_newcheckclient (pr, sv.lastcheck); sv.lastcheck = PF_newcheckclient (pr, sv.lastcheck);
sv.lastchecktime = sv.time; sv.lastchecktime = sv.time;
} }
// return check if it might be visible // return check if it might be visible
ent = EDICT_NUM (pr, sv.lastcheck); ent = EDICT_NUM (pr, sv.lastcheck);
if (ent->free || SVfloat (ent, health) <= 0) { if (ent->free || SVfloat (ent, health) <= 0) {
RETURN_EDICT (pr, sv.edicts); RETURN_EDICT (pr, sv.edicts);
return; return;
} }
// if current entity can't possibly see the check entity, return 0 // if current entity can't possibly see the check entity, return 0
self = PROG_TO_EDICT (pr, *sv_globals.self); self = PROG_TO_EDICT (pr, *sv_globals.self);
VectorAdd (SVvector (self, origin), SVvector (self, view_ofs), view); VectorAdd (SVvector (self, origin), SVvector (self, view_ofs), view);
leaf = Mod_PointInLeaf (view, sv.worldmodel); leaf = Mod_PointInLeaf (view, sv.worldmodel);
@ -574,13 +568,11 @@ PF_checkclient (progs_t *pr)
RETURN_EDICT (pr, sv.edicts); RETURN_EDICT (pr, sv.edicts);
return; return;
} }
// might be able to see it // might be able to see it
c_invis++; c_invis++;
RETURN_EDICT (pr, ent); RETURN_EDICT (pr, ent);
} }
//============================================================================
/* /*
PF_stuffcmd PF_stuffcmd
@ -609,7 +601,7 @@ PF_stuffcmd (progs_t *pr)
/* /*
PF_localcmd PF_localcmd
Sends text over to the client's execution buffer Inserts text into the server console's execution buffer
localcmd (string) localcmd (string)
*/ */
@ -634,7 +626,7 @@ PF_findradius (progs_t *pr)
{ {
edict_t *ent, *chain; edict_t *ent, *chain;
float rad; float rad;
float *eorigin, *emins, *emaxs, *org; float *eorigin, *emins, *emaxs, *org;
int i, j; int i, j;
vec3_t eorg; vec3_t eorg;
@ -642,7 +634,7 @@ PF_findradius (progs_t *pr)
org = P_VECTOR (pr, 0); org = P_VECTOR (pr, 0);
rad = P_FLOAT (pr, 1); rad = P_FLOAT (pr, 1);
rad *= rad; // Square early, sqrt never rad *= rad; // Square early, sqrt never
ent = NEXT_EDICT (pr, sv.edicts); ent = NEXT_EDICT (pr, sv.edicts);
for (i = 1; i < sv.num_edicts; i++, ent = NEXT_EDICT (pr, ent)) { for (i = 1; i < sv.num_edicts; i++, ent = NEXT_EDICT (pr, ent)) {
@ -756,11 +748,11 @@ PF_precache_model (progs_t *pr)
void void
PF_walkmove (progs_t *pr) PF_walkmove (progs_t *pr)
{ {
dfunction_t *oldf;
edict_t *ent; edict_t *ent;
float yaw, dist; float yaw, dist;
vec3_t move;
dfunction_t *oldf;
int oldself; int oldself;
vec3_t move;
ent = PROG_TO_EDICT (pr, *sv_globals.self); ent = PROG_TO_EDICT (pr, *sv_globals.self);
yaw = P_FLOAT (pr, 0); yaw = P_FLOAT (pr, 0);
@ -777,14 +769,13 @@ PF_walkmove (progs_t *pr)
move[1] = sin (yaw) * dist; move[1] = sin (yaw) * dist;
move[2] = 0; move[2] = 0;
// save program state, because SV_movestep may call other progs // save program state, because SV_movestep may call other progs
oldf = pr->pr_xfunction; oldf = pr->pr_xfunction;
oldself = *sv_globals.self; oldself = *sv_globals.self;
R_FLOAT (pr) = SV_movestep (ent, move, true); R_FLOAT (pr) = SV_movestep (ent, move, true);
// restore program state
// restore program state
pr->pr_xfunction = oldf; pr->pr_xfunction = oldf;
*sv_globals.self = oldself; *sv_globals.self = oldself;
} }
@ -798,16 +789,15 @@ void
PF_droptofloor (progs_t *pr) PF_droptofloor (progs_t *pr)
{ {
edict_t *ent; edict_t *ent;
vec3_t end;
trace_t trace; trace_t trace;
vec3_t end;
ent = PROG_TO_EDICT (pr, *sv_globals.self); ent = PROG_TO_EDICT (pr, *sv_globals.self);
VectorCopy (SVvector (ent, origin), end); VectorCopy (SVvector (ent, origin), end);
end[2] -= 256; end[2] -= 256;
trace = SV_Move (SVvector (ent, origin), trace = SV_Move (SVvector (ent, origin), SVvector (ent, mins),
SVvector (ent, mins),
SVvector (ent, maxs), end, false, ent); SVvector (ent, maxs), end, false, ent);
if (trace.fraction == 1 || trace.allsolid) { if (trace.fraction == 1 || trace.allsolid) {
@ -829,18 +819,17 @@ PF_droptofloor (progs_t *pr)
void void
PF_lightstyle (progs_t *pr) PF_lightstyle (progs_t *pr)
{ {
int style; const char *val;
char *val;
client_t *client; client_t *client;
int j; int style, j;
style = P_FLOAT (pr, 0); style = P_FLOAT (pr, 0);
val = P_GSTRING (pr, 1); val = P_GSTRING (pr, 1);
// change the string in sv // change the string in sv
sv.lightstyles[style] = val; sv.lightstyles[style] = val;
// send message to all clients on this server // send message to all clients on this server
if (sv.state != ss_active) if (sv.state != ss_active)
return; return;
@ -885,6 +874,7 @@ PF_aim (progs_t *pr)
{ {
edict_t *ent, *check, *bestent; edict_t *ent, *check, *bestent;
float dist, bestdist, speed; float dist, bestdist, speed;
float *mins, *maxs, *org;
int i, j; int i, j;
trace_t tr; trace_t tr;
vec3_t start, dir, end, bestdir; vec3_t start, dir, end, bestdir;
@ -895,7 +885,7 @@ PF_aim (progs_t *pr)
VectorCopy (SVvector (ent, origin), start); VectorCopy (SVvector (ent, origin), start);
start[2] += 20; start[2] += 20;
// try sending a trace straight // try sending a trace straight
VectorCopy (*sv_globals.v_forward, dir); VectorCopy (*sv_globals.v_forward, dir);
VectorMA (start, 2048, dir, end); VectorMA (start, 2048, dir, end);
tr = SV_Move (start, vec3_origin, vec3_origin, end, false, ent); tr = SV_Move (start, vec3_origin, vec3_origin, end, false, ent);
@ -905,7 +895,8 @@ PF_aim (progs_t *pr)
VectorCopy (*sv_globals.v_forward, R_VECTOR (pr)); VectorCopy (*sv_globals.v_forward, R_VECTOR (pr));
return; return;
} }
// try all possible entities
// try all possible entities
VectorCopy (dir, bestdir); VectorCopy (dir, bestdir);
bestdist = sv_aim->value; bestdist = sv_aim->value;
bestent = NULL; bestent = NULL;
@ -920,9 +911,11 @@ PF_aim (progs_t *pr)
&& SVfloat (ent, team) == SVfloat (check, team)) && SVfloat (ent, team) == SVfloat (check, team))
continue; // don't aim at teammate continue; // don't aim at teammate
mins = SVvector (check, mins);
maxs = SVvector (check, maxs);
org = SVvector (check, origin);
for (j = 0; j < 3; j++) for (j = 0; j < 3; j++)
end[j] = SVvector (check, origin)[j] + 0.5 end[j] = org[j] + 0.5 * (mins[j] + maxs[j]);
* (SVvector (check, mins)[j] + SVvector (check, maxs)[j]);
VectorSubtract (end, start, dir); VectorSubtract (end, start, dir);
VectorNormalize (dir); VectorNormalize (dir);
dist = DotProduct (dir, *sv_globals.v_forward); dist = DotProduct (dir, *sv_globals.v_forward);
@ -985,7 +978,7 @@ PF_changeyaw (progs_t *pr)
SVvector (ent, angles)[1] = anglemod (current + move); SVvector (ent, angles)[1] = anglemod (current + move);
} }
// MESSAGE WRITING ============================================================ /* MESSAGE WRITING */
#define MSG_BROADCAST 0 // unreliable to all #define MSG_BROADCAST 0 // unreliable to all
#define MSG_ONE 1 // reliable to one (msg_entity) #define MSG_ONE 1 // reliable to one (msg_entity)
@ -1078,14 +1071,15 @@ PF_WriteEntity (progs_t *pr)
void void
PF_makestatic (progs_t *pr) PF_makestatic (progs_t *pr)
{ {
const char *model;
edict_t *ent; edict_t *ent;
ent = P_EDICT (pr, 0); ent = P_EDICT (pr, 0);
MSG_WriteByte (&sv.signon, svc_spawnstatic); MSG_WriteByte (&sv.signon, svc_spawnstatic);
MSG_WriteByte (&sv.signon, model = PR_GetString (pr, SVstring (ent, model));
SV_ModelIndex (PR_GetString (pr, SVstring (ent, model)))); MSG_WriteByte (&sv.signon, SV_ModelIndex (model));
MSG_WriteByte (&sv.signon, SVfloat (ent, frame)); MSG_WriteByte (&sv.signon, SVfloat (ent, frame));
MSG_WriteByte (&sv.signon, SVfloat (ent, colormap)); MSG_WriteByte (&sv.signon, SVfloat (ent, colormap));
@ -1093,23 +1087,17 @@ PF_makestatic (progs_t *pr)
MSG_WriteCoordAngleV (&sv.signon, SVvector (ent, origin), MSG_WriteCoordAngleV (&sv.signon, SVvector (ent, origin),
SVvector (ent, angles)); SVvector (ent, angles));
/* for (i = 0; i < 3; i++) { // FIXME: DESPAIR
MSG_WriteCoord (&sv.signon, SVvector (ent, origin)[i]);
MSG_WriteAngle (&sv.signon, SVvector (ent, angles)[i]);
} */
// throw the entity away now // throw the entity away now
ED_Free (pr, ent); ED_Free (pr, ent);
} }
// ============================================================================
void void
PF_setspawnparms (progs_t *pr) PF_setspawnparms (progs_t *pr)
{ {
client_t *client;
edict_t *ent; edict_t *ent;
int i; int i;
client_t *client;
ent = P_EDICT (pr, 0); ent = P_EDICT (pr, 0);
i = NUM_FOR_EDICT (pr, ent); i = NUM_FOR_EDICT (pr, ent);
@ -1126,7 +1114,7 @@ PF_setspawnparms (progs_t *pr)
void void
PF_changelevel (progs_t *pr) PF_changelevel (progs_t *pr)
{ {
char *s; const char *s;
// make sure we don't issue two changelevels // make sure we don't issue two changelevels
if (svs.changelevel_issued) if (svs.changelevel_issued)
@ -1159,11 +1147,11 @@ PF_hullpointcontents (progs_t *pr)
static void static void
PF_getboxbounds (progs_t *pr) PF_getboxbounds (progs_t *pr)
{ {
int h = P_INT (pr, 0) - 1;
clip_hull_t *ch; clip_hull_t *ch;
int h = P_INT (pr, 0) - 1;
if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h])) if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h]))
PR_RunError (pr, "PF_freeboxhull: invalid box hull handle\n"); PR_RunError (pr, "PF_getboxbounds: invalid box hull handle\n");
if (P_INT (pr, 1)) { if (P_INT (pr, 1)) {
VectorCopy (ch->maxs, R_VECTOR (pr)); VectorCopy (ch->maxs, R_VECTOR (pr));
@ -1228,31 +1216,31 @@ calc_dist (vec3_t p, vec3_t n, vec3_t *offsets)
static void static void
PF_rotate_bbox (progs_t *pr) PF_rotate_bbox (progs_t *pr)
{ {
int h = P_INT (pr, 0) - 1; clip_hull_t *ch;
float l;
float *mi = P_VECTOR (pr, 4);
float *ma = P_VECTOR (pr, 5);
float *dir[3] = { float *dir[3] = {
P_VECTOR (pr, 1), P_VECTOR (pr, 1),
P_VECTOR (pr, 2), P_VECTOR (pr, 2),
P_VECTOR (pr, 3), P_VECTOR (pr, 3),
}; };
float *mi = P_VECTOR (pr, 4);
float *ma = P_VECTOR (pr, 5);
vec3_t mins, maxs; hull_t *hull;
int i, j;
int h = P_INT (pr, 0) - 1;
vec3_t mins, maxs, d;
float *verts[6] = {maxs, mins, maxs, mins, maxs, mins}; float *verts[6] = {maxs, mins, maxs, mins, maxs, mins};
vec3_t v[8];
vec3_t offsets[3][2] = { vec3_t offsets[3][2] = {
{ { 0, 0, 0 }, { 0, 0, 0} }, { { 0, 0, 0 }, { 0, 0, 0} },
{ { -16, -16, -32 }, { 16, 16, 24} }, { { -16, -16, -32 }, { 16, 16, 24} },
{ { -32, -32, -64 }, { 32, 32, 24} }, { { -32, -32, -64 }, { 32, 32, 24} },
}; };
vec3_t v[8], d;
hull_t *hull;
clip_hull_t *ch;
int i, j;
float l;
if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h])) if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h]))
PR_RunError (pr, "PF_freeboxhull: invalid box hull handle\n"); PR_RunError (pr, "PF_rotate_bbox: invalid box hull handle\n");
// set up the rotation matrix. the three orientation vectors form the // set up the rotation matrix. the three orientation vectors form the
// columns of the rotation matrix // columns of the rotation matrix
@ -1306,7 +1294,7 @@ PF_rotate_bbox (progs_t *pr)
void void
PF_Fixme (progs_t *pr) PF_Fixme (progs_t *pr)
{ {
PR_RunError (pr, "unimplemented bulitin"); PR_RunError (pr, "unimplemented bulitin function called");
} }

View file

@ -297,8 +297,8 @@ PF_centerprint (progs_t *pr)
void void
PF_ambientsound (progs_t *pr) PF_ambientsound (progs_t *pr)
{ {
const char **check; const char **check;
const char *samp; const char *samp;
float *pos; float *pos;
float vol, attenuation; float vol, attenuation;
int soundnum; int soundnum;
@ -321,9 +321,7 @@ PF_ambientsound (progs_t *pr)
// add an svc_spawnambient command to the level signon packet // add an svc_spawnambient command to the level signon packet
MSG_WriteByte (&sv.signon, svc_spawnstaticsound); MSG_WriteByte (&sv.signon, svc_spawnstaticsound);
MSG_WriteCoordV (&sv.signon, pos); MSG_WriteCoordV (&sv.signon, pos);
MSG_WriteByte (&sv.signon, soundnum); MSG_WriteByte (&sv.signon, soundnum);
MSG_WriteByte (&sv.signon, vol * 255); MSG_WriteByte (&sv.signon, vol * 255);
MSG_WriteByte (&sv.signon, attenuation * 64); MSG_WriteByte (&sv.signon, attenuation * 64);
@ -344,7 +342,7 @@ PF_ambientsound (progs_t *pr)
void void
PF_sound (progs_t *pr) PF_sound (progs_t *pr)
{ {
const char *sample; const char *sample;
edict_t *entity; edict_t *entity;
float attenuation; float attenuation;
int channel, volume; int channel, volume;
@ -361,7 +359,7 @@ PF_sound (progs_t *pr)
/* /*
PF_traceline PF_traceline
Used for use tracing and shot targeting Used for use tracing and shot targeting.
Traces are blocked by bbox and exact bsp entityes, and also slide box Traces are blocked by bbox and exact bsp entityes, and also slide box
entities if the tryents flag is set. entities if the tryents flag is set.
@ -434,12 +432,12 @@ PF_checkmove (progs_t *pr)
} }
/* /*
PF_checkpos PF_checkpos
Returns true if the given entity can move to the given position from it's Returns true if the given entity can move to the given position from it's
current position by walking or rolling. current position by walking or rolling.
FIXME: make work... FIXME: make work...
scalar checkpos (entity, vector) scalar checkpos (entity, vector)
*/ */
void void
PF_checkpos (progs_t *pr) PF_checkpos (progs_t *pr)
@ -501,15 +499,15 @@ PF_newcheckclient (progs_t *pr, int check)
int c_invis, c_notvis; int c_invis, c_notvis;
/* /*
PF_checkclient PF_checkclient
Returns a client (or object that has a client enemy) that would be a valid Returns a client (or object that has a client enemy) that would be a
target. valid target.
If there are more than one valid options, they are cycled each frame If there are more than one valid options, they are cycled each frame
If (self.origin + self.viewofs) is not in the PVS of the current target, it If (self.origin + self.viewofs) is not in the PVS of the current target, it
is not returned at all. is not returned at all.
*/ */
void void
PF_checkclient (progs_t *pr) PF_checkclient (progs_t *pr)
@ -555,7 +553,7 @@ PF_checkclient (progs_t *pr)
void void
PF_stuffcmd (progs_t *pr) PF_stuffcmd (progs_t *pr)
{ {
const char *str; const char *str;
char *buf, *p; char *buf, *p;
client_t *cl; client_t *cl;
int entnum; int entnum;
@ -811,9 +809,9 @@ PF_droptofloor (progs_t *pr)
trace = SV_Move (SVvector (ent, origin), SVvector (ent, mins), trace = SV_Move (SVvector (ent, origin), SVvector (ent, mins),
SVvector (ent, maxs), end, false, ent); SVvector (ent, maxs), end, false, ent);
if (trace.fraction == 1 || trace.allsolid) if (trace.fraction == 1 || trace.allsolid) {
R_FLOAT (pr) = 0; R_FLOAT (pr) = 0;
else { } else {
VectorCopy (trace.endpos, SVvector (ent, origin)); VectorCopy (trace.endpos, SVvector (ent, origin));
SV_LinkEdict (ent, false); SV_LinkEdict (ent, false);
SVfloat (ent, flags) = (int) SVfloat (ent, flags) | FL_ONGROUND; SVfloat (ent, flags) = (int) SVfloat (ent, flags) | FL_ONGROUND;
@ -830,7 +828,7 @@ PF_droptofloor (progs_t *pr)
void void
PF_lightstyle (progs_t *pr) PF_lightstyle (progs_t *pr)
{ {
const char *val; const char *val;
client_t *client; client_t *client;
int style, j; int style, j;
@ -859,9 +857,6 @@ PF_lightstyle (progs_t *pr)
} }
} }
/*
PF_checkbottom
*/
void void
PF_checkbottom (progs_t *pr) PF_checkbottom (progs_t *pr)
{ {
@ -893,13 +888,13 @@ cvar_t *sv_aim;
void void
PF_aim (progs_t *pr) PF_aim (progs_t *pr)
{ {
const char *noaim;
edict_t *ent, *check, *bestent; edict_t *ent, *check, *bestent;
vec3_t start, dir, end, bestdir; float dist, bestdist, speed;
float *mins, *maxs, *org;
int i, j; int i, j;
trace_t tr; trace_t tr;
float dist, bestdist; vec3_t start, dir, end, bestdir;
float speed;
const char *noaim;
if (sv_aim->value >= 1.0) { if (sv_aim->value >= 1.0) {
VectorCopy (*sv_globals.v_forward, R_VECTOR (pr)); VectorCopy (*sv_globals.v_forward, R_VECTOR (pr));
@ -945,11 +940,14 @@ PF_aim (progs_t *pr)
if (check == ent) if (check == ent)
continue; continue;
if (teamplay->int_val && SVfloat (ent, team) > 0 if (teamplay->int_val && SVfloat (ent, team) > 0
&& SVfloat (ent, team) == SVfloat (check, team)) continue; && SVfloat (ent, team) == SVfloat (check, team))
// don't aim at teammate continue; // don't aim at teammate
mins = SVvector (check, mins);
maxs = SVvector (check, maxs);
org = SVvector (check, origin);
for (j = 0; j < 3; j++) for (j = 0; j < 3; j++)
end[j] = SVvector (check, origin)[j] + 0.5 * end[j] = org[j] + 0.5 * (mins[j] + maxs[j]);
(SVvector (check, mins)[j] + SVvector (check, maxs)[j]);
VectorSubtract (end, start, dir); VectorSubtract (end, start, dir);
VectorNormalize (dir); VectorNormalize (dir);
dist = DotProduct (dir, *sv_globals.v_forward); dist = DotProduct (dir, *sv_globals.v_forward);
@ -1027,34 +1025,27 @@ WriteDest (progs_t *pr)
dest = P_FLOAT (pr, 0); dest = P_FLOAT (pr, 0);
switch (dest) { switch (dest) {
case MSG_BROADCAST: case MSG_BROADCAST:
return &sv.datagram; return &sv.datagram;
case MSG_ONE: case MSG_ONE:
Sys_Error ("Shouldn't be at MSG_ONE"); Sys_Error ("Shouldn't be at MSG_ONE");
#if 0
ent = PROG_TO_EDICT (pr, *sv_globals.msg_entity);
entnum = NUM_FOR_EDICT (pr, ent);
if (entnum < 1 || entnum > MAX_CLIENTS)
PR_RunError (pr, "WriteDest: not a client");
return &svs.clients[entnum - 1].netchan.message;
#endif
case MSG_ALL: case MSG_ALL:
return &sv.reliable_datagram; return &sv.reliable_datagram;
case MSG_INIT: case MSG_INIT:
if (sv.state != ss_loading) if (sv.state != ss_loading)
PR_RunError (pr, "PF_Write_*: MSG_INIT can only be written in " PR_RunError (pr, "PF_Write_*: MSG_INIT can only be written in "
"spawn functions"); "spawn functions");
return &sv.signon; return &sv.signon;
case MSG_MULTICAST: case MSG_MULTICAST:
return &sv.multicast; return &sv.multicast;
default: default:
PR_RunError (pr, "WriteDest: bad destination"); PR_RunError (pr, "WriteDest: bad destination");
break; break;
} }
return NULL; return NULL;
@ -1300,7 +1291,6 @@ PF_makestatic (progs_t *pr)
MSG_WriteByte (&sv.signon, svc_spawnstatic); MSG_WriteByte (&sv.signon, svc_spawnstatic);
model = PR_GetString (pr, SVstring (ent, model)); model = PR_GetString (pr, SVstring (ent, model));
// SV_Printf ("Model: %d %s\n", SVstring (ent, model), model);
MSG_WriteByte (&sv.signon, SV_ModelIndex (model)); MSG_WriteByte (&sv.signon, SV_ModelIndex (model));
MSG_WriteByte (&sv.signon, SVfloat (ent, frame)); MSG_WriteByte (&sv.signon, SVfloat (ent, frame));
@ -1309,6 +1299,7 @@ PF_makestatic (progs_t *pr)
MSG_WriteCoordAngleV (&sv.signon, SVvector (ent, origin), MSG_WriteCoordAngleV (&sv.signon, SVvector (ent, origin),
SVvector (ent, angles)); SVvector (ent, angles));
// throw the entity away now // throw the entity away now
ED_Free (pr, ent); ED_Free (pr, ent);
} }
@ -1338,7 +1329,7 @@ PF_setspawnparms (progs_t *pr)
void void
PF_changelevel (progs_t *pr) PF_changelevel (progs_t *pr)
{ {
const char *s; const char *s;
static int last_spawncount; static int last_spawncount;
// make sure we don't issue two changelevels // make sure we don't issue two changelevels
@ -1611,7 +1602,7 @@ static void
PF_getboxbounds (progs_t *pr) PF_getboxbounds (progs_t *pr)
{ {
clip_hull_t *ch; clip_hull_t *ch;
int h = P_INT (pr, 0) - 1; int h = P_INT (pr, 0) - 1;
if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h])) if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h]))
PR_RunError (pr, "PF_getboxbounds: invalid box hull handle\n"); PR_RunError (pr, "PF_getboxbounds: invalid box hull handle\n");
@ -1627,7 +1618,7 @@ static void
PF_getboxhull (progs_t *pr) PF_getboxhull (progs_t *pr)
{ {
clip_hull_t *ch = 0; clip_hull_t *ch = 0;
int i; int i;
for (i = 0; i < MAX_PF_HULLS; i++) { for (i = 0; i < MAX_PF_HULLS; i++) {
if (!pf_hull_list[i]) { if (!pf_hull_list[i]) {
@ -1650,7 +1641,7 @@ PF_getboxhull (progs_t *pr)
static void static void
PF_freeboxhull (progs_t *pr) PF_freeboxhull (progs_t *pr)
{ {
int h = P_INT (pr, 0) - 1; int h = P_INT (pr, 0) - 1;
clip_hull_t *ch; clip_hull_t *ch;
if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h])) if (h < 0 || h > MAX_PF_HULLS - 1 || !(ch = pf_hull_list[h]))
@ -1733,7 +1724,6 @@ PF_rotate_bbox (progs_t *pr)
VectorCopy (v[0], ch->mins); VectorCopy (v[0], ch->mins);
VectorCopy (v[0], ch->maxs); VectorCopy (v[0], ch->maxs);
for (i = 0; i < 8; i++) { for (i = 0; i < 8; i++) {
//SV_Printf ("'%0.1f %0.1f %0.1f'\n", v[i][0], v[i][1], v[i][2]);
for (j = 0; j < 3; j++) { for (j = 0; j < 3; j++) {
ch->mins[j] = min (ch->mins[j], v[i][j]); ch->mins[j] = min (ch->mins[j], v[i][j]);
ch->maxs[j] = max (ch->maxs[j], v[i][j]); ch->maxs[j] = max (ch->maxs[j], v[i][j]);
@ -1751,10 +1741,6 @@ PF_rotate_bbox (progs_t *pr)
offsets[j]); offsets[j]);
hull->planes[i].type = 4; hull->planes[i].type = 4;
VectorCopy (dir[i / 2], hull->planes[i].normal); VectorCopy (dir[i / 2], hull->planes[i].normal);
// SV_Printf ("%f %f %f %f\n",
// hull->planes[i].dist,
// hull->planes[i].normal[0], hull->planes[i].normal[1],
// hull->planes[i].normal[2]);
} }
} }
} }
@ -1766,7 +1752,7 @@ PF_Fixme (progs_t *pr)
} }
static void static void
PF_Checkextension (progs_t *pr) PF_checkextension (progs_t *pr)
{ {
R_FLOAT (pr) = 0; // FIXME: make this function actually useful :P R_FLOAT (pr) = 0; // FIXME: make this function actually useful :P
} }
@ -1877,78 +1863,164 @@ SV_PR_Cmds_Init ()
PR_Cmds_Init (&sv_pr_state); PR_Cmds_Init (&sv_pr_state);
PR_Obj_Progs_Init (&sv_pr_state); PR_Obj_Progs_Init (&sv_pr_state);
sv_pr_state.builtins[45] = 0; // (override standard builtin) // (override standard builtin)
PR_AddBuiltin (&sv_pr_state, "cvar", PF_sv_cvar, 45); // float (string s) cvar sv_pr_state.builtins[45] = 0;
// float (string s) cvar
PR_AddBuiltin (&sv_pr_state, "cvar", PF_sv_cvar, 45);
PR_AddBuiltin (&sv_pr_state, "makevectors", PF_makevectors, 1); // void (entity e) makevectors // void (entity e) makevectors
PR_AddBuiltin (&sv_pr_state, "setorigin", PF_setorigin, 2); // void (entity e, vector o) setorigin PR_AddBuiltin (&sv_pr_state, "makevectors", PF_makevectors, 1);
PR_AddBuiltin (&sv_pr_state, "setmodel", PF_setmodel, 3); // void (entity e, string m) setmodel // void (entity e, vector o) setorigin
PR_AddBuiltin (&sv_pr_state, "setsize", PF_setsize, 4); // void (entity e, vector min, vector max) setsize PR_AddBuiltin (&sv_pr_state, "setorigin", PF_setorigin, 2);
PR_AddBuiltin (&sv_pr_state, "fixme", PF_Fixme, 5); // void (entity e, vector min, vector max) setabssize // void (entity e, string m) setmodel
PR_AddBuiltin (&sv_pr_state, "sound", PF_sound, 8); // void (entity e, float chan, string samp) sound PR_AddBuiltin (&sv_pr_state, "setmodel", PF_setmodel, 3);
PR_AddBuiltin (&sv_pr_state, "error", PF_error, 10); // void (string e) error // void (entity e, vector min, vector max) setsize
PR_AddBuiltin (&sv_pr_state, "objerror", PF_objerror, 11); // void (string e) objerror PR_AddBuiltin (&sv_pr_state, "setsize", PF_setsize, 4);
PR_AddBuiltin (&sv_pr_state, "spawn", PF_Spawn, 14); // entity () spawn // void (entity e, vector min, vector max) setabssize
PR_AddBuiltin (&sv_pr_state, "remove", PF_Remove, 15); // void (entity e) remove PR_AddBuiltin (&sv_pr_state, "fixme", PF_Fixme, 5);
PR_AddBuiltin (&sv_pr_state, "traceline", PF_traceline, 16); // float (vector v1, vector v2, float tryents) traceline
PR_AddBuiltin (&sv_pr_state, "checkclient", PF_checkclient, 17); // entity () clientlist
PR_AddBuiltin (&sv_pr_state, "precache_sound", PF_precache_sound, 19); // void (string s) precache_sound
PR_AddBuiltin (&sv_pr_state, "precache_model", PF_precache_model, 20); // void (string s) precache_model
PR_AddBuiltin (&sv_pr_state, "stuffcmd", PF_stuffcmd, 21); // void (entity client, string s) stuffcmd
PR_AddBuiltin (&sv_pr_state, "findradius", PF_findradius, 22); // entity (vector org, float rad) findradius
PR_AddBuiltin (&sv_pr_state, "bprint", PF_bprint, 23); // void (string s) bprint
PR_AddBuiltin (&sv_pr_state, "sprint", PF_sprint, 24); // void (entity client, string s) sprint
PR_AddBuiltin (&sv_pr_state, "walkmove", PF_walkmove, 32); // float (float yaw, float dist) walkmove
PR_AddBuiltin (&sv_pr_state, "droptofloor", PF_droptofloor, 34); // float () droptofloor
PR_AddBuiltin (&sv_pr_state, "lightstyle", PF_lightstyle, 35); // void (float style, string value) lightstyle
PR_AddBuiltin (&sv_pr_state, "checkbottom", PF_checkbottom, 40); // float (entity e) checkbottom
PR_AddBuiltin (&sv_pr_state, "pointcontents", PF_pointcontents, 41); // float (vector v) pointcontents
PR_AddBuiltin (&sv_pr_state, "aim", PF_aim, 44); // vector (entity e, float speed) aim
PR_AddBuiltin (&sv_pr_state, "localcmd", PF_localcmd, 46); // void (string s) localcmd
PR_AddBuiltin (&sv_pr_state, "changeyaw", PF_changeyaw, 49); // void () ChangeYaw
PR_AddBuiltin (&sv_pr_state, "writebyte", PF_WriteByte, 52); // void (float to, float f) WriteByte
PR_AddBuiltin (&sv_pr_state, "WriteBytes", PF_WriteBytes, -1); // void (float to, ...) WriteBytes
PR_AddBuiltin (&sv_pr_state, "writechar", PF_WriteChar, 53); // void (float to, float f) WriteChar
PR_AddBuiltin (&sv_pr_state, "writeshort", PF_WriteShort, 54); // void (float to, float f) WriteShort
PR_AddBuiltin (&sv_pr_state, "writelong", PF_WriteLong, 55); // void (float to, float f) WriteLong
PR_AddBuiltin (&sv_pr_state, "writecoord", PF_WriteCoord, 56); // void (float to, float f) WriteCoord
PR_AddBuiltin (&sv_pr_state, "writeangle", PF_WriteAngle, 57); // void (float to, float f) WriteAngle
PR_AddBuiltin (&sv_pr_state, "WriteCoordV", PF_WriteCoordV, -1); // void (float to, vector v) WriteCoordV
PR_AddBuiltin (&sv_pr_state, "WriteAngleV", PF_WriteAngleV, -1); // void (float to, vector v) WriteAngleV
PR_AddBuiltin (&sv_pr_state, "writestring", PF_WriteString, 58); // void (float to, string s) WriteString
PR_AddBuiltin (&sv_pr_state, "writeentity", PF_WriteEntity, 59); // void (float to, entity s) WriteEntity
PR_AddBuiltin (&sv_pr_state, "movetogoal", SV_MoveToGoal, 67); // void (float step) movetogoal
PR_AddBuiltin (&sv_pr_state, "precache_file", PF_precache_file, 68); // string (string s) precache_file
PR_AddBuiltin (&sv_pr_state, "makestatic", PF_makestatic, 69); // void (entity e) makestatic
PR_AddBuiltin (&sv_pr_state, "changelevel", PF_changelevel, 70); // void (string s) changelevel
PR_AddBuiltin (&sv_pr_state, "centerprint", PF_centerprint, 73); // void (...) centerprint
PR_AddBuiltin (&sv_pr_state, "ambientsound", PF_ambientsound, 74); // void (vector pos, string samp, float vol, float atten) ambientsound
PR_AddBuiltin (&sv_pr_state, "precache_model2", PF_precache_model, 75); // string (string s) precache_model2
PR_AddBuiltin (&sv_pr_state, "precache_sound2", PF_precache_sound, 76); // string (string s) precache_sound2
PR_AddBuiltin (&sv_pr_state, "precache_file2", PF_precache_file, 77); // string (string s) precache_file2
PR_AddBuiltin (&sv_pr_state, "setspawnparms", PF_setspawnparms, 78); // void (entity e) setspawnparms
PR_AddBuiltin (&sv_pr_state, "logfrag", PF_logfrag, 79); // void (entity killer, entity killee) logfrag
PR_AddBuiltin (&sv_pr_state, "infokey", PF_infokey, 80); // string (entity e, string key) infokey
PR_AddBuiltin (&sv_pr_state, "multicast", PF_multicast, 82); // void (vector where, float set) multicast
PR_AddBuiltin (&sv_pr_state, "testentitypos", PF_testentitypos, 92); // entity (entity ent) testentitypos
PR_AddBuiltin (&sv_pr_state, "hullpointcontents", PF_hullpointcontents, 93); // integer (entity ent, vector point) hullpointcontents
PR_AddBuiltin (&sv_pr_state, "getboxbounds", PF_getboxbounds, 94); // vector (integer hull, integer max) getboxbounds
PR_AddBuiltin (&sv_pr_state, "getboxhull", PF_getboxhull, 95); // integer () getboxhull
PR_AddBuiltin (&sv_pr_state, "freeboxhull", PF_freeboxhull, 96); // void (integer hull) freeboxhull
PR_AddBuiltin (&sv_pr_state, "rotate_bbox", PF_rotate_bbox, 97); // void (integer hull, vector right, vector forward, vector up, vector mins, vector maxs) rotate_bbox
PR_AddBuiltin (&sv_pr_state, "checkmove", PF_checkmove, 98); // void (vector start, vector mins, vector maxs, vector end, float type, entity passent) checkmove
PR_AddBuiltin (&sv_pr_state, "checkextension", PF_Checkextension, 99); // float () checkextension
PR_AddBuiltin (&sv_pr_state, "setinfokey", PF_setinfokey, 102); // void (entity ent, string key, string value) setinfokey
PR_AddBuiltin (&sv_pr_state, "cfopen", PF_cfopen, 103); // float (string path, string mode) cfopen
PR_AddBuiltin (&sv_pr_state, "cfclose", PF_cfclose, 104); // void (float desc) cfclose
PR_AddBuiltin (&sv_pr_state, "cfread", PF_cfread, 105); // string (float desc) cfread
PR_AddBuiltin (&sv_pr_state, "cfwrite", PF_cfwrite, 106); // float (float desc, string buf) cfwrite
PR_AddBuiltin (&sv_pr_state, "cfeof", PF_cfeof, 107); // float (float desc) cfeof
PR_AddBuiltin (&sv_pr_state, "cfquota", PF_cfquota, 108); // float () cfquota
PR_AddBuiltin (&sv_pr_state, "SV_AllocClient", PF_SV_AllocClient, -1); // entity () SV_AllocClient // void (entity e, float chan, string samp) sound
PR_AddBuiltin (&sv_pr_state, "SV_FreeClient", PF_SV_FreeClient, -1); // void (entity cl) SV_FreeClient PR_AddBuiltin (&sv_pr_state, "sound", PF_sound, 8);
PR_AddBuiltin (&sv_pr_state, "SV_SetUserinfo", PF_SV_SetUserinfo, -1); // void (entity cl, string userinfo) SV_SetUserinfo
PR_AddBuiltin (&sv_pr_state, "SV_SetPing", PR_SV_SetPing, -1); // void (entity cl, integer ping) SV_SetPing // void (string e) error
PR_AddBuiltin (&sv_pr_state, "SV_UserCmd", PR_SV_UserCmd, -1); // void (entity cl, float secs, vector angles, vector move, integer buttons, integer impulse) SV_UserCmd PR_AddBuiltin (&sv_pr_state, "error", PF_error, 10);
// void (string e) objerror
PR_AddBuiltin (&sv_pr_state, "objerror", PF_objerror, 11);
// entity () spawn
PR_AddBuiltin (&sv_pr_state, "spawn", PF_Spawn, 14);
// void (entity e) remove
PR_AddBuiltin (&sv_pr_state, "remove", PF_Remove, 15);
// float (vector v1, vector v2, float tryents) traceline
PR_AddBuiltin (&sv_pr_state, "traceline", PF_traceline, 16);
// entity () clientlist
PR_AddBuiltin (&sv_pr_state, "checkclient", PF_checkclient, 17);
// void (string s) precache_sound
PR_AddBuiltin (&sv_pr_state, "precache_sound", PF_precache_sound, 19);
// void (string s) precache_model
PR_AddBuiltin (&sv_pr_state, "precache_model", PF_precache_model, 20);
// void (entity client, string s) stuffcmd
PR_AddBuiltin (&sv_pr_state, "stuffcmd", PF_stuffcmd, 21);
// entity (vector org, float rad) findradius
PR_AddBuiltin (&sv_pr_state, "findradius", PF_findradius, 22);
// void (string s) bprint
PR_AddBuiltin (&sv_pr_state, "bprint", PF_bprint, 23);
// void (entity client, string s) sprint
PR_AddBuiltin (&sv_pr_state, "sprint", PF_sprint, 24);
// float (float yaw, float dist) walkmove
PR_AddBuiltin (&sv_pr_state, "walkmove", PF_walkmove, 32);
// float () droptofloor
PR_AddBuiltin (&sv_pr_state, "droptofloor", PF_droptofloor, 34);
// void (float style, string value) lightstyle
PR_AddBuiltin (&sv_pr_state, "lightstyle", PF_lightstyle, 35);
// float (entity e) checkbottom
PR_AddBuiltin (&sv_pr_state, "checkbottom", PF_checkbottom, 40);
// float (vector v) pointcontents
PR_AddBuiltin (&sv_pr_state, "pointcontents", PF_pointcontents, 41);
// vector (entity e, float speed) aim
PR_AddBuiltin (&sv_pr_state, "aim", PF_aim, 44);
// void (string s) localcmd
PR_AddBuiltin (&sv_pr_state, "localcmd", PF_localcmd, 46);
// void () ChangeYaw
PR_AddBuiltin (&sv_pr_state, "changeyaw", PF_changeyaw, 49);
// void (float to, float f) WriteByte
PR_AddBuiltin (&sv_pr_state, "writebyte", PF_WriteByte, 52);
// void (float to, ...) WriteBytes
PR_AddBuiltin (&sv_pr_state, "WriteBytes", PF_WriteBytes, -1);
// void (float to, float f) WriteChar
PR_AddBuiltin (&sv_pr_state, "writechar", PF_WriteChar, 53);
// void (float to, float f) WriteShort
PR_AddBuiltin (&sv_pr_state, "writeshort", PF_WriteShort, 54);
// void (float to, float f) WriteLong
PR_AddBuiltin (&sv_pr_state, "writelong", PF_WriteLong, 55);
// void (float to, float f) WriteCoord
PR_AddBuiltin (&sv_pr_state, "writecoord", PF_WriteCoord, 56);
// void (float to, float f) WriteAngle
PR_AddBuiltin (&sv_pr_state, "writeangle", PF_WriteAngle, 57);
// void (float to, vector v) WriteCoordV
PR_AddBuiltin (&sv_pr_state, "WriteCoordV", PF_WriteCoordV, -1);
// void (float to, vector v) WriteAngleV
PR_AddBuiltin (&sv_pr_state, "WriteAngleV", PF_WriteAngleV, -1);
// void (float to, string s) WriteString
PR_AddBuiltin (&sv_pr_state, "writestring", PF_WriteString, 58);
// void (float to, entity s) WriteEntity
PR_AddBuiltin (&sv_pr_state, "writeentity", PF_WriteEntity, 59);
// void (float step) movetogoal
PR_AddBuiltin (&sv_pr_state, "movetogoal", SV_MoveToGoal, 67);
// string (string s) precache_file
PR_AddBuiltin (&sv_pr_state, "precache_file", PF_precache_file, 68);
// void (entity e) makestatic
PR_AddBuiltin (&sv_pr_state, "makestatic", PF_makestatic, 69);
// void (string s) changelevel
PR_AddBuiltin (&sv_pr_state, "changelevel", PF_changelevel, 70);
// void (...) centerprint
PR_AddBuiltin (&sv_pr_state, "centerprint", PF_centerprint, 73);
// void (vector pos, string samp, float vol, float atten) ambientsound
PR_AddBuiltin (&sv_pr_state, "ambientsound", PF_ambientsound, 74);
// string (string s) precache_model2
PR_AddBuiltin (&sv_pr_state, "precache_model2", PF_precache_model, 75);
// string (string s) precache_sound2
PR_AddBuiltin (&sv_pr_state, "precache_sound2", PF_precache_sound, 76);
// string (string s) precache_file2
PR_AddBuiltin (&sv_pr_state, "precache_file2", PF_precache_file, 77);
// void (entity e) setspawnparms
PR_AddBuiltin (&sv_pr_state, "setspawnparms", PF_setspawnparms, 78);
// void (entity killer, entity killee) logfrag
PR_AddBuiltin (&sv_pr_state, "logfrag", PF_logfrag, 79);
// string (entity e, string key) infokey
PR_AddBuiltin (&sv_pr_state, "infokey", PF_infokey, 80);
// void (vector where, float set) multicast
PR_AddBuiltin (&sv_pr_state, "multicast", PF_multicast, 82);
// entity (entity ent) testentitypos
PR_AddBuiltin (&sv_pr_state, "testentitypos", PF_testentitypos, 92);
// integer (entity ent, vector point) hullpointcontents
PR_AddBuiltin (&sv_pr_state, "hullpointcontents", PF_hullpointcontents,
93);
// vector (integer hull, integer max) getboxbounds
PR_AddBuiltin (&sv_pr_state, "getboxbounds", PF_getboxbounds, 94);
// integer () getboxhull
PR_AddBuiltin (&sv_pr_state, "getboxhull", PF_getboxhull, 95);
// void (integer hull) freeboxhull
PR_AddBuiltin (&sv_pr_state, "freeboxhull", PF_freeboxhull, 96);
// void (integer hull, vector right, vector forward, vector up, vector mins, vector maxs) rotate_bbox
PR_AddBuiltin (&sv_pr_state, "rotate_bbox", PF_rotate_bbox, 97);
// void (vector start, vector mins, vector maxs, vector end, float type, entity passent) checkmove
PR_AddBuiltin (&sv_pr_state, "checkmove", PF_checkmove, 98);
// float () checkextension
PR_AddBuiltin (&sv_pr_state, "checkextension", PF_checkextension, 99);
// void (entity ent, string key, string value) setinfokey
PR_AddBuiltin (&sv_pr_state, "setinfokey", PF_setinfokey, 102);
// float (string path, string mode) cfopen
PR_AddBuiltin (&sv_pr_state, "cfopen", PF_cfopen, 103);
// void (float desc) cfclose
PR_AddBuiltin (&sv_pr_state, "cfclose", PF_cfclose, 104);
// string (float desc) cfread
PR_AddBuiltin (&sv_pr_state, "cfread", PF_cfread, 105);
// float (float desc, string buf) cfwrite
PR_AddBuiltin (&sv_pr_state, "cfwrite", PF_cfwrite, 106);
// float (float desc) cfeof
PR_AddBuiltin (&sv_pr_state, "cfeof", PF_cfeof, 107);
// float () cfquota
PR_AddBuiltin (&sv_pr_state, "cfquota", PF_cfquota, 108);
// entity () SV_AllocClient
PR_AddBuiltin (&sv_pr_state, "SV_AllocClient", PF_SV_AllocClient, -1);
// void (entity cl) SV_FreeClient
PR_AddBuiltin (&sv_pr_state, "SV_FreeClient", PF_SV_FreeClient, -1);
// void (entity cl, string userinfo) SV_SetUserinfo
PR_AddBuiltin (&sv_pr_state, "SV_SetUserinfo", PF_SV_SetUserinfo, -1);
// void (entity cl, integer ping) SV_SetPing
PR_AddBuiltin (&sv_pr_state, "SV_SetPing", PR_SV_SetPing, -1);
// void (entity cl, float secs, vector angles, vector move, integer buttons, integer impulse) SV_UserCmd
PR_AddBuiltin (&sv_pr_state, "SV_UserCmd", PR_SV_UserCmd, -1);
}; };