]> Dogcows Code - chaz/openbox/blobdiff - openbox/menu_render.c
half way through the changes to new menu code/design. hot shit. static menus work...
[chaz/openbox] / openbox / menu_render.c
diff --git a/openbox/menu_render.c b/openbox/menu_render.c
deleted file mode 100644 (file)
index 1f03459..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/* Functions for default rendering of menus. Might become pluginnable */
-
-#include "debug.h"
-#include "menu.h"
-#include "openbox.h"
-#include "render/theme.h"
-
-void menu_render(ObMenu *self) {
-    GList *it;
-    int items_h = 0;
-    int nitems = 0; /* each item, only one is used */
-    int item_y;
-
-    self->size.width = 1;
-    self->item_h = 1;
-
-    if (self->a_title == NULL) {
-        XSetWindowBorderWidth(ob_display, self->frame, ob_rr_theme->bwidth);
-        XSetWindowBackground(ob_display, self->frame,
-                             RrColorPixel(ob_rr_theme->b_color));
-        XSetWindowBorderWidth(ob_display, self->title, ob_rr_theme->bwidth);
-        XSetWindowBorder(ob_display, self->frame,
-                         RrColorPixel(ob_rr_theme->b_color));
-        XSetWindowBorder(ob_display, self->title,
-                         RrColorPixel(ob_rr_theme->b_color));
-
-        self->a_title = RrAppearanceCopy(ob_rr_theme->a_menu_title);
-        self->a_items = RrAppearanceCopy(ob_rr_theme->a_menu);
-    }
-    
-    /* set texture data and size them mofos out */
-    if (self->label && !(self->parent && self->parent->shown)) {
-       self->a_title->texture[0].data.text.string = self->label;
-       RrMinsize(self->a_title, &self->title_min_w, &self->title_h);
-       self->title_min_w += ob_rr_theme->bevel * 2;
-       self->title_h += ob_rr_theme->bevel * 2;
-       self->size.width = MAX(self->size.width, self->title_min_w);
-    } else
-        self->title_h = -ob_rr_theme->bwidth;
-
-    for (it = self->entries; it; it = it->next) {
-        ObMenuEntry *e = it->data;
-        int h;
-
-        if (e->a_item == NULL) {
-            e->a_item = RrAppearanceCopy(ob_rr_theme->a_menu_item);
-            e->a_disabled = RrAppearanceCopy(ob_rr_theme->a_menu_disabled);
-            e->a_hilite = RrAppearanceCopy(ob_rr_theme->a_menu_hilite);
-            e->a_submenu = RrAppearanceCopy(ob_rr_theme->a_menu_bullet);
-        }
-        
-        e->a_item->texture[0].data.text.string = e->label;
-        RrMinsize(e->a_item, &e->min_w, &self->item_h);
-        self->size.width = MAX(self->size.width, e->min_w);
-
-        e->a_disabled->texture[0].data.text.string = e->label;
-        RrMinsize(e->a_disabled, &e->min_w, &h);
-        self->item_h = MAX(self->item_h, h);
-        self->size.width = MAX(self->size.width, e->min_w);
-       
-        e->a_hilite->texture[0].data.text.string = e->label;
-        RrMinsize(e->a_hilite, &e->min_w, &h);
-        self->item_h = MAX(self->item_h, h);
-        self->size.width = MAX(self->size.width, e->min_w);
-
-        e->min_w += ob_rr_theme->bevel * 2;
-        ++nitems;
-    }
-    self->bullet_w = self->item_h + ob_rr_theme->bevel;
-    self->size.width += 2 * self->bullet_w + 2 * ob_rr_theme->bevel;
-    self->item_h += ob_rr_theme->bevel * 2;
-    items_h = self->item_h * MAX(nitems, 1);
-
-    self->size.height = MAX(self->title_h + items_h + ob_rr_theme->bwidth, 1);
-    XResizeWindow(ob_display, self->frame, self->size.width,self->size.height);
-    if (self->label && !(self->parent && self->parent->shown)) {
-       XMoveResizeWindow(ob_display, self->title, -ob_rr_theme->bwidth,
-                         -ob_rr_theme->bwidth,
-                          self->size.width, self->title_h);
-        XMapWindow(ob_display, self->title);
-    } else
-        XUnmapWindow(ob_display, self->title);
-
-    XMoveResizeWindow(ob_display, self->items, 0, 
-                     self->title_h + ob_rr_theme->bwidth, self->size.width, 
-                     items_h);
-
-    if (self->label && !(self->parent && self->parent->shown))
-       RrPaint(self->a_title, self->title, self->size.width, self->title_h);
-    RrPaint(self->a_items, self->items, self->size.width, items_h);
-
-    item_y = 0;
-    for (it = self->entries; it; it = it->next) {
-        ((ObMenuEntry*)it->data)->y = item_y;
-        menu_entry_render(it->data);
-        item_y += self->item_h;
-    }
-    
-    self->invalid = FALSE;
-}
-
-void menu_entry_render(ObMenuEntry *self)
-{
-    ObMenu *menu = self->parent;
-    RrAppearance *a, *s = NULL;
-    
-    switch (self->render_type) {
-    case OB_MENU_ENTRY_RENDER_TYPE_SUBMENU:
-        a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item)
-            : self->a_disabled;
-        s = self->a_submenu;
-        break;
-    case OB_MENU_ENTRY_RENDER_TYPE_BOOLEAN:
-       /* TODO: boolean check */
-       a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item) 
-           : self->a_disabled;
-       break;
-    case OB_MENU_ENTRY_RENDER_TYPE_NONE:
-       a = self->enabled ? (self->hilite ? self->a_hilite : self->a_item )
-           : self->a_disabled;
-       break;
-    case OB_MENU_ENTRY_RENDER_TYPE_SEPARATOR:
-       a = self->a_item;
-       break;
-
-    default:
-       g_assert_not_reached(); /* unhandled rendering type */
-       break;
-    }
-
-    XMoveResizeWindow(ob_display, self->item, 0, self->y,
-                      menu->size.width, menu->item_h);
-    if (s) {
-        XMoveResizeWindow(ob_display, self->submenu_pic,
-                          menu->size.width -
-                          menu->bullet_w + (menu->bullet_w - 8) / 2,
-                          self->y + (menu->item_h - 8) / 2,
-                          8, 8);
-        XMapWindow(ob_display, self->submenu_pic);
-    } else
-        XUnmapWindow(ob_display, self->submenu_pic);
-
-    a->surface.parent = menu->a_items;
-    a->surface.parentx = 0;
-    a->surface.parenty = self->y;
-
-    if (s) {
-        s->surface.parent = a;
-        s->surface.parentx = menu->size.width -
-            menu->bullet_w + (menu->bullet_w - 8) / 2,
-        s->surface.parenty = (menu->item_h - 8) / 2;
-    }
-
-    RrPaint(a, self->item, menu->size.width, menu->item_h);
-
-    if (s) 
-        RrPaint(s, self->submenu_pic, 8, 8);
-}
This page took 0.025942 seconds and 4 git commands to generate.