+ //zymlump_t lump_trizone; // byte trizone[numtris]; // see trizone explanation
+ //loadmodel->alias.zymdata_trizone = Mem_Alloc(loadmodel->mempool, pheader->numtris);
+ //memcpy(loadmodel->alias.zymdata_trizone, (void *) (pheader->lump_trizone.start + pbase), pheader->numtris);
+
+ loadmodel->alias.aliasdata_meshes = Mem_Alloc(loadmodel->mempool, loadmodel->alias.aliasnum_meshes * sizeof(aliasmesh_t));
+
+ //zymlump_t lump_shaders; // char shadername[numshaders][32]; // shaders used on this model
+ //zymlump_t lump_render; // int renderlist[rendersize]; // sorted by shader with run lengths (int count), shaders are sequentially used, each run can be used with glDrawElements (each triangle is 3 int indices)
+ // byteswap, validate, and swap winding order of tris
+ count = pheader->numshaders * sizeof(int) + pheader->numtris * sizeof(int[3]);
+ if (pheader->lump_render.length != count)
+ Host_Error("%s renderlist is wrong size (%i bytes, should be %i bytes)\n", loadmodel->name, pheader->lump_render.length, count);
+ renderlist = (void *) (pheader->lump_render.start + pbase);
+ renderlistend = (void *) ((qbyte *) renderlist + pheader->lump_render.length);
+ for (i = 0;i < loadmodel->alias.aliasnum_meshes;i++)
+ {
+ if (renderlist >= renderlistend)
+ Host_Error("%s corrupt renderlist (wrong size)\n", loadmodel->name);
+ count = BigLong(*renderlist);renderlist++;
+ if (renderlist + count * 3 > renderlistend || (i == pheader->numshaders - 1 && renderlist + count * 3 != renderlistend))
+ Host_Error("%s corrupt renderlist (wrong size)\n", loadmodel->name);
+ mesh = loadmodel->alias.aliasdata_meshes + i;
+ mesh->num_skins = loadmodel->numskins;
+ mesh->num_triangles = count;
+ mesh->data_skins = Mem_Alloc(loadmodel->mempool, mesh->num_skins * sizeof(aliasskin_t));
+ mesh->data_element3i = Mem_Alloc(loadmodel->mempool, mesh->num_triangles * sizeof(int[3]));
+ mesh->data_neighbor3i = Mem_Alloc(loadmodel->mempool, mesh->num_triangles * sizeof(int[3]));
+ outelements = mesh->data_element3i;
+ for (j = 0;j < mesh->num_triangles;j++)
+ {
+ outelements[2] = BigLong(renderlist[0]);
+ outelements[1] = BigLong(renderlist[1]);
+ outelements[0] = BigLong(renderlist[2]);
+ if ((unsigned int)outelements[0] >= (unsigned int)pheader->numverts
+ || (unsigned int)outelements[1] >= (unsigned int)pheader->numverts
+ || (unsigned int)outelements[2] >= (unsigned int)pheader->numverts)
+ Host_Error("%s corrupt renderlist (out of bounds index)\n", loadmodel->name);
+ renderlist += 3;
+ outelements += 3;
+ }
+ remapvertices = Mem_Alloc(loadmodel->mempool, pheader->numverts * sizeof(int));
+ mesh->num_vertices = Mod_BuildVertexRemapTableFromElements(mesh->num_triangles * 3, mesh->data_element3i, pheader->numverts, remapvertices);
+ for (j = 0;j < mesh->num_triangles * 3;j++)
+ mesh->data_element3i[j] = remapvertices[mesh->data_element3i[j]];
+ Mod_BuildTriangleNeighbors(mesh->data_neighbor3i, mesh->data_element3i, mesh->num_triangles);
+ mesh->data_texcoord2f = Mem_Alloc(loadmodel->mempool, mesh->num_vertices * sizeof(float[2]));
+ for (j = 0;j < pheader->numverts;j++)
+ {
+ if (remapvertices[j] >= 0)
+ {
+ mesh->data_texcoord2f[remapvertices[j]*2+0] = outtexcoord2f[j*2+0];
+ mesh->data_texcoord2f[remapvertices[j]*2+1] = outtexcoord2f[j*2+1];
+ }
+ }
+ mesh->num_vertexboneweights = 0;
+ for (j = 0;j < mesh->num_vertices;j++)
+ if (remapvertices[j] >= 0)
+ mesh->num_vertexboneweights += vertbonecounts[remapvertices[j]];
+ mesh->data_vertexboneweights = Mem_Alloc(loadmodel->mempool, mesh->num_vertexboneweights * sizeof(aliasvertexboneweight_t));
+ mesh->num_vertexboneweights = 0;
+ // note this vertexboneweight ordering requires that the remapvertices array is sequential numbers (separated by -1 values for omitted vertices)
+ l = 0;
+ for (j = 0;j < mesh->num_vertices;j++)
+ {
+ if (remapvertices[j] < 0)
+ {
+ l += vertbonecounts[j];
+ continue;
+ }
+ for (k = 0;k < vertbonecounts[j];k++)
+ {
+ // this format really should have had a per vertexweight weight value...
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].vertexindex = remapvertices[j];
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].boneindex = verts[l].bonenum;
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[3] = 1.0f / vertbonecounts[j];
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[0] = verts[l].origin[0] * mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[3];
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[1] = verts[l].origin[1] * mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[3];
+ mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[2] = verts[l].origin[2] * mesh->data_vertexboneweights[mesh->num_vertexboneweights].origin[3];
+ mesh->num_vertexboneweights++;
+ l++;
+ }
+ }
+
+ Mod_ValidateElements(mesh->data_element3i, mesh->num_triangles, mesh->num_vertices, __FILE__, __LINE__);
+ Mod_BuildTriangleNeighbors(mesh->data_neighbor3i, mesh->data_element3i, mesh->num_triangles);
+ Mod_Alias_Mesh_CompileFrameZero(mesh);
+
+ // since zym models do not have named sections, reuse their shader
+ // name as the section name
+ shadername = (char *) (pheader->lump_shaders.start + pbase) + i * 32;
+ if (shadername[0])
+ Mod_BuildAliasSkinsFromSkinFiles(mesh->data_skins, skinfiles, shadername, shadername);
+ else
+ for (j = 0;j < mesh->num_skins;j++)
+ Mod_BuildAliasSkinFromSkinFrame(mesh->data_skins + j, NULL);
+ }
+
+ Mem_Free(vertbonecounts);
+ Mem_Free(verts);
+ Mem_Free(outtexcoord2f);