Fix combining characters messing with width counter

This commit is contained in:
Vladimir 'phcoder' Serbinenko 2010-03-16 19:55:09 +01:00
parent bf17ef45d6
commit 50186d826d
5 changed files with 17 additions and 10 deletions

View file

@ -84,6 +84,9 @@ struct grub_unicode_glyph
grub_uint32_t code; grub_uint32_t code;
enum grub_comb_type type; enum grub_comb_type type;
} *combining; } *combining;
/* Hint by unicode subsystem how wide this character usually is.
Real width is determined by font. Set only in UTF-8 stream. */
int estimated_width;
}; };
#define GRUB_UNICODE_GLYPH_ATTRIBUTE_MIRROR 0x1 #define GRUB_UNICODE_GLYPH_ATTRIBUTE_MIRROR 0x1
@ -134,15 +137,11 @@ static inline struct grub_unicode_glyph *
grub_unicode_glyph_from_code (grub_uint32_t code) grub_unicode_glyph_from_code (grub_uint32_t code)
{ {
struct grub_unicode_glyph *ret; struct grub_unicode_glyph *ret;
ret = grub_malloc (sizeof (*ret)); ret = grub_zalloc (sizeof (*ret));
if (!ret) if (!ret)
return NULL; return NULL;
ret->base = code; ret->base = code;
ret->variant = 0;
ret->attributes = 0;
ret->ncomb = 0;
ret->combining = 0;
return ret; return ret;
} }

View file

@ -41,7 +41,8 @@ grub_putcode_dumb (grub_uint32_t code,
.variant = 0, .variant = 0,
.attributes = 0, .attributes = 0,
.ncomb = 0, .ncomb = 0,
.combining = 0 .combining = 0,
.estimated_width = 1
}; };
if (code == '\t' && term->getxy) if (code == '\t' && term->getxy)

View file

@ -538,6 +538,7 @@ grub_unicode_aglomerate_comb (const grub_uint32_t *in, grub_size_t inlen,
out->variant = 0; out->variant = 0;
out->attributes = 0; out->attributes = 0;
out->ncomb = 0; out->ncomb = 0;
out->estimated_width = 1;
out->combining = NULL; out->combining = NULL;
} }
return ptr - in; return ptr - in;
@ -1075,7 +1076,8 @@ putglyph (const struct grub_unicode_glyph *c, struct grub_term_output *term)
.variant = 0, .variant = 0,
.attributes = 0, .attributes = 0,
.ncomb = 0, .ncomb = 0,
.combining = 0 .combining = 0,
.estimated_width = 1
}; };
if (c->base == '\t' && term->getxy) if (c->base == '\t' && term->getxy)
@ -1096,6 +1098,7 @@ putglyph (const struct grub_unicode_glyph *c, struct grub_term_output *term)
== GRUB_TERM_CODE_TYPE_UTF8_VISUAL) == GRUB_TERM_CODE_TYPE_UTF8_VISUAL)
{ {
int i; int i;
c2.estimated_width = 1;
for (i = -1; i < (int) c->ncomb; i++) for (i = -1; i < (int) c->ncomb; i++)
{ {
grub_uint8_t u8[20], *ptr; grub_uint8_t u8[20], *ptr;
@ -1112,8 +1115,10 @@ putglyph (const struct grub_unicode_glyph *c, struct grub_term_output *term)
{ {
c2.base = *ptr; c2.base = *ptr;
(term->putchar) (&c2); (term->putchar) (&c2);
c2.estimated_width = 0;
} }
} }
c2.estimated_width = 1;
} }
else else
(term->putchar) (c); (term->putchar) (c);
@ -1133,7 +1138,8 @@ putcode_real (grub_uint32_t code, struct grub_term_output *term)
.variant = 0, .variant = 0,
.attributes = 0, .attributes = 0,
.ncomb = 0, .ncomb = 0,
.combining = 0 .combining = 0,
.estimated_width = 1
}; };
c.base = map_code (code, term); c.base = map_code (code, term);

View file

@ -273,7 +273,8 @@ print_entry (int y, int highlight, grub_menu_entry_t entry,
.variant = 0, .variant = 0,
.attributes = 0, .attributes = 0,
.ncomb = 0, .ncomb = 0,
.combining = 0 .combining = 0,
.estimated_width = 1
}; };
x += grub_term_getcharwidth (term, &pseudo_glyph); x += grub_term_getcharwidth (term, &pseudo_glyph);
} }

View file

@ -356,7 +356,7 @@ grub_serial_putchar (const struct grub_unicode_glyph *c)
serial_hw_put ('\r'); serial_hw_put ('\r');
serial_hw_put ('\n'); serial_hw_put ('\n');
} }
xpos++; xpos += c->estimated_width;
break; break;
} }
} }