Check return value on R_AllocDlight. Small optimization, people cutting r_dlight_max heavily should like it.

This commit is contained in:
Ragnvald Maartmann-Moe IV 2002-06-05 22:07:38 +00:00
parent f31705380f
commit 46949068a2
9 changed files with 100 additions and 72 deletions

View file

@ -146,13 +146,14 @@ R_ShowNearestLoc (void)
if (nearloc) {
dl = R_AllocDlight (4096);
if (dl) {
VectorCopy (nearloc->loc, dl->origin);
dl->radius = 200;
dl->die = r_realtime + 0.1;
dl->color[0] = 0;
dl->color[1] = 1;
dl->color[2] = 0;
}
VectorCopy (nearloc->loc, trueloc);
(*R_WizSpikeEffect) (trueloc);
}

View file

@ -435,11 +435,9 @@ R_AllocDlight (int key)
{
int i;
dlight_t *dl;
static dlight_t dummy;
if (!r_maxdlights) {
memset (&dummy, 0, sizeof (dummy));
return &dummy;
return NULL;
}
// first look for an exact key match

View file

@ -465,10 +465,12 @@ R_ShowNearestLoc (void)
nearloc = locs_find (r_origin);
if (nearloc) {
dl = R_AllocDlight (4096);
if (dl) {
VectorCopy (nearloc->loc, dl->origin);
dl->radius = 200;
dl->die = r_realtime + 0.1;
dl->color[1] = 1;
}
VectorCopy(nearloc->loc, trueloc);
R_RunParticleEffect(trueloc, vec3_origin, 252, 10);

View file

@ -493,10 +493,12 @@ R_ShowNearestLoc (void)
nearloc = locs_find (r_origin);
if (nearloc) {
dl = R_AllocDlight (4096);
if (dl) {
VectorCopy (nearloc->loc, dl->origin);
dl->radius = 200;
dl->die = r_realtime + 0.1;
dl->color[1] = 1;
}
VectorCopy(nearloc->loc, trueloc);
R_RunParticleEffect(trueloc, vec3_origin, 252, 10);

View file

@ -433,9 +433,11 @@ CL_NewDlight (int key, vec3_t org, int effects)
if (!(effects & (EF_BLUE | EF_RED | EF_BRIGHTLIGHT | EF_DIMLIGHT)))
return;
radius = 200 + (rand () & 31);
dl = R_AllocDlight (key);
if (!dl)
return;
VectorCopy (org, dl->origin);
switch (effects & (EF_BLUE | EF_RED)) {
case EF_BLUE | EF_RED:
VectorCopy (purple, dl->color);
@ -450,6 +452,7 @@ CL_NewDlight (int key, vec3_t org, int effects)
VectorCopy (normal, dl->color);
break;
}
radius = 200 + (rand () & 31);
if (effects & EF_BRIGHTLIGHT) {
radius += 200;
dl->origin[2] += 16;
@ -593,6 +596,7 @@ CL_RelinkEntities (void)
vec3_t fv, rv, uv;
dl = R_AllocDlight (i);
if (dl) {
VectorCopy (ent->origin, dl->origin);
dl->origin[2] += 16;
AngleVectors (ent->angles, fv, rv, uv);
@ -605,15 +609,18 @@ CL_RelinkEntities (void)
dl->color[1] = 0.1;
dl->color[2] = 0.05;
}
}
CL_NewDlight (i, ent->origin, state->baseline.effects);
if (VectorDistance_fast(state->msg_origins[1], ent->origin) > (256*256))
VectorCopy (ent ->origin, state->msg_origins[1]);
if (ent->model->flags & EF_ROCKET) {
dl = R_AllocDlight (i);
if (dl) {
VectorCopy (ent->origin, dl->origin);
VectorCopy (r_firecolor->vec, dl->color);
dl->radius = 200;
dl->die = cl.time + 0.1;
}
R_RocketTrail (ent);
} else if (ent->model->flags & EF_GRENADE)
R_GrenadeTrail (ent);

View file

@ -285,6 +285,7 @@ CL_ParseTEnt (void)
// light
dl = R_AllocDlight (0);
if (dl) {
VectorCopy (pos, dl->origin);
dl->radius = 350;
dl->die = cl.time + 0.5;
@ -292,6 +293,7 @@ CL_ParseTEnt (void)
dl->color[0] = 0.86;
dl->color[1] = 0.31;
dl->color[2] = 0.24;
}
// sound
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
@ -342,8 +344,11 @@ CL_ParseTEnt (void)
MSG_ReadCoordV (net_message, pos);
colorStart = MSG_ReadByte (net_message);
colorLength = MSG_ReadByte (net_message);
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
R_ParticleExplosion2 (pos, colorStart, colorLength);
dl = R_AllocDlight (0);
if (!dl)
break;
VectorCopy (pos, dl->origin);
dl->radius = 350;
dl->die = cl.time + 0.5;
@ -354,7 +359,6 @@ CL_ParseTEnt (void)
3 + 1] * (1.0 / 255.0);
dl->color[2] = vid_basepal[(colorStart + (rand() % colorLength)) *
3 + 2] * (1.0 / 255.0);
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
break;
case TE_GUNSHOT: // bullet hitting wall
@ -373,6 +377,7 @@ CL_ParseTEnt (void)
// light
dl = R_AllocDlight (0);
if (dl) {
VectorCopy (pos, dl->origin);
dl->radius = 150;
dl->die = cl.time + 0.1;
@ -380,6 +385,7 @@ CL_ParseTEnt (void)
dl->color[0] = 0.25;
dl->color[1] = 0.40;
dl->color[2] = 0.65;
}
R_LightningBloodEffect (pos);
break;

View file

@ -100,8 +100,9 @@ CL_NewDlight (int key, vec3_t org, int effects)
if (!(effects & (EF_BLUE | EF_RED | EF_BRIGHTLIGHT | EF_DIMLIGHT)))
return;
radius = 200 + (rand () & 31);
dl = R_AllocDlight (key);
if (!dl)
return;
VectorCopy (org, dl->origin);
dl->die = cl.time + 0.1;
switch (effects & (EF_BLUE | EF_RED)) {
@ -118,6 +119,7 @@ CL_NewDlight (int key, vec3_t org, int effects)
VectorCopy (normal, dl->color);
break;
}
radius = 200 + (rand () & 31);
if (effects & EF_BRIGHTLIGHT) {
radius += 200;
dl->origin[2] += 16;
@ -510,11 +512,13 @@ CL_LinkPacketEntities (void)
if (model->flags & EF_ROCKET) {
dl = R_AllocDlight (-s1->number);
if (dl) {
VectorCopy ((*ent)->origin, dl->origin);
VectorCopy (r_firecolor->vec, dl->color);
dl->radius = 200;
dl->die = cl.time + 0.1;
}
}
if (model->flags & EF_ROCKET)
R_RocketTrail (*ent);

View file

@ -1102,8 +1102,10 @@ CL_MuzzleFlash (void)
pl = &cl.frames[parsecountmod].playerstate[i - 1];
dl = R_AllocDlight (i); //FIXME
// this interfers with powerup glows, but we need more lights.
dl = R_AllocDlight (i);
if (!dl)
return;
VectorCopy (pl->origin, dl->origin);
if (i - 1 == cl.playernum)
AngleVectors (cl.viewangles, fv, rv, uv);

View file

@ -349,6 +349,7 @@ CL_ParseTEnt (void)
// light
dl = R_AllocDlight (0);
if (dl) {
VectorCopy (pos, dl->origin);
dl->radius = 350;
dl->die = cl.time + 0.5;
@ -356,6 +357,7 @@ CL_ParseTEnt (void)
dl->color[0] = 0.86;
dl->color[1] = 0.31;
dl->color[2] = 0.24;
}
// sound
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
@ -408,8 +410,11 @@ CL_ParseTEnt (void)
MSG_ReadCoordV (net_message, pos);
colorStart = MSG_ReadByte (net_message);
colorLength = MSG_ReadByte (net_message);
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
R_ParticleExplosion2 (pos, colorStart, colorLength);
dl = R_AllocDlight (0);
if (!dl)
break;
VectorCopy (pos, dl->origin);
dl->radius = 350;
dl->die = cl.time + 0.5;
@ -420,7 +425,6 @@ CL_ParseTEnt (void)
3 + 1] * (1.0 / 255.0);
dl->color[2] = vid_basepal[(colorStart + (rand() % colorLength)) *
3 + 2] * (1.0 / 255.0);
S_StartSound (-1, 0, cl_sfx_r_exp3, pos, 1, 1);
break;
case TE_GUNSHOT: // bullet hitting wall
@ -440,6 +444,7 @@ CL_ParseTEnt (void)
// light
dl = R_AllocDlight (0);
if (dl) {
VectorCopy (pos, dl->origin);
dl->radius = 150;
dl->die = cl.time + 0.1;
@ -447,6 +452,7 @@ CL_ParseTEnt (void)
dl->color[0] = 0.25;
dl->color[1] = 0.40;
dl->color[2] = 0.65;
}
R_LightningBloodEffect (pos);
break;