* grub-core/normal/charset.c (bidi_line_wrap): Eliminate nested

functions.
	(grub_bidi_line_logical_to_visual): Likewise.
This commit is contained in:
Vladimir Serbinenko 2013-11-07 02:31:31 +01:00
parent ec0ebb3fc2
commit c03995d297
2 changed files with 61 additions and 52 deletions

View file

@ -1,3 +1,9 @@
2013-11-07 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/normal/charset.c (bidi_line_wrap): Eliminate nested
functions.
(grub_bidi_line_logical_to_visual): Likewise.
2013-11-07 Vladimir Serbinenko <phcoder@gmail.com> 2013-11-07 Vladimir Serbinenko <phcoder@gmail.com>
Remove vestiges of -Wunsafe-loop-optimisations. Remove vestiges of -Wunsafe-loop-optimisations.

View file

@ -523,6 +523,34 @@ grub_unicode_aglomerate_comb (const grub_uint32_t *in, grub_size_t inlen,
return ptr - in; return ptr - in;
} }
static void
revert (struct grub_unicode_glyph *visual,
struct grub_term_pos *pos,
unsigned start, unsigned end)
{
struct grub_unicode_glyph t;
unsigned i;
int a = 0, b = 0;
if (pos)
{
a = pos[visual[start].orig_pos].x;
b = pos[visual[end].orig_pos].x;
}
for (i = 0; i < (end - start) / 2 + 1; i++)
{
t = visual[start + i];
visual[start + i] = visual[end - i];
visual[end - i] = t;
if (pos)
{
pos[visual[start + i].orig_pos].x = a + b - pos[visual[start + i].orig_pos].x;
pos[visual[end - i].orig_pos].x = a + b - pos[visual[end - i].orig_pos].x;
}
}
}
static grub_ssize_t static grub_ssize_t
bidi_line_wrap (struct grub_unicode_glyph *visual_out, bidi_line_wrap (struct grub_unicode_glyph *visual_out,
struct grub_unicode_glyph *visual, struct grub_unicode_glyph *visual,
@ -542,31 +570,6 @@ bidi_line_wrap (struct grub_unicode_glyph *visual_out,
grub_ssize_t last_space_width = 0; grub_ssize_t last_space_width = 0;
int lines = 0; int lines = 0;
auto void revert (unsigned start, unsigned end);
void revert (unsigned start, unsigned end)
{
struct grub_unicode_glyph t;
unsigned i;
int a = 0, b = 0;
if (pos)
{
a = pos[visual[start].orig_pos].x;
b = pos[visual[end].orig_pos].x;
}
for (i = 0; i < (end - start) / 2 + 1; i++)
{
t = visual[start + i];
visual[start + i] = visual[end - i];
visual[end - i] = t;
if (pos)
{
pos[visual[start + i].orig_pos].x = a + b - pos[visual[start + i].orig_pos].x;
pos[visual[end - i].orig_pos].x = a + b - pos[visual[end - i].orig_pos].x;
}
}
}
if (!visual_len) if (!visual_len)
return 0; return 0;
@ -644,7 +647,7 @@ bidi_line_wrap (struct grub_unicode_glyph *visual_out,
in = i; in = i;
if (visual[i].bidi_level >= j && (i + 1 == k if (visual[i].bidi_level >= j && (i + 1 == k
|| visual[i+1].bidi_level < j)) || visual[i+1].bidi_level < j))
revert (in, i); revert (visual, pos, in, i);
} }
} }
} }
@ -790,34 +793,34 @@ grub_bidi_line_logical_to_visual (const grub_uint32_t *logical,
unsigned cur_level; unsigned cur_level;
int bidi_needed = 0; int bidi_needed = 0;
auto void push_stack (unsigned new_override, unsigned new_level); #define push_stack(new_override, new_level) \
void push_stack (unsigned new_override, unsigned new_level) { \
{ if (new_level > GRUB_BIDI_MAX_EXPLICIT_LEVEL) \
if (new_level > GRUB_BIDI_MAX_EXPLICIT_LEVEL) { \
{ invalid_pushes++; \
invalid_pushes++; } \
return; else \
} { \
stack_level[stack_depth] = cur_level; stack_level[stack_depth] = cur_level; \
stack_override[stack_depth] = cur_override; stack_override[stack_depth] = cur_override; \
stack_depth++; stack_depth++; \
cur_level = new_level; cur_level = new_level; \
cur_override = new_override; cur_override = new_override; \
} \
} }
auto void pop_stack (void); #define pop_stack() \
void pop_stack (void) { \
{ if (invalid_pushes) \
if (invalid_pushes) { \
{ invalid_pushes--; \
invalid_pushes--; } \
return; else if (stack_depth) \
} { \
if (!stack_depth) stack_depth--; \
return; cur_level = stack_level[stack_depth]; \
stack_depth--; cur_override = stack_override[stack_depth]; \
cur_level = stack_level[stack_depth]; } \
cur_override = stack_override[stack_depth];
} }
visual = grub_malloc (sizeof (visual[0]) * logical_len); visual = grub_malloc (sizeof (visual[0]) * logical_len);