return cliptrace;
}
-float CL_SelectTraceLine(const vec3_t start, const vec3_t end, vec3_t impact, vec3_t normal, int *hitent, entity_render_t *ignoreent)
+float CL_SelectTraceLine(const vec3_t start, const vec3_t end, vec3_t impact, vec3_t normal, int *hitent, entity_render_t *ignoreent, qboolean csqcents)
{
float maxfrac, maxrealfrac;
- int n;
+ int n, entsnum;
+ entity_t *entlist;
+ unsigned char *entactivelist;
entity_render_t *ent;
float tracemins[3], tracemaxs[3];
trace_t trace;
tracemins[2] = min(start[2], end[2]);
tracemaxs[2] = max(start[2], end[2]);
+ if(csqcents)
+ {
+ entlist = cl_csqcentities;
+ entactivelist = cl_csqcentities_active;
+ entsnum = cl_num_csqcentities;
+ }
+ else
+ {
+ entlist = cl_entities;
+ entactivelist = cl_entities_active;
+ entsnum = cl_num_entities;
+ }
+
// look for embedded bmodels
- for (n = 0;n < cl_num_entities;n++)
+ for (n = 0;n < entsnum;n++)
{
- if (!cl_entities_active[n])
+ if (!entactivelist[n])
continue;
- ent = &cl_entities[n].render;
+ ent = &entlist[n].render;
if (!BoxesOverlap(ent->mins, ent->maxs, tracemins, tracemaxs))
continue;
if (!ent->model || !ent->model->TraceBox)
if ((ent->flags & RENDER_EXTERIORMODEL) && !chase_active.integer)
continue;
// if transparent and not selectable, skip entity
- if (!(cl_entities[n].state_current.effects & EF_SELECTABLE) && (ent->alpha < 1 || (ent->effects & (EF_ADDITIVE | EF_NODEPTHTEST))))
+ if (!(entlist[n].state_current.effects & EF_SELECTABLE) && (ent->alpha < 1 || (ent->effects & (EF_ADDITIVE | EF_NODEPTHTEST))))
continue;
if (ent == ignoreent)
continue;