2011-02-23 10:52:22 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/*
  
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 *  * * * * *  BEGIN  GPL  LICENSE  BLOCK  * * * * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  This  program  is  free  software ;  you  can  redistribute  it  and / or 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  modify  it  under  the  terms  of  the  GNU  General  Public  License 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  as  published  by  the  Free  Software  Foundation ;  either  version  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  of  the  License ,  or  ( at  your  option )  any  later  version . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  This  program  is  distributed  in  the  hope  that  it  will  be  useful , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  but  WITHOUT  ANY  WARRANTY ;  without  even  the  implied  warranty  of 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  MERCHANTABILITY  or  FITNESS  FOR  A  PARTICULAR  PURPOSE .   See  the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  GNU  General  Public  License  for  more  details . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  You  should  have  received  a  copy  of  the  GNU  General  Public  License 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  along  with  this  program ;  if  not ,  write  to  the  Free  Software  Foundation , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Inc . ,  51  Franklin  Street ,  Fifth  Floor ,  Boston ,  MA  02110 - 1301 ,  USA . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  The  Original  Code  is  Copyright  ( C )  2011  Blender  Foundation . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  All  rights  reserved . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  * * * * *  END  GPL  LICENSE  BLOCK  * * * * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-27 20:40:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/** \file blender/blenkernel/intern/mesh_validate.c
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *   \ ingroup  bke 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  <stdio.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <stdlib.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <string.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <limits.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "DNA_mesh_types.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "DNA_meshdata_types.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "BLO_sys_types.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  "BLI_utildefines.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  "BLI_edgehash.h" 
  
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "BLI_math_base.h" 
  
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 02:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "BKE_DerivedMesh.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  "MEM_guardedalloc.h" 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "BKE_mesh.h" 
  
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  "BKE_deform.h" 
  
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# define SELECT 1 
  
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								typedef  union  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									uint32_t  verts [ 2 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int64_t  edval ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  EdgeUUID ;  
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								typedef  struct  SortFace  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//	unsigned int	v[4];
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									EdgeUUID 		es [ 4 ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									unsigned  int 	index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  SortFace ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  edge_store_assign ( uint32_t  verts [ 2 ] ,   const  uint32_t  v1 ,  const  uint32_t  v2 )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if ( v1  <  v2 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										verts [ 0 ] =  v1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										verts [ 1 ] =  v2 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										verts [ 0 ] =  v2 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										verts [ 1 ] =  v1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  edge_store_from_mface_quad ( EdgeUUID  es [ 4 ] ,  MFace  * mf )  
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 0 ] . verts ,  mf - > v1 ,  mf - > v2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 1 ] . verts ,  mf - > v2 ,  mf - > v3 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 2 ] . verts ,  mf - > v3 ,  mf - > v4 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									edge_store_assign ( es [ 3 ] . verts ,  mf - > v4 ,  mf - > v1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  edge_store_from_mface_tri ( EdgeUUID  es [ 4 ] ,  MFace  * mf )  
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 0 ] . verts ,  mf - > v1 ,  mf - > v2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 1 ] . verts ,  mf - > v2 ,  mf - > v3 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									edge_store_assign ( es [ 2 ] . verts ,  mf - > v3 ,  mf - > v1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									es [ 3 ] . verts [ 0 ]  =  es [ 3 ] . verts [ 1 ]  =  UINT_MAX ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  int  int64_cmp ( const  void  * v1 ,  const  void  * v2 )  
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									const  int64_t  x1 =  * ( const  int64_t  * ) v1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									const  int64_t  x2 =  * ( const  int64_t  * ) v2 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if (  x1  >  x2  )  return  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if (  x1  <  x2  )  return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  int  search_face_cmp ( const  void  * v1 ,  const  void  * v2 )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									const  SortFace  * sfa =  v1 ,  * sfb =  v2 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if 	( sfa - > es [ 0 ] . edval  >  sfb - > es [ 0 ] . edval )  return  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 0 ] . edval  <  sfb - > es [ 0 ] . edval )  return  - 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 1 ] . edval  >  sfb - > es [ 1 ] . edval )  return  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 1 ] . edval  <  sfb - > es [ 1 ] . edval )  return  - 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 2 ] . edval  >  sfb - > es [ 2 ] . edval )  return  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 2 ] . edval  <  sfb - > es [ 2 ] . edval )  return  - 1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 3 ] . edval  >  sfb - > es [ 3 ] . edval )  return  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  if 	( sfa - > es [ 3 ] . edval  <  sfb - > es [ 3 ] . edval )  return  - 1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else 										  return  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# define PRINT if(do_verbose) printf 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								int  BKE_mesh_validate_arrays (  Mesh  * me ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              MVert  * mverts ,  unsigned  int  totvert , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              MEdge  * medges ,  unsigned  int  totedge , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              MFace  * mfaces ,  unsigned  int  totface , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              MDeformVert  * dverts ,  /* assume totvert length */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                              const  short  do_verbose ,  const  short  do_fixes ) 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# 	define REMOVE_EDGE_TAG(_med) { _med->v2= _med->v1; do_edge_free= 1; } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# 	define REMOVE_FACE_TAG(_mf) { _mf->v3=0; do_face_free= 1; } 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								//	MVert *mv;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									MEdge  * med ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									MFace  * mf ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									MFace  * mf_prev ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									MVert  * mvert =  mverts ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-27 08:31:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									unsigned  int  i ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									short  do_face_free =  FALSE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									short  do_edge_free =  FALSE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									short  verts_fixed =  FALSE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									short  vert_weights_fixed =  FALSE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  do_edge_recalc =  FALSE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									EdgeHash  * edge_hash  =  BLI_edgehash_new ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									SortFace  * sort_faces =  MEM_callocN ( sizeof ( SortFace )  *  totface ,  " search faces " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SortFace  * sf ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									SortFace  * sf_prev ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-27 08:31:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									unsigned  int  totsortface =  0 ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									BLI_assert ( ! ( do_fixes  & &  me  = =  NULL ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-09-14 00:37:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PRINT ( " %s: verts(%u), edges(%u), faces(%u) \n " ,  __func__ ,  totvert ,  totedge ,  totface ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if ( totedge  = =  0  & &  totface  ! =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										PRINT ( "     locical error, %u faces and 0 edges \n " ,  totface ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										do_edge_recalc =  TRUE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for ( i = 1 ;  i < totvert ;  i + + ,  mvert + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										int  j ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										int  fix_normal =  TRUE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for ( j = 0 ;  j < 3 ;  j + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if ( ! finite ( mvert - > co [ j ] ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												PRINT ( "     vertex %u: has invalid coordinate \n " ,  i ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													zero_v3 ( mvert - > co ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													verts_fixed =  TRUE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if ( mvert - > no [ j ] ! = 0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												fix_normal =  FALSE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( fix_normal )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PRINT ( "     vertex %u: has zero normal, assuming Z-up normal \n " ,  i ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if  ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												mvert - > no [ 2 ] =  SHRT_MAX ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												verts_fixed =  TRUE ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-01 19:21:58 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for ( i = 0 ,  med =  medges ;  i < totedge ;  i + + ,  med + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										int  remove =  FALSE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										if ( med - > v1  = =  med - > v2 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											PRINT ( "     edge %u: has matching verts, both %u \n " ,  i ,  med - > v1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( med - > v1  > =  totvert )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											PRINT ( "     edge %u: v1 index out of range, %u \n " ,  i ,  med - > v1 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( med - > v2  > =  totvert )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											PRINT ( "     edge %u: v2 index out of range, %u \n " ,  i ,  med - > v2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( BLI_edgehash_haskey ( edge_hash ,  med - > v1 ,  med - > v2 ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-03 15:36:36 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											PRINT ( "     edge %u: is a duplicate of, %d \n " ,  i ,  GET_INT_FROM_POINTER ( BLI_edgehash_lookup ( edge_hash ,  med - > v1 ,  med - > v2 ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2012-02-23 02:17:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( remove  = =  FALSE )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											BLI_edgehash_insert ( edge_hash ,  med - > v1 ,  med - > v2 ,  SET_INT_IN_POINTER ( i ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											REMOVE_EDGE_TAG ( med ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for ( i = 0 ,  mf = mfaces ,  sf = sort_faces ;  i < totface ;  i + + ,  mf + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										int  remove =  FALSE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										int  fidx ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										unsigned  int  fv [ 4 ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fidx  =  mf - > v4  ?  3 : 2 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										do  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											fv [ fidx ] =  * ( & ( mf - > v1 )  +  fidx ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if ( fv [ fidx ]  > =  totvert )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												PRINT ( "     face %u: 'v%d' index out of range, %u \n " ,  i ,  fidx  +  1 ,  fv [ fidx ] ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  while  ( fidx - - ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( remove  = =  FALSE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if ( mf - > v4 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v1  = =  mf - > v2 )  {  PRINT ( "     face %u: verts invalid, v1/v2 both %u \n " ,  i ,  mf - > v1 ) ;  remove =  do_fixes ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( mf - > v1  = =  mf - > v3 )  {  PRINT ( "     face %u: verts invalid, v1/v3 both %u \n " ,  i ,  mf - > v1 ) ;  remove =  do_fixes ;   } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( mf - > v1  = =  mf - > v4 )  {  PRINT ( "     face %u: verts invalid, v1/v4 both %u \n " ,  i ,  mf - > v1 ) ;  remove =  do_fixes ;   } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v2  = =  mf - > v3 )  {  PRINT ( "     face %u: verts invalid, v2/v3 both %u \n " ,  i ,  mf - > v2 ) ;  remove =  do_fixes ;   } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( mf - > v2  = =  mf - > v4 )  {  PRINT ( "     face %u: verts invalid, v2/v4 both %u \n " ,  i ,  mf - > v2 ) ;  remove =  do_fixes ;   } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v3  = =  mf - > v4 )  {  PRINT ( "     face %u: verts invalid, v3/v4 both %u \n " ,  i ,  mf - > v3 ) ;  remove =  do_fixes ;   } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											else  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v1  = =  mf - > v2 )  {  PRINT ( "     faceT %u: verts invalid, v1/v2 both %u \n " ,  i ,  mf - > v1 ) ;  remove =  do_fixes ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( mf - > v1  = =  mf - > v3 )  {  PRINT ( "     faceT %u: verts invalid, v1/v3 both %u \n " ,  i ,  mf - > v1 ) ;  remove =  do_fixes ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v2  = =  mf - > v3 )  {  PRINT ( "     faceT %u: verts invalid, v2/v3 both %u \n " ,  i ,  mf - > v2 ) ;  remove =  do_fixes ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if ( remove  = =  FALSE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( totedge )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if ( mf - > v4 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v1 ,  mf - > v2 ) )  {  PRINT ( "     face %u: edge v1/v2 (%u,%u) is missing egde data \n " ,  i ,  mf - > v1 ,  mf - > v2 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v2 ,  mf - > v3 ) )  {  PRINT ( "     face %u: edge v2/v3 (%u,%u) is missing egde data \n " ,  i ,  mf - > v2 ,  mf - > v3 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v3 ,  mf - > v4 ) )  {  PRINT ( "     face %u: edge v3/v4 (%u,%u) is missing egde data \n " ,  i ,  mf - > v3 ,  mf - > v4 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v4 ,  mf - > v1 ) )  {  PRINT ( "     face %u: edge v4/v1 (%u,%u) is missing egde data \n " ,  i ,  mf - > v4 ,  mf - > v1 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													else  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v1 ,  mf - > v2 ) )  {  PRINT ( "     face %u: edge v1/v2 (%u,%u) is missing egde data \n " ,  i ,  mf - > v1 ,  mf - > v2 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v2 ,  mf - > v3 ) )  {  PRINT ( "     face %u: edge v2/v3 (%u,%u) is missing egde data \n " ,  i ,  mf - > v2 ,  mf - > v3 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if ( ! BLI_edgehash_haskey ( edge_hash ,  mf - > v3 ,  mf - > v1 ) )  {  PRINT ( "     face %u: edge v3/v1 (%u,%u) is missing egde data \n " ,  i ,  mf - > v3 ,  mf - > v1 ) ;  do_edge_recalc =  TRUE ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												sf - > index  =  i ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if ( mf - > v4 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													edge_store_from_mface_quad ( sf - > es ,  mf ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													qsort ( sf - > es ,  4 ,  sizeof ( int64_t ) ,  int64_cmp ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												else  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													edge_store_from_mface_tri ( sf - > es ,  mf ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													qsort ( sf - > es ,  3 ,  sizeof ( int64_t ) ,  int64_cmp ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												totsortface + + ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												sf + + ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( remove )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											REMOVE_FACE_TAG ( mf ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									qsort ( sort_faces ,  totsortface ,  sizeof ( SortFace ) ,  search_face_cmp ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									sf =  sort_faces ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									sf_prev =  sf ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									sf + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									for ( i = 1 ;  i < totsortface ;  i + + ,  sf + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										int  remove =  FALSE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										/* on a valid mesh, code below will never run */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										if ( memcmp ( sf - > es ,  sf_prev - > es ,  sizeof ( sf_prev - > es ) )  = =  0 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 12:34:52 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											mf =  mfaces  +  sf - > index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											if ( do_verbose )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												mf_prev =  mfaces  +  sf_prev - > index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if ( mf - > v4 )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													PRINT ( "     face %u & %u: are duplicates (%u,%u,%u,%u) (%u,%u,%u,%u) \n " ,  sf - > index ,  sf_prev - > index ,  mf - > v1 ,  mf - > v2 ,  mf - > v3 ,  mf - > v4 ,  mf_prev - > v1 ,  mf_prev - > v2 ,  mf_prev - > v3 ,  mf_prev - > v4 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												else  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-08-27 03:25:02 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													PRINT ( "     face %u & %u: are duplicates (%u,%u,%u) (%u,%u,%u) \n " ,  sf - > index ,  sf_prev - > index ,  mf - > v1 ,  mf - > v2 ,  mf - > v3 ,  mf_prev - > v1 ,  mf_prev - > v2 ,  mf_prev - > v3 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											remove =  do_fixes ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											sf_prev =  sf ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 14:13:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( remove )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											REMOVE_FACE_TAG ( mf ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									BLI_edgehash_free ( edge_hash ,  NULL ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 04:48:49 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									MEM_freeN ( sort_faces ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* fix deform verts */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  ( dverts )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										MDeformVert  * dv ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for ( i = 0 ,  dv =  dverts ;  i < totvert ;  i + + ,  dv + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 20:29:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											MDeformWeight  * dw ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											unsigned  int  j ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for ( j = 0 ,  dw =  dv - > dw ;  j  <  dv - > totweight ;  j + + ,  dw + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												/* note, greater then max defgroups is accounted for in our code, but not < 0 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ! finite ( dw - > weight ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													PRINT ( "     vertex deform %u, group %d has weight: %f \n " ,  i ,  dw - > def_nr ,  dw - > weight ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														dw - > weight =  0.0f ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														vert_weights_fixed =  TRUE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 20:29:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												else  if  ( dw - > weight  <  0.0f  | |  dw - > weight  >  1.0f )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													PRINT ( "     vertex deform %u, group %d has weight: %f \n " ,  i ,  dw - > def_nr ,  dw - > weight ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														CLAMP ( dw - > weight ,  0.0f ,  1.0f ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														vert_weights_fixed =  TRUE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( dw - > def_nr  <  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													PRINT ( "     vertex deform %u, has invalid group %d \n " ,  i ,  dw - > def_nr ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													if  ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														defvert_remove_group ( dv ,  dw ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														if  ( dv - > dw )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															/* re-allocated, the new values compensate for stepping
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															 *  within  the  for  loop  and  may  not  be  valid  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															j - - ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															dw =  dv - > dw  +  j ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															vert_weights_fixed =  TRUE ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														else  {  /* all freed */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
															break ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
														} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									PRINT ( " BKE_mesh_validate: finished \n \n " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# 	 undef REMOVE_EDGE_TAG 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# 	 undef REMOVE_FACE_TAG 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if ( me )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( do_face_free )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											mesh_strip_loose_faces ( me ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if  ( do_edge_free )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											mesh_strip_loose_edges ( me ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( do_fixes  & &  do_edge_recalc )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											BKE_mesh_calc_edges ( me ,  TRUE ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-09 07:23:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  ( verts_fixed  | |  vert_weights_fixed  | |  do_face_free  | |  do_edge_free  | |  do_edge_recalc ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  int  mesh_validate_customdata ( CustomData  * data ,  short  do_verbose ,  const  short  do_fixes )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  i =  0 ,  has_fixes =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									while ( i < data - > totlayer )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										CustomDataLayer  * layer =  & data - > layers [ i ] ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-23 20:30:23 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										CustomDataMask  mask =  CD_TYPE_AS_MASK ( layer - > type ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										int  ok =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( ( mask & CD_MASK_MESH ) = = 0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											PRINT ( " CustomDataLayer type %d which isn't in CD_MASK_MESH is stored in Mehs structure \n " ,  layer - > type ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if ( do_fixes )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												CustomData_free_layer ( data ,  layer - > type ,  0 ,  i ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												ok =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												has_fixes =  1 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( ok ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											i + + ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  has_fixes ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# undef PRINT 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  int  BKE_mesh_validate_all_customdata ( CustomData  * vdata ,  CustomData  * edata ,  CustomData  * fdata ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                            short  do_verbose ,  const  short  do_fixes ) 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  vfixed =  0 ,  efixed =  0 ,  ffixed =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									vfixed =  mesh_validate_customdata ( vdata ,  do_verbose ,  do_fixes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									efixed =  mesh_validate_customdata ( edata ,  do_verbose ,  do_fixes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ffixed =  mesh_validate_customdata ( fdata ,  do_verbose ,  do_fixes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  vfixed  | |  efixed  | |  ffixed ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								int  BKE_mesh_validate ( Mesh  * me ,  int  do_verbose )  
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									int  layers_fixed =  0 ,  arrays_fixed =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-04-25 06:44:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if ( do_verbose )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										printf ( " MESH: %s \n " ,  me - > id . name + 2 ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									layers_fixed =  BKE_mesh_validate_all_customdata ( & me - > vdata ,  & me - > edata ,  & me - > fdata ,  do_verbose ,  TRUE ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									arrays_fixed =  BKE_mesh_validate_arrays ( me , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									                                       me - > mvert ,  me - > totvert , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									                                       me - > medge ,  me - > totedge , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									                                       me - > mface ,  me - > totface , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									                                       me - > dvert , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									                                       do_verbose ,  TRUE ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-23 17:52:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									return  layers_fixed  | |  arrays_fixed ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 02:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-10 09:29:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								int  BKE_mesh_validate_dm ( DerivedMesh  * dm )  
						 
					
						
							
								
									
										
										
										
											2011-02-09 02:28:11 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2011-12-08 04:51:03 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									return  BKE_mesh_validate_arrays ( NULL , 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-08 17:32:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    dm - > getVertArray ( dm ) ,  dm - > getNumVerts ( dm ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    dm - > getEdgeArray ( dm ) ,  dm - > getNumEdges ( dm ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    dm - > getTessFaceArray ( dm ) ,  dm - > getNumTessFaces ( dm ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    dm - > getVertDataArray ( dm ,  CD_MDEFORMVERT ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    TRUE ,  FALSE ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								void  BKE_mesh_calc_edges ( Mesh  * mesh ,  int  update )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									CustomData  edata ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									EdgeHashIterator  * ehi ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									MFace  * mf  =  mesh - > mface ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									MEdge  * med ,  * med_orig ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									EdgeHash  * eh  =  BLI_edgehash_new ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									int  i ,  totedge ,  totface  =  mesh - > totface ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-09 16:59:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									int  med_index ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if ( mesh - > totedge = = 0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										update =  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if ( update )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* assume existing edges are valid
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										 *  useful  when  adding  more  faces  and  generating  edges  from  them  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										med =  mesh - > medge ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for ( i =  0 ;  i < mesh - > totedge ;  i + + ,  med + + ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											BLI_edgehash_insert ( eh ,  med - > v1 ,  med - > v2 ,  med ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 08:27:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if ( mesh - > totpoly )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* mesh loops (bmesh only) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										MPoly  * mp =  mesh - > mpoly ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for ( i = 0 ;  i  <  mesh - > totpoly ;  i + + ,  mp + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											MLoop  * l =  & mesh - > mloop [ mp - > loopstart ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											int  j ,  l_prev =  ( l  +  ( mp - > totloop - 1 ) ) - > v ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for  ( j = 0 ;  j  <  mp - > totloop ;  j + + ,  l + + )  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-09 16:59:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												if  ( ! BLI_edgehash_haskey ( eh ,  l_prev ,  l - > v ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													BLI_edgehash_insert ( eh ,  l_prev ,  l - > v ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												} 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 08:27:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												l_prev =  l - > v ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* regular faces (note, we could remove this for bmesh - campbell) */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  ( i  =  0 ;  i  <  totface ;  i + + ,  mf + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ! BLI_edgehash_haskey ( eh ,  mf - > v1 ,  mf - > v2 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												BLI_edgehash_insert ( eh ,  mf - > v1 ,  mf - > v2 ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( ! BLI_edgehash_haskey ( eh ,  mf - > v2 ,  mf - > v3 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												BLI_edgehash_insert ( eh ,  mf - > v2 ,  mf - > v3 ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  ( mf - > v4 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ! BLI_edgehash_haskey ( eh ,  mf - > v3 ,  mf - > v4 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													BLI_edgehash_insert ( eh ,  mf - > v3 ,  mf - > v4 ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ! BLI_edgehash_haskey ( eh ,  mf - > v4 ,  mf - > v1 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													BLI_edgehash_insert ( eh ,  mf - > v4 ,  mf - > v1 ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											}  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												if  ( ! BLI_edgehash_haskey ( eh ,  mf - > v3 ,  mf - > v1 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
													BLI_edgehash_insert ( eh ,  mf - > v3 ,  mf - > v1 ,  NULL ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									totedge  =  BLI_edgehash_size ( eh ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									/* write new edges into a temporary CustomData */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									memset ( & edata ,  0 ,  sizeof ( edata ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									CustomData_add_layer ( & edata ,  CD_MEDGE ,  CD_CALLOC ,  NULL ,  totedge ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ehi  =  BLI_edgehashIterator_new ( eh ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									med  =  CustomData_get_layer ( & edata ,  CD_MEDGE ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for ( i  =  0 ;  ! BLI_edgehashIterator_isDone ( ehi ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										BLI_edgehashIterator_step ( ehi ) ,  + + i ,  + + med )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										if ( update  & &  ( med_orig = BLI_edgehashIterator_getValue ( ehi ) ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											* med =  * med_orig ;  /* copy from the original */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										}  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-28 10:06:10 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											BLI_edgehashIterator_getKey ( ehi ,  & med - > v1 ,  & med - > v2 ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											med - > flag  =  ME_EDGEDRAW | ME_EDGERENDER | SELECT ;  /* select for newly created meshes which are selected [#25595] */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-09 16:59:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* store the new edge index in the hash value */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										BLI_edgehashIterator_setValue ( ehi ,  SET_INT_IN_POINTER ( i ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									BLI_edgehashIterator_free ( ehi ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-10-09 16:59:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									if  ( mesh - > totpoly )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										/* second pass, iterate through all loops again and assign
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										   the  newly  created  edges  to  them .  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										MPoly  * mp =  mesh - > mpoly ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for ( i = 0 ;  i  <  mesh - > totpoly ;  i + + ,  mp + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											MLoop  * l =  & mesh - > mloop [ mp - > loopstart ] ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											MLoop  * l_prev =  ( l  +  ( mp - > totloop - 1 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											int  j ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											for  ( j = 0 ;  j  <  mp - > totloop ;  j + + ,  l + + )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												/* lookup hashed edge index */ 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-10 14:56:09 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												med_index  =  GET_INT_FROM_POINTER ( BLI_edgehash_lookup ( eh ,  l_prev - > v ,  l - > v ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-10-09 16:59:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												l_prev - > e  =  med_index ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												l_prev =  l ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 15:13:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									/* free old CustomData and assign new one */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									CustomData_free ( & mesh - > edata ,  mesh - > totedge ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mesh - > edata  =  edata ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mesh - > totedge  =  totedge ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									mesh - > medge  =  CustomData_get_layer ( & mesh - > edata ,  CD_MEDGE ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									BLI_edgehash_free ( eh ,  NULL ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2011-02-09 01:27:46 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}