diff --git a/event.c b/event.c index b280c1df9..2753fb1f8 100644 --- a/event.c +++ b/event.c @@ -87,10 +87,9 @@ event_handle_mouse_button(client_t *c, * \return A widget node. */ static widget_node_t * -widget_getbycoords(position_t position, widget_node_t *widgets, int width, int height, int16_t *x, int16_t *y) +widget_getbycoords(position_t position, widget_node_array_t *widgets, int width, int height, int16_t *x, int16_t *y) { int tmp; - widget_node_t *w; /* Need to transform coordinates like it was top/bottom */ switch(position) @@ -109,11 +108,14 @@ widget_getbycoords(position_t position, widget_node_t *widgets, int width, int h break; } - for(w = widgets; w; w = w->next) + for(int i = 0; i < widgets->len; i++) + { + widget_node_t *w = &widgets->tab[i]; if(w->widget->isvisible && *x >= w->area.x && *x < w->area.x + w->area.width && *y >= w->area.y && *y < w->area.y + w->area.height) return w; + } return NULL; } @@ -148,7 +150,7 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e ev->event_x -= wibox->sw.geometry.x; ev->event_y -= wibox->sw.geometry.y; } - if((w = widget_getbycoords(wibox->position, wibox->widgets, + if((w = widget_getbycoords(wibox->position, &wibox->widgets, wibox->sw.geometry.width, wibox->sw.geometry.height, &ev->event_x, &ev->event_y))) @@ -331,21 +333,21 @@ event_handle_destroynotify(void *data __attribute__ ((unused)), */ static void event_handle_widget_motionnotify(void *object, - widget_node_t **mouse_over, + widget_t **mouse_over, widget_node_t *w) { - if(w != *mouse_over) + if(w->widget != *mouse_over) { if(*mouse_over) { /* call mouse leave function on old widget */ luaA_wibox_userdata_new(globalconf.L, object); - luaA_dofunction(globalconf.L, (*mouse_over)->widget->mouse_leave, 1, 0); + luaA_dofunction(globalconf.L, (*mouse_over)->mouse_leave, 1, 0); } if(w) { /* call mouse enter function on new widget and register it */ - *mouse_over = w; + *mouse_over = w->widget; luaA_wibox_userdata_new(globalconf.L, object); luaA_dofunction(globalconf.L, w->widget->mouse_enter, 1, 0); } @@ -365,14 +367,12 @@ event_handle_motionnotify(void *data __attribute__ ((unused)), wibox_t *wibox = wibox_getbywin(ev->event); widget_node_t *w; - if(wibox) - { - w = widget_getbycoords(wibox->position, wibox->widgets, - wibox->sw.geometry.width, - wibox->sw.geometry.height, - &ev->event_x, &ev->event_y); + if(wibox + && (w = widget_getbycoords(wibox->position, &wibox->widgets, + wibox->sw.geometry.width, + wibox->sw.geometry.height, + &ev->event_x, &ev->event_y))) event_handle_widget_motionnotify(wibox, &wibox->mouse_over, w); - } return 0; } @@ -393,7 +393,7 @@ event_handle_leavenotify(void *data __attribute__ ((unused)), { /* call mouse leave function on widget the mouse was over */ luaA_wibox_userdata_new(globalconf.L, wibox); - luaA_dofunction(globalconf.L, wibox->mouse_over->widget->mouse_leave, 1, 0); + luaA_dofunction(globalconf.L, wibox->mouse_over->mouse_leave, 1, 0); } return 0; diff --git a/structs.h b/structs.h index d3131b3dd..1aa2fb427 100644 --- a/structs.h +++ b/structs.h @@ -84,6 +84,8 @@ typedef widget_t *(widget_constructor_t)(alignment_t); typedef void (widget_destructor_t)(widget_t *); typedef struct awesome_t awesome_t; +ARRAY_TYPE(widget_node_t, widget_node) + /** Wibox type */ typedef struct { @@ -104,10 +106,10 @@ typedef struct /** Screen */ int screen; /** Widget list */ - widget_node_t *widgets; + widget_node_array_t widgets; luaA_ref widgets_table; /** Widget the mouse is over */ - widget_node_t *mouse_over; + widget_t *mouse_over; /** Need update */ bool need_update; } wibox_t; @@ -185,22 +187,8 @@ struct widget_node_t widget_t *widget; /** The area where the widget was drawn */ area_t area; - /** Next and previous widget in the list */ - widget_node_t *prev, *next; }; -/** Delete a widget node structure. - * \param node The node to destroy. - */ -static inline void -widget_node_delete(widget_node_t **node) -{ - widget_unref(&(*node)->widget); - p_delete(node); -} - -DO_SLIST(widget_node_t, widget_node, widget_node_delete) - /* Strut */ typedef struct { diff --git a/wibox.c b/wibox.c index 0321054bb..91d177092 100644 --- a/wibox.c +++ b/wibox.c @@ -114,12 +114,12 @@ wibox_systray_kickout(int phys_screen) static void wibox_systray_refresh(wibox_t *wibox) { - widget_node_t *systray; - if(wibox->screen == SCREEN_UNDEF) return; - for(systray = wibox->widgets; systray; systray = systray->next) + for(int i = 0; i < wibox->widgets.len; i++) + { + widget_node_t *systray = &wibox->widgets.tab[i]; if(systray->widget->type == systray_new) { uint32_t config_back[] = { wibox->sw.ctx.bg.pixel }; @@ -263,6 +263,7 @@ wibox_systray_refresh(wibox_t *wibox) } break; } + } } /** Update the wibox position. It deletes every wibox resources and @@ -447,7 +448,7 @@ wibox_delete(wibox_t **wibox) { simplewindow_wipe(&(*wibox)->sw); luaL_unref(globalconf.L, LUA_REGISTRYINDEX, (*wibox)->widgets_table); - widget_node_list_wipe(&(*wibox)->widgets); + widget_node_array_wipe(&(*wibox)->widgets); p_delete(wibox); } @@ -481,7 +482,7 @@ wibox_draw(wibox_t *wibox) { if(wibox->isvisible) { - widget_render(wibox->widgets, &wibox->sw.ctx, wibox->sw.gc, + widget_render(&wibox->widgets, &wibox->sw.ctx, wibox->sw.gc, wibox->sw.pixmap, wibox->screen, wibox->sw.orientation, wibox->sw.geometry.x, wibox->sw.geometry.y, @@ -697,7 +698,8 @@ luaA_wibox_new(lua_State *L) static void wibox_widgets_table_build(lua_State *L, wibox_t *wibox) { - widget_node_list_wipe(&wibox->widgets); + widget_node_array_wipe(&wibox->widgets); + widget_node_array_init(&wibox->widgets); luaA_table2widgets(L, &wibox->widgets); wibox->mouse_over = NULL; wibox->need_update = true; diff --git a/widget.c b/widget.c index 27daf95d8..45ff4caff 100644 --- a/widget.c +++ b/widget.c @@ -87,7 +87,7 @@ widget_common_button(widget_node_t *w, * \param widgets The linked list of widget node. */ void -luaA_table2widgets(lua_State *L, widget_node_t **widgets) +luaA_table2widgets(lua_State *L, widget_node_array_t *widgets) { if(lua_istable(L, -1)) { @@ -103,9 +103,10 @@ luaA_table2widgets(lua_State *L, widget_node_t **widgets) widget_t **widget = luaA_toudata(L, -1, "widget"); if(widget) { - widget_node_t *w = p_new(widget_node_t, 1); - w->widget = widget_ref(widget); - widget_node_list_append(widgets, w); + widget_node_t w; + p_clear(&w, 1); + w.widget = widget_ref(widget); + widget_node_array_append(widgets, w); } } } @@ -123,13 +124,12 @@ luaA_table2widgets(lua_State *L, widget_node_t **widgets) * \todo Remove GC. */ void -widget_render(widget_node_t *wnode, draw_context_t *ctx, xcb_gcontext_t gc, xcb_pixmap_t rotate_px, +widget_render(widget_node_array_t *widgets, draw_context_t *ctx, xcb_gcontext_t gc, xcb_pixmap_t rotate_px, int screen, orientation_t orientation, int x, int y, wibox_t *wibox) { xcb_pixmap_t rootpix; xcb_screen_t *s; - widget_node_t *w; int left = 0, right = 0; char *data; xcb_get_property_reply_t *prop_r; @@ -183,28 +183,28 @@ widget_render(widget_node_t *wnode, draw_context_t *ctx, xcb_gcontext_t gc, xcb_ draw_rectangle(ctx, rectangle, 1.0, true, &ctx->bg); - for(w = wnode; w; w = w->next) - if(w->widget->align == AlignLeft && w->widget->isvisible) - left += w->widget->draw(ctx, screen, w, left, (left + right), wibox); + for(int i = 0; i < widgets->len; i++) + if(widgets->tab[i].widget->align == AlignLeft && widgets->tab[i].widget->isvisible) + left += widgets->tab[i].widget->draw(ctx, screen, &widgets->tab[i], left, (left + right), wibox); /* renders right widget from last to first */ - for(w = *widget_node_list_last(&wnode); w; w = w->prev) - if(w->widget->align == AlignRight && w->widget->isvisible) - right += w->widget->draw(ctx, screen, w, right, (left + right), wibox); + for(int i = widgets->len - 1; i; i--) + if(widgets->tab[i].widget->align == AlignRight && widgets->tab[i].widget->isvisible) + right += widgets->tab[i].widget->draw(ctx, screen, &widgets->tab[i], right, (left + right), wibox); /* \todo rewrite this */ int flex = 0; - for(w = wnode; w; w = w->next) - if(w->widget->align == AlignFlex && w->widget->isvisible) + for(int i = 0; i < widgets->len; i++) + if(widgets->tab[i].widget->align == AlignFlex && widgets->tab[i].widget->isvisible) flex++; if(flex) { int length = (ctx->width - (left + right)) / flex; - for(w = wnode; w; w = w->next) - if(w->widget->align == AlignFlex && w->widget->isvisible) - left += w->widget->draw(ctx, screen, w, left, (left + right) + length * --flex , wibox); + for(int i = 0; i < widgets->len; i++) + if(widgets->tab[i].widget->align == AlignFlex && widgets->tab[i].widget->isvisible) + left += widgets->tab[i].widget->draw(ctx, screen, &widgets->tab[i], left, (left + right) + length * --flex , wibox); } switch(orientation) @@ -249,10 +249,9 @@ widget_invalidate_cache(int screen, int flags) for(int i = 0; i < globalconf.screens[screen].wiboxes.len; i++) { wibox_t *wibox = globalconf.screens[screen].wiboxes.tab[i]; - widget_node_t *widget; - for(widget = wibox->widgets; widget; widget = widget->next) - if(widget->widget->cache_flags & flags) + for(int j = 0; j < wibox->widgets.len; j++) + if(wibox->widgets.tab[j].widget->cache_flags & flags) { wibox->need_update = true; break; @@ -272,8 +271,8 @@ widget_invalidate_bywidget(widget_t *widget) { wibox_t *wibox = globalconf.screens[screen].wiboxes.tab[i]; if(!wibox->need_update) - for(widget_node_t *witer = wibox->widgets; witer; witer = witer->next) - if(witer->widget == widget) + for(int j = 0; j < wibox->widgets.len; j++) + if(wibox->widgets.tab[j].widget == widget) { wibox->need_update = true; break; @@ -282,8 +281,8 @@ widget_invalidate_bywidget(widget_t *widget) for(client_t *c = globalconf.clients; c; c = c->next) if(c->titlebar && !c->titlebar->need_update) - for(widget_node_t *witer = c->titlebar->widgets; witer; witer = witer->next) - if(witer->widget == widget) + for(int j = 0; j < c->titlebar->widgets.len; j++) + if(c->titlebar->widgets.tab[j].widget == widget) { c->titlebar->need_update = true; break; diff --git a/widget.h b/widget.h index d886b8570..0d1d03c08 100644 --- a/widget.h +++ b/widget.h @@ -29,10 +29,10 @@ void widget_invalidate_cache(int, int); int widget_calculate_offset(int, int, int, int); void widget_common_new(widget_t *); -void widget_render(widget_node_t *, draw_context_t *, xcb_gcontext_t, xcb_drawable_t, int, orientation_t, int, int, wibox_t *); +void widget_render(widget_node_array_t *, draw_context_t *, xcb_gcontext_t, xcb_drawable_t, int, orientation_t, int, int, wibox_t *); int luaA_widget_userdata_new(lua_State *, widget_t *); -void luaA_table2widgets(lua_State *, widget_node_t **); +void luaA_table2widgets(lua_State *, widget_node_array_t *); void widget_invalidate_bywidget(widget_t *); @@ -42,6 +42,17 @@ widget_constructor_t graph_new; widget_constructor_t systray_new; widget_constructor_t imagebox_new; +/** Delete a widget node structure. + * \param node The node to destroy. + */ +static inline void +widget_node_delete(widget_node_t *node) +{ + widget_unref(&node->widget); +} + +ARRAY_FUNCS(widget_node_t, widget_node, widget_node_delete) + #endif // vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80