From: havoc Date: Thu, 22 Feb 2007 08:44:01 +0000 (+0000) Subject: added some debugging code to RSurf_DrawBatch_WithLightmapSwitching to print out how... X-Git-Tag: xonotic-v0.1.0preview~3526 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=ff11978d949d651b486e3372a0260fd18e858d15;p=xonotic%2Fdarkplaces.git added some debugging code to RSurf_DrawBatch_WithLightmapSwitching to print out how many surfaces are rendered in each batch and each subbatch by lightmap (this revealed that q3map2's surface sorting is horrible) git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@6890 d7cf8633-e32d-0410-b094-e92efae38249 --- diff --git a/gl_rmain.c b/gl_rmain.c index af64eda4..a2e4b418 100644 --- a/gl_rmain.c +++ b/gl_rmain.c @@ -3090,6 +3090,19 @@ static void RSurf_DrawBatch_WithLightmapSwitching(int texturenumsurfaces, msurfa } else if (r_batchmode.integer == 1) { +#if 0 + Con_Printf("%s batch sizes ignoring lightmap:", rsurface_texture->name); + for (i = 0;i < texturenumsurfaces;i = j) + { + surface = texturesurfacelist[i]; + for (j = i + 1, surface2 = surface + 1;j < texturenumsurfaces;j++, surface2++) + if (texturesurfacelist[j] != surface2) + break; + Con_Printf(" %i", j - i); + } + Con_Printf("\n"); + Con_Printf("%s batch sizes honoring lightmap:", rsurface_texture->name); +#endif for (i = 0;i < texturenumsurfaces;i = j) { surface = texturesurfacelist[i]; @@ -3099,12 +3112,18 @@ static void RSurf_DrawBatch_WithLightmapSwitching(int texturenumsurfaces, msurfa for (j = i + 1, surface2 = surface + 1;j < texturenumsurfaces;j++, surface2++) if (texturesurfacelist[j] != surface2 || texturesurfacelist[j]->lightmaptexture != surface->lightmaptexture) break; +#if 0 + Con_Printf(" %i", j - i); +#endif surface2 = texturesurfacelist[j-1]; numvertices = surface2->num_firstvertex + surface2->num_vertices - surface->num_firstvertex; numtriangles = surface2->num_firsttriangle + surface2->num_triangles - surface->num_firsttriangle; GL_LockArrays(surface->num_firstvertex, numvertices); R_Mesh_Draw(surface->num_firstvertex, numvertices, numtriangles, (rsurface_model->surfmesh.data_element3i + 3 * surface->num_firsttriangle)); } +#if 0 + Con_Printf("\n"); +#endif } else {