Fix linewrapper when levels=NULL

This commit is contained in:
Vladimir 'phcoder' Serbinenko 2010-03-16 11:31:05 +01:00
parent eb67952309
commit cacd173d3e

View file

@ -553,25 +553,24 @@ line_wrap (struct grub_unicode_glyph *visual_out,
struct grub_unicode_glyph *outptr = visual_out; struct grub_unicode_glyph *outptr = visual_out;
unsigned line_start = 0; unsigned line_start = 0;
grub_ssize_t line_width = startwidth; grub_ssize_t line_width = startwidth;
unsigned k;
auto void revert (unsigned start, unsigned end); auto void revert (unsigned start, unsigned end);
void revert (unsigned start, unsigned end) void revert (unsigned start, unsigned end)
{ {
struct grub_unicode_glyph t; struct grub_unicode_glyph t;
unsigned k, tl; unsigned i, tl;
for (k = 0; k <= (end - start) / 2; k++) for (i = 0; i <= (end - start) / 2; i++)
{ {
t = visual[start + k]; t = visual[start + i];
visual[start + k] = visual[end - k]; visual[start + i] = visual[end - i];
visual[end - k] = t; visual[end - i] = t;
tl = levels[start + k]; tl = levels[start + i];
levels[start + k] = levels[end - k]; levels[start + i] = levels[end - i];
levels[end - k] = tl; levels[end - i] = tl;
} }
} }
unsigned k;
if (!visual_len) if (!visual_len)
return 0; return 0;
@ -582,20 +581,22 @@ line_wrap (struct grub_unicode_glyph *visual_out,
line_width += last_width = getcharwidth (&visual[k]); line_width += last_width = getcharwidth (&visual[k]);
if (((grub_ssize_t) maxwidth > 0 if (((grub_ssize_t) maxwidth > 0
&& line_width > (grub_ssize_t) maxwidth) || k == visual_len) && line_width > (grub_ssize_t) maxwidth) || k == visual_len)
{ {
unsigned min_odd_level = 0xffffffff;
unsigned max_level = 0;
unsigned i, j;
for (i = line_start; i < k; i++)
{
if (levels[i] > max_level)
max_level = levels[i];
if (levels[i] < min_odd_level && (levels[i] & 1))
min_odd_level = levels[i];
}
if (levels) if (levels)
{ {
unsigned min_odd_level = 0xffffffff;
unsigned max_level = 0;
unsigned j;
unsigned i;
for (i = line_start; i < k; i++)
{
if (levels[i] > max_level)
max_level = levels[i];
if (levels[i] < min_odd_level && (levels[i] & 1))
min_odd_level = levels[i];
}
/* FIXME: can be optimized. */ /* FIXME: can be optimized. */
for (j = max_level; j >= min_odd_level; j--) for (j = max_level; j >= min_odd_level; j--)
{ {