@ -1919,7 +1919,7 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					         float  dx  =  e - > fdx ;           float  dx  =  e - > fdx ;   
			
		
	
		
		
			
				
					
					         float  xb  =  x0  +  dx ;           float  xb  =  x0  +  dx ;   
			
		
	
		
		
			
				
					
					         float  x_top ,  x_bottom ;           float  x_top ,  x_bottom ;   
			
		
	
		
		
			
				
					
					         float  y0 , y1 ;           float  s y0, s y1;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					         float  dy  =  e - > fdy ;           float  dy  =  e - > fdy ;   
			
		
	
		
		
			
				
					
					         STBTT_assert ( e - > sy  < =  y_bottom  & &  e - > ey  > =  y_top ) ;           STBTT_assert ( e - > sy  < =  y_bottom  & &  e - > ey  > =  y_top ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1928,17 +1928,17 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					         // line with y_top, but that may be off the line segment.
           // line with y_top, but that may be off the line segment.
   
			
		
	
		
		
			
				
					
					         if  ( e - > sy  >  y_top )  {           if  ( e - > sy  >  y_top )  {   
			
		
	
		
		
			
				
					
					            x_top  =  x0  +  dx  *  ( e - > sy  -  y_top ) ;              x_top  =  x0  +  dx  *  ( e - > sy  -  y_top ) ;   
			
		
	
		
		
			
				
					
					            y0  =  e - > sy ;              s y0=  e - > sy ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					         }  else  {           }  else  {   
			
		
	
		
		
			
				
					
					            x_top  =  x0 ;              x_top  =  x0 ;   
			
		
	
		
		
			
				
					
					            y0  =  y_top ;              s y0=  y_top ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					         }           }   
			
		
	
		
		
			
				
					
					         if  ( e - > ey  <  y_bottom )  {           if  ( e - > ey  <  y_bottom )  {   
			
		
	
		
		
			
				
					
					            x_bottom  =  x0  +  dx  *  ( e - > ey  -  y_top ) ;              x_bottom  =  x0  +  dx  *  ( e - > ey  -  y_top ) ;   
			
		
	
		
		
			
				
					
					            y1  =  e - > ey ;              s y1=  e - > ey ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					         }  else  {           }  else  {   
			
		
	
		
		
			
				
					
					            x_bottom  =  xb ;              x_bottom  =  xb ;   
			
		
	
		
		
			
				
					
					            y1  =  y_bottom ;              s y1=  y_bottom ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					         }           }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					         if  ( x_top  > =  0  & &  x_bottom  > =  0  & &  x_top  <  len  & &  x_bottom  <  len )  {           if  ( x_top  > =  0  & &  x_bottom  > =  0  & &  x_top  <  len  & &  x_bottom  <  len )  {   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1948,7 +1948,7 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					               float  height ;                 float  height ;   
			
		
	
		
		
			
				
					
					               // simple case, only spans one pixel
                 // simple case, only spans one pixel
   
			
		
	
		
		
			
				
					
					               int  x  =  ( int )  x_top ;                 int  x  =  ( int )  x_top ;   
			
		
	
		
		
			
				
					
					               height  =  y1  -  y0 ;                 height  =  s y1-  s y0;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					               STBTT_assert ( x  > =  0  & &  x  <  len ) ;                 STBTT_assert ( x  > =  0  & &  x  <  len ) ;   
			
		
	
		
		
			
				
					
					               scanline [ x ]  + =  e - > direction  *  ( 1 - ( ( x_top  -  x )  +  ( x_bottom - x ) ) / 2 )   *  height ;                 scanline [ x ]  + =  e - > direction  *  ( 1 - ( ( x_top  -  x )  +  ( x_bottom - x ) ) / 2 )   *  height ;   
			
		
	
		
		
			
				
					
					               scanline_fill [ x ]  + =  e - > direction  *  height ;  // everything right of this pixel is filled
                 scanline_fill [ x ]  + =  e - > direction  *  height ;  // everything right of this pixel is filled
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1959,9 +1959,9 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					               if  ( x_top  >  x_bottom )  {                 if  ( x_top  >  x_bottom )  {   
			
		
	
		
		
			
				
					
					                  // flip scanline vertically; signed area is the same
                    // flip scanline vertically; signed area is the same
   
			
		
	
		
		
			
				
					
					                  float  t ;                    float  t ;   
			
		
	
		
		
			
				
					
					                  y0  =  y_bottom  -  ( y0  -  y_top ) ;                    s y0=  y_bottom  -  ( s y0-  y_top ) ;   
			
				
				
			
		
	
		
		
			
				
					
					                  y1  =  y_bottom  -  ( y1  -  y_top ) ;                    s y1=  y_bottom  -  ( s y1-  y_top ) ;   
			
				
				
			
		
	
		
		
			
				
					
					                  t  =  y0 ,  y0  =  y1 ,  y1  =  t ;                    t  =  s y0,  s y0=  s y1,  s y1=  t ;   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					                  t  =  x_bottom ,  x_bottom  =  x_top ,  x_top  =  t ;                    t  =  x_bottom ,  x_bottom  =  x_top ,  x_top  =  t ;   
			
		
	
		
		
			
				
					
					                  dx  =  - dx ;                    dx  =  - dx ;   
			
		
	
		
		
			
				
					
					                  dy  =  - dy ;                    dy  =  - dy ;   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1975,7 +1975,7 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					               sign  =  e - > direction ;                 sign  =  e - > direction ;   
			
		
	
		
		
			
				
					
					               // area of the rectangle covered from y0..y_crossing
                 // area of the rectangle covered from y0..y_crossing
   
			
		
	
		
		
			
				
					
					               area  =  sign  *  ( y_crossing - y0 ) ;                 area  =  sign  *  ( y_crossing - s y0) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					               // area of the triangle (x_top,y0), (x+1,y0), (x+1,y_crossing)
                 // area of the triangle (x_top,y0), (x+1,y0), (x+1,y_crossing)
   
			
		
	
		
		
			
				
					
					               scanline [ x1 ]  + =  area  *  ( 1 - ( ( x_top  -  x1 ) + ( x1 + 1 - x1 ) ) / 2 ) ;                 scanline [ x1 ]  + =  area  *  ( 1 - ( ( x_top  -  x1 ) + ( x1 + 1 - x1 ) ) / 2 ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1988,9 +1988,9 @@ static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					               STBTT_assert ( fabs ( area )  < =  1.01f ) ;                 STBTT_assert ( fabs ( area )  < =  1.01f ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					               scanline [ x2 ]  + =  area  +  sign  *  ( 1 - ( ( x2 - x2 ) + ( x_bottom - x2 ) ) / 2 )  *  ( y1 - y_crossing ) ;                 scanline [ x2 ]  + =  area  +  sign  *  ( 1 - ( ( x2 - x2 ) + ( x_bottom - x2 ) ) / 2 )  *  ( s y1- y_crossing ) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					               scanline_fill [ x2 ]  + =  sign  *  ( y1 - y0 ) ;                 scanline_fill [ x2 ]  + =  sign  *  ( s y1- s y0) ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					            }              }   
			
		
	
		
		
			
				
					
					         }  else  {           }  else  {   
			
		
	
		
		
			
				
					
					            // if edge goes outside of box we're drawing, we require
              // if edge goes outside of box we're drawing, we require