Mercurial > MadButterfly
diff src/shape_stext.c @ 437:e73b3644d802
Fix bug of compute extents of sh_stext.
Full extents sh_stext_t::extents should be initialized with extents of
first style block if existed. But, it was not. So, it is fixed, now.
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Thu, 30 Jul 2009 15:42:43 +0800 |
parents | c02d2aa2c45e |
children | 2437047b8bb8 |
line wrap: on
line diff
--- a/src/shape_stext.c Thu Jul 30 12:11:27 2009 +0800 +++ b/src/shape_stext.c Thu Jul 30 15:42:43 2009 +0800 @@ -478,7 +478,7 @@ */ static void extent_extents(mb_text_extents_t *full, mb_text_extents_t *sub) { - co_aix f_rbx, f_rby; /* rb stands for right button */ + co_aix f_rbx, f_rby; /* rb stands for right bottom */ co_aix s_rbx, s_rby; co_aix s_xbr, s_ybr; co_aix new_x_adv, new_y_adv; @@ -541,8 +541,6 @@ char *txt, saved; int i, nscaled; - memset(&txt_o->extents, sizeof(mb_text_extents_t), 0); - scaled_fonts = &txt_o->scaled_fonts; for(i = 0; i < scaled_fonts->num; i++) scaled_font_free(scaled_fonts->ds[i]); @@ -571,11 +569,19 @@ compute_text_extents(scaled, txt, sub); txt[blk_txt_len] = saved; - extent_extents(&txt_o->extents, sub); - blk++; txt += blk_txt_len; - } + } + + if(style_blks->num > 0) { + sub = sub_exts->ds; + memcpy(&txt_o->extents, sub, sizeof(mb_text_extents_t)); + for(i = 1; i < style_blks->num; i++) { + sub = sub_exts->ds + i; + extent_extents(&txt_o->extents, sub); + } + } else + memset(&txt_o->extents, sizeof(mb_text_extents_t), 0); } /*