summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-07 22:15:40 +0000
committerDana Jansens <danakj@orodu.net>2007-05-07 22:15:40 +0000
commitd915480371427b6813e7a5140caa4f15c30ee5c9 (patch)
treef73b4f171f04281ab31ba6becdcf8d5342614f86 /openbox
parent3905872982478e4e0ae05f4ce114a8025a2389ee (diff)
oops hehe. a render call in the loop for debugging was what made it slow. anyhow make it even faster by only calling render once too. yay snappiness.
Diffstat (limited to 'openbox')
-rw-r--r--openbox/menuframe.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/openbox/menuframe.c b/openbox/menuframe.c
index b04fda55..476f3373 100644
--- a/openbox/menuframe.c
+++ b/openbox/menuframe.c
@@ -824,13 +824,18 @@ static void menu_frame_update(ObMenuFrame *self)
fit = n;
}
- menu_frame_render(self);
-
- /* make the menu fit on the screen. at most we call render twice, at least
- not like n times or sometime */
+ /* * make the menu fit on the screen */
+
+ /* calculate the height of the menu */
+ h = 0;
+ for (fit = self->entries; fit; fit = g_list_next(fit))
+ h += menu_entry_frame_get_height(fit->data,
+ fit == self->entries,
+ g_list_next(fit) == NULL);
+ /* add the border at the top and bottom */
+ h += ob_rr_theme->mbwidth * 2;
a = screen_physical_area_monitor(self->monitor);
- h = self->area.height;
if (h > a->height) {
GList *flast, *tmp;
@@ -854,8 +859,6 @@ static void menu_frame_update(ObMenuFrame *self)
menu_entry_frame_free(tmp->data);
self->entries = g_list_delete_link(self->entries, tmp);
- menu_frame_render(self);
-
/* only the first one that we see is the last entry in the menu */
last_entry = FALSE;
};
@@ -881,10 +884,9 @@ static void menu_frame_update(ObMenuFrame *self)
/* add our More... entry to the frame */
self->entries = g_list_append(self->entries, more_frame);
}
-
- /* render again */
- menu_frame_render(self);
}
+
+ menu_frame_render(self);
}
static gboolean menu_frame_is_visible(ObMenuFrame *self)