Refactorize item drawing: add draw_item() function

This commit is contained in:
Julien Danjou 2008-03-07 16:37:09 +01:00
parent e5069d1b8c
commit ddd4f1c43b
1 changed files with 15 additions and 17 deletions

View File

@ -213,6 +213,19 @@ compute_match(void)
/* Why not? */ /* Why not? */
#define MARGIN 10 #define MARGIN 10
static void
draw_item(item_t *item, Area geometry)
{
if(item == globalconf.item_selected)
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data,
globalconf.fg_focus, globalconf.bg_focus);
else
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data,
globalconf.fg, globalconf.bg);
}
static void static void
redraw(void) redraw(void)
{ {
@ -244,15 +257,7 @@ redraw(void)
for(item = globalconf.items; item && geometry.width > 0; item = item->next) for(item = globalconf.items; item && geometry.width > 0; item = item->next)
if(item->match) if(item->match)
{ {
if(item == globalconf.item_selected) draw_item(item, geometry);
{
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data, globalconf.fg_focus, globalconf.bg_focus);
selected_item_is_drawn = True;
}
else
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data, globalconf.fg, globalconf.bg);
len = MARGIN + draw_textwidth(globalconf.display, globalconf.font, item->data); len = MARGIN + draw_textwidth(globalconf.display, globalconf.font, item->data);
geometry.x += len; geometry.x += len;
geometry.width -= len; geometry.width -= len;
@ -274,14 +279,7 @@ redraw(void)
if(geometry.x < prompt_len) if(geometry.x < prompt_len)
break; break;
/* XXX need factorizing */ draw_item(item, geometry);
if(item == globalconf.item_selected)
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data, globalconf.fg_focus, globalconf.bg_focus);
else
draw_text(globalconf.ctx, geometry, AlignLeft,
MARGIN / 2, globalconf.font, item->data, globalconf.fg, globalconf.bg);
} }
if(item) if(item)