summaryrefslogtreecommitdiff
path: root/obrender/button.c
diff options
context:
space:
mode:
Diffstat (limited to 'obrender/button.c')
-rw-r--r--obrender/button.c124
1 files changed, 43 insertions, 81 deletions
diff --git a/obrender/button.c b/obrender/button.c
index 35437afd..faf83e02 100644
--- a/obrender/button.c
+++ b/obrender/button.c
@@ -29,49 +29,25 @@ RrButton *RrButtonNew (const RrInstance *inst)
{
RrButton *out = NULL;
- out = g_new(RrButton, 1);
+ /* no need to alloc colors and masks, set them null (for freeing later) */
+ out = g_new0(RrButton, 1);
out->inst = inst;
- /* no need to alloc colors, set them null (for freeing later) */
- out->focused_unpressed_color = NULL;
- out->unfocused_unpressed_color = NULL;
- out->focused_pressed_color = NULL;
- out->unfocused_pressed_color = NULL;
- out->disabled_focused_color = NULL;
- out->disabled_unfocused_color = NULL;
- out->hover_focused_color = NULL;
- out->hover_unfocused_color = NULL;
- out->toggled_hover_focused_color = NULL;
- out->toggled_hover_unfocused_color = NULL;
- out->toggled_focused_pressed_color = NULL;
- out->toggled_unfocused_pressed_color = NULL;
- out->toggled_focused_unpressed_color = NULL;
- out->toggled_unfocused_unpressed_color = NULL;
-
- /* same with masks */
- out->mask = NULL;
- out->pressed_mask = NULL;
- out->disabled_mask = NULL;
- out->hover_mask = NULL;
- out->toggled_mask = NULL;
- out->toggled_hover_mask = NULL;
- out->toggled_pressed_mask = NULL;
-
/* allocate appearances */
out->a_focused_unpressed = RrAppearanceNew(inst, 1);
out->a_unfocused_unpressed = RrAppearanceNew(inst, 1);
out->a_focused_pressed = RrAppearanceNew(inst, 1);
out->a_unfocused_pressed = RrAppearanceNew(inst, 1);
- out->a_disabled_focused = RrAppearanceNew(inst, 1);
- out->a_disabled_unfocused = RrAppearanceNew(inst, 1);
- out->a_hover_focused = RrAppearanceNew(inst, 1);
- out->a_hover_unfocused = RrAppearanceNew(inst, 1);
- out->a_toggled_focused_unpressed = RrAppearanceNew(inst, 1);
- out->a_toggled_unfocused_unpressed = RrAppearanceNew(inst, 1);
- out->a_toggled_focused_pressed = RrAppearanceNew(inst, 1);
- out->a_toggled_unfocused_pressed = RrAppearanceNew(inst, 1);
- out->a_toggled_hover_focused = RrAppearanceNew(inst, 1);
- out->a_toggled_hover_unfocused = RrAppearanceNew(inst, 1);
+ out->a_focused_disabled = RrAppearanceNew(inst, 1);
+ out->a_unfocused_disabled = RrAppearanceNew(inst, 1);
+ out->a_focused_hover = RrAppearanceNew(inst, 1);
+ out->a_unfocused_hover = RrAppearanceNew(inst, 1);
+ out->a_focused_unpressed_toggled = RrAppearanceNew(inst, 1);
+ out->a_unfocused_unpressed_toggled = RrAppearanceNew(inst, 1);
+ out->a_focused_pressed_toggled = RrAppearanceNew(inst, 1);
+ out->a_unfocused_pressed_toggled = RrAppearanceNew(inst, 1);
+ out->a_focused_hover_toggled = RrAppearanceNew(inst, 1);
+ out->a_unfocused_hover_toggled = RrAppearanceNew(inst, 1);
return out;
}
@@ -79,57 +55,43 @@ RrButton *RrButtonNew (const RrInstance *inst)
void RrButtonFree(RrButton *b)
{
/* colors */
- if (b->focused_unpressed_color)
- RrColorFree(b->focused_unpressed_color);
- if (b->unfocused_unpressed_color)
- RrColorFree(b->unfocused_unpressed_color);
- if (b->focused_pressed_color)
- RrColorFree(b->focused_pressed_color);
- if (b->unfocused_pressed_color)
- RrColorFree(b->unfocused_pressed_color);
- if (b->disabled_focused_color)
- RrColorFree(b->disabled_focused_color);
- if (b->disabled_unfocused_color)
- RrColorFree(b->disabled_unfocused_color);
- if (b->hover_focused_color)
- RrColorFree(b->hover_focused_color);
- if (b->hover_unfocused_color)
- RrColorFree(b->hover_unfocused_color);
- if (b->toggled_hover_focused_color)
- RrColorFree(b->toggled_hover_focused_color);
- if (b->toggled_hover_unfocused_color)
- RrColorFree(b->toggled_hover_unfocused_color);
- if (b->toggled_focused_pressed_color)
- RrColorFree(b->toggled_focused_pressed_color);
- if (b->toggled_unfocused_pressed_color)
- RrColorFree(b->toggled_unfocused_pressed_color);
- if (b->toggled_focused_unpressed_color)
- RrColorFree(b->toggled_focused_unpressed_color);
- if (b->toggled_unfocused_unpressed_color)
- RrColorFree(b->toggled_unfocused_unpressed_color);
+ RrColorFree(b->focused_unpressed_color);
+ RrColorFree(b->unfocused_unpressed_color);
+ RrColorFree(b->focused_pressed_color);
+ RrColorFree(b->unfocused_pressed_color);
+ RrColorFree(b->focused_disabled_color);
+ RrColorFree(b->unfocused_disabled_color);
+ RrColorFree(b->focused_hover_color);
+ RrColorFree(b->unfocused_hover_color);
+ RrColorFree(b->focused_hover_toggled_color);
+ RrColorFree(b->unfocused_hover_toggled_color);
+ RrColorFree(b->focused_pressed_toggled_color);
+ RrColorFree(b->unfocused_pressed_toggled_color);
+ RrColorFree(b->focused_unpressed_toggled_color);
+ RrColorFree(b->unfocused_unpressed_toggled_color);
/* masks */
- if (b->mask) RrPixmapMaskFree(b->mask);
- if (b->pressed_mask) RrPixmapMaskFree(b->pressed_mask);
- if (b->disabled_mask) RrPixmapMaskFree(b->disabled_mask);
- if (b->hover_mask) RrPixmapMaskFree(b->hover_mask);
- if (b->toggled_mask) RrPixmapMaskFree(b->toggled_mask);
- if (b->toggled_hover_mask) RrPixmapMaskFree(b->toggled_hover_mask);
- if (b->toggled_pressed_mask) RrPixmapMaskFree(b->toggled_pressed_mask);
+ RrPixmapMaskFree(b->unpressed_mask);
+ RrPixmapMaskFree(b->pressed_mask);
+ RrPixmapMaskFree(b->disabled_mask);
+ RrPixmapMaskFree(b->hover_mask);
+ RrPixmapMaskFree(b->unpressed_toggled_mask);
+ RrPixmapMaskFree(b->hover_toggled_mask);
+ RrPixmapMaskFree(b->pressed_toggled_mask);
/* appearances */
RrAppearanceFree(b->a_focused_unpressed);
RrAppearanceFree(b->a_unfocused_unpressed);
RrAppearanceFree(b->a_focused_pressed);
RrAppearanceFree(b->a_unfocused_pressed);
- RrAppearanceFree(b->a_disabled_focused);
- RrAppearanceFree(b->a_disabled_unfocused);
- RrAppearanceFree(b->a_hover_focused);
- RrAppearanceFree(b->a_hover_unfocused);
- RrAppearanceFree(b->a_toggled_focused_unpressed);
- RrAppearanceFree(b->a_toggled_unfocused_unpressed);
- RrAppearanceFree(b->a_toggled_focused_pressed);
- RrAppearanceFree(b->a_toggled_unfocused_pressed);
- RrAppearanceFree(b->a_toggled_hover_focused);
- RrAppearanceFree(b->a_toggled_hover_unfocused);
+ RrAppearanceFree(b->a_focused_disabled);
+ RrAppearanceFree(b->a_unfocused_disabled);
+ RrAppearanceFree(b->a_focused_hover);
+ RrAppearanceFree(b->a_unfocused_hover);
+ RrAppearanceFree(b->a_focused_unpressed_toggled);
+ RrAppearanceFree(b->a_unfocused_unpressed_toggled);
+ RrAppearanceFree(b->a_focused_pressed_toggled);
+ RrAppearanceFree(b->a_unfocused_pressed_toggled);
+ RrAppearanceFree(b->a_focused_hover_toggled);
+ RrAppearanceFree(b->a_unfocused_hover_toggled);
}