1
0
Fork 0
forked from len0rd/rockbox

count line numbers correctly, handle the VIEWPORT change so it only ever has one child

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26824 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Jonathan Gordon 2010-06-13 02:27:13 +00:00
parent 4752798b58
commit 3f06273e7c

View file

@ -30,12 +30,14 @@
#include "symbols.h" #include "symbols.h"
#include "skin_scan.h" #include "skin_scan.h"
void skin_render_alternator(struct skin_element* alternator); void skin_render_alternator(struct skin_element* alternator, int line_number);
/* Draw a LINE element onto the display */ /* Draw a LINE element onto the display */
void skin_render_line(struct skin_element* line) void skin_render_line(struct skin_element* line, int line_number)
{ {
int i=0, value; int i=0, value;
if (line->children_count == 0)
return; /* empty line, do nothing */
struct skin_element *child = line->children[0]; struct skin_element *child = line->children[0];
while (child) while (child)
{ {
@ -46,9 +48,9 @@ void skin_render_line(struct skin_element* line)
if (value >= child->children_count) if (value >= child->children_count)
value = child->children_count-1; value = child->children_count-1;
if (child->children[value]->type == SUBLINES) if (child->children[value]->type == SUBLINES)
skin_render_alternator(child->children[value]); skin_render_alternator(child->children[value], line_number);
else if (child->children[value]->type == LINE) else if (child->children[value]->type == LINE)
skin_render_line(child->children[value]); skin_render_line(child->children[value], line_number);
break; break;
case TAG: case TAG:
printf("%%%s", child->tag->name); printf("%%%s", child->tag->name);
@ -62,24 +64,26 @@ void skin_render_line(struct skin_element* line)
} }
child = child->next; child = child->next;
} }
printf("\n"); /* might be incorrect */
} }
void skin_render_alternator(struct skin_element* alternator) void skin_render_alternator(struct skin_element* alternator, int line_number)
{ {
/*TODO Choose which subline to draw */ /*TODO Choose which subline to draw */
skin_render_line(alternator->children[0]); skin_render_line(alternator->children[0], line_number);
} }
void skin_render_viewport(struct skin_element* viewport) void skin_render_viewport(struct skin_element* viewport)
{ {
struct skin_element *line = viewport; struct skin_element *line = viewport;
int line_number = 0;
while (line) while (line)
{ {
printf("\n[%d]", line_number); /* might be incorrect */
if (line->type == SUBLINES) if (line->type == SUBLINES)
skin_render_alternator(line); skin_render_alternator(line, line_number);
else if (line->type == LINE) else if (line->type == LINE)
skin_render_line(line); skin_render_line(line, line_number);
line_number++;
line = line->next; line = line->next;
} }
} }
@ -89,7 +93,7 @@ void skin_render(struct skin_element* root)
struct skin_element* viewport = root; struct skin_element* viewport = root;
while (viewport) while (viewport)
{ {
skin_render_viewport(viewport->children[viewport->children_count-1]); skin_render_viewport(viewport->children[0]);
viewport = viewport->next; viewport = viewport->next;
} }
} }