@ -238,8 +238,8 @@ drw_rect(Drw *drw, int x, int y, unsigned int w, unsigned int h, int filled, int
int
drw_text ( Drw * drw , int x , int y , unsigned int w , unsigned int h , unsigned int lpad , const char * text , int invert )
{
int i , ty , ellipsis_x = 0 ;
unsigned int tmpw , ew , ellipsis_w = 0 , ellipsis_len ;
int ty , ellipsis_x = 0 ;
unsigned int tmpw , ew , ellipsis_w = 0 , ellipsis_len , hash , h0 , h1 ;
XftDraw * d = NULL ;
Fnt * usedfont , * curfont , * nextfont ;
int utf8strlen , utf8charlen , render = x | | y | | w | | h ;
@ -251,9 +251,7 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
XftResult result ;
int charexists = 0 , overflow = 0 ;
/* keep track of a couple codepoints for which we have no match. */
enum { nomatches_len = 64 } ;
static struct { long codepoint [ nomatches_len ] ; unsigned int idx ; } nomatches ;
static unsigned int ellipsis_width = 0 ;
static unsigned int nomatches [ 128 ] , ellipsis_width ;
if ( ! drw | | ( render & & ( ! drw - > scheme | | ! w ) ) | | ! text | | ! drw - > fonts )
return 0 ;
@ -338,11 +336,14 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
* character must be drawn . */
charexists = 1 ;
for ( i = 0 ; i < nomatches_len ; + + i ) {
/* avoid calling XftFontMatch if we know we won't find a match */
if ( utf8codepoint = = nomatches . codepoint [ i ] )
goto no_match ;
}
hash = ( unsigned int ) utf8codepoint ;
hash = ( ( hash > > 16 ) ^ hash ) * 0x21F0AAAD ;
hash = ( ( hash > > 15 ) ^ hash ) * 0xD35A2D97 ;
h0 = ( ( hash > > 15 ) ^ hash ) % LENGTH ( nomatches ) ;
h1 = ( hash > > 17 ) % LENGTH ( nomatches ) ;
/* avoid expensive XftFontMatch call when we know we won't find a match */
if ( nomatches [ h0 ] = = utf8codepoint | | nomatches [ h1 ] = = utf8codepoint )
goto no_match ;
fccharset = FcCharSetCreate ( ) ;
FcCharSetAddChar ( fccharset , utf8codepoint ) ;
@ -371,7 +372,7 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp
curfont - > next = usedfont ;
} else {
xfont_free ( usedfont ) ;
nomatches . codepoint [ + + nomatches . idx % nomatches_len ] = utf8codepoint ;
nomatches [ nomatches [ h0 ] ? h1 : h0 ] = utf8codepoint ;
no_match :
usedfont = drw - > fonts ;
}