Fix combining characters messing with width counter
This commit is contained in:
parent
bf17ef45d6
commit
50186d826d
5 changed files with 17 additions and 10 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue