+ if (r_surfaceworldnode.integer || viewleaf->contents == CONTENTS_SOLID)
+ R_SurfaceWorldNode (ent);
+ else
+ R_PortalWorldNode (ent, viewleaf);
+
+ if (r_drawportals.integer)
+ R_DrawPortals(ent);
+}
+
+void R_Q1BSP_DrawSky(entity_render_t *ent)
+{
+ if (ent->model == NULL)
+ return;
+ if (ent != &cl_entities[0].render)
+ R_PrepareBrushModel(ent);
+ R_PrepareSurfaces(ent);
+ R_DrawSurfaces(ent, SURF_DRAWSKY);
+}
+
+void R_Q1BSP_Draw(entity_render_t *ent)
+{
+ if (ent->model == NULL)
+ return;
+ c_bmodels++;
+ if (ent != &cl_entities[0].render)
+ R_PrepareBrushModel(ent);
+ R_PrepareSurfaces(ent);
+ R_UpdateTextureInfo(ent);
+ R_UpdateLightmapInfo(ent);
+ R_DrawSurfaces(ent, SURF_DRAWTURB | SURF_LIGHTMAP);
+}
+
+void R_Q1BSP_GetLightInfo(entity_render_t *ent, vec3_t relativelightorigin, float lightradius, vec3_t outmins, vec3_t outmaxs, int *outclusterlist, qbyte *outclusterpvs, int *outnumclusterspointer, int *outsurfacelist, qbyte *outsurfacepvs, int *outnumsurfacespointer)
+{
+ model_t *model = ent->model;
+ vec3_t lightmins, lightmaxs;
+ int t, leafindex, marksurfaceindex, surfaceindex, triangleindex, outnumclusters = 0, outnumsurfaces = 0;
+ const int *e;
+ const float *v[3];
+ msurface_t *surface;
+ mleaf_t *leaf;
+ const qbyte *pvs;
+ lightmins[0] = relativelightorigin[0] - lightradius;
+ lightmins[1] = relativelightorigin[1] - lightradius;
+ lightmins[2] = relativelightorigin[2] - lightradius;
+ lightmaxs[0] = relativelightorigin[0] + lightradius;
+ lightmaxs[1] = relativelightorigin[1] + lightradius;
+ lightmaxs[2] = relativelightorigin[2] + lightradius;
+ *outnumclusterspointer = 0;
+ *outnumsurfacespointer = 0;
+ memset(outclusterpvs, 0, model->brush.num_pvsclusterbytes);
+ memset(outsurfacepvs, 0, (model->nummodelsurfaces + 7) >> 3);
+ if (model == NULL)
+ {
+ VectorCopy(lightmins, outmins);
+ VectorCopy(lightmaxs, outmaxs);
+ return;
+ }
+ VectorCopy(relativelightorigin, outmins);
+ VectorCopy(relativelightorigin, outmaxs);
+ if (model->brush.GetPVS)
+ pvs = model->brush.GetPVS(model, relativelightorigin);
+ else
+ pvs = NULL;
+ // FIXME: use BSP recursion as lights are often small
+ for (leafindex = 0, leaf = model->brushq1.data_leafs;leafindex < model->brushq1.num_leafs;leafindex++, leaf++)
+ {
+ if (BoxesOverlap(lightmins, lightmaxs, leaf->mins, leaf->maxs) && (pvs == NULL || CHECKPVSBIT(pvs, leaf->clusterindex)))
+ {
+ outmins[0] = min(outmins[0], leaf->mins[0]);
+ outmins[1] = min(outmins[1], leaf->mins[1]);
+ outmins[2] = min(outmins[2], leaf->mins[2]);
+ outmaxs[0] = max(outmaxs[0], leaf->maxs[0]);
+ outmaxs[1] = max(outmaxs[1], leaf->maxs[1]);
+ outmaxs[2] = max(outmaxs[2], leaf->maxs[2]);
+ if (outclusterpvs)