- vg_line(tri[0],tri[1],0xff00ff00 );
- vg_line(tri[1],tri[2],0xff00ff00 );
- vg_line(tri[2],tri[0],0xff00ff00 );
+
+ /* build edges brute force */
+ int edge_picture[ 128*3 ][4];
+ int unique_edges = 0;
+
+ for( int i=0; i<len; i++ )
+ {
+ struct face_info *inf = &faces[i];
+
+ for( int j=0; j<3; j++ )
+ {
+ int i0 = j,
+ i1 = (j+1)%3,
+ e0 = VG_MIN( inf->unique_cos[i0], inf->unique_cos[i1] ),
+ e1 = VG_MAX( inf->unique_cos[i0], inf->unique_cos[i1] ),
+ matched = 0;
+
+ for( int k=0; k<unique_edges; k ++ )
+ {
+ int k0 = VG_MIN( edge_picture[k][0], edge_picture[k][1] ),
+ k1 = VG_MAX( edge_picture[k][0], edge_picture[k][1] );
+
+ /* matched ! */
+ if( (k0 == e0) && (k1 == e1) )
+ {
+ edge_picture[ k ][3] = i;
+ matched = 1;
+ break;
+ }
+ }
+
+ if( !matched )
+ {
+ /* create new edge */
+ edge_picture[ unique_edges ][0] = inf->unique_cos[i0];
+ edge_picture[ unique_edges ][1] = inf->unique_cos[i1];
+
+ edge_picture[ unique_edges ][2] = i;
+ edge_picture[ unique_edges ][3] = -1;
+
+ unique_edges ++;
+ }
+ }
+ }
+#endif
+
+ v3f tri[3];
+
+ for( int i=0; i<len; i++ )
+ {
+#ifdef RIGIDBODY_DYNAMIC_MESH_EDGES
+ struct face_info *inf = &faces[i];
+
+ float *v0 = co_picture[inf->unique_cos[0]],
+ *v1 = co_picture[inf->unique_cos[1]],
+ *v2 = co_picture[inf->unique_cos[2]];
+
+ v3_copy( v0, tri[0] );
+ v3_copy( v1, tri[1] );
+ v3_copy( v2, tri[2] );
+
+ buf[count].element_id = inf->element_id;
+#else
+ u32 *ptri = &sc->arrindices[ geo[i]*3 ];
+
+ for( int j=0; j<3; j++ )
+ v3_copy( sc->arrvertices[ptri[j]].co, tri[j] );