diff --git a/openbox/menu.c b/openbox/menu.c
index c6c3a4a3..00a2bc2b 100644
--- a/openbox/menu.c
+++ b/openbox/menu.c
@@ -142,8 +142,9 @@ void menu_entry_free(ObMenuEntry *self)
RrAppearanceFree(self->a_item);
RrAppearanceFree(self->a_disabled);
RrAppearanceFree(self->a_hilite);
+ RrAppearanceFree(self->a_submenu);
XDestroyWindow(ob_display, self->item);
-
+ XDestroyWindow(ob_display, self->submenu_pic);
g_free(self);
}
@@ -273,13 +274,17 @@ void menu_add_entry(ObMenu *menu, ObMenuEntry *entry)
attrib.event_mask = ENTRY_EVENTMASK;
entry->item = createWindow(menu->items, CWEventMask, &attrib);
+ entry->submenu_pic = createWindow(menu->items, CWEventMask, &attrib);
XMapWindow(ob_display, entry->item);
+ XMapWindow(ob_display, entry->submenu_pic);
- entry->a_item = entry->a_disabled = entry->a_hilite = NULL;
+ entry->a_item = entry->a_disabled = entry->a_hilite = entry->a_submenu
+ = NULL;
menu->invalid = TRUE;
g_hash_table_insert(window_map, &entry->item, menu);
+ g_hash_table_insert(window_map, &entry->submenu_pic, menu);
}
void menu_show(char *name, int x, int y, ObClient *client)
@@ -473,9 +478,21 @@ void menu_control_mouseover(ObMenuEntry *self, gboolean enter)
a = screen_physical_area_monitor(self->parent->xin_area);
- if (self->submenu->size.width + x >= a->x + a->width)
- x = self->parent->location.x - self->submenu->size.width -
- ob_rr_theme->bwidth + ob_rr_theme->menu_overlap;
+ if (self->submenu->size.width + x >= a->x + a->width) {
+ int newparentx = a->x + a->width
+ - self->submenu->size.width
+ - self->parent->size.width
+ - ob_rr_theme->bwidth
+ - ob_rr_theme->menu_overlap;
+
+ x = a->x + a->width - self->submenu->size.width
+ - ob_rr_theme->menu_overlap;
+ XWarpPointer(ob_display, None, None, 0, 0, 0, 0,
+ newparentx - self->parent->location.x, 0);
+
+ menu_show_full(self->parent, newparentx,
+ self->parent->location.y, self->parent->client);
+ }
menu_show_full(self->submenu, x,
self->parent->location.y + self->y,
diff --git a/openbox/menu.h b/openbox/menu.h
index 1d20ff03..3b7c1c38 100644
--- a/openbox/menu.h
+++ b/openbox/menu.h
@@ -114,9 +114,12 @@ struct _ObMenuEntry
/* render stuff */
Window item;
+ Window submenu_pic;
+
RrAppearance *a_item;
RrAppearance *a_disabled;
RrAppearance *a_hilite;
+ RrAppearance *a_submenu;
gint y;
gint min_w;
} MenuEntry;
diff --git a/openbox/menu_render.c b/openbox/menu_render.c
index 60f02976..42c7f965 100644
--- a/openbox/menu_render.c
+++ b/openbox/menu_render.c
@@ -45,8 +45,9 @@ void menu_render(ObMenu *self) {
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);
@@ -97,11 +98,14 @@ void menu_render(ObMenu *self) {
void menu_entry_render(ObMenuEntry *self)
{
ObMenu *menu = self->parent;
- RrAppearance *a;
+ RrAppearance *a, *s = NULL;
switch (self->render_type) {
case OB_MENU_ENTRY_RENDER_TYPE_SUBMENU:
- /* TODO: submenu mask */
+ 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)
@@ -119,14 +123,23 @@ void menu_entry_render(ObMenuEntry *self)
g_assert_not_reached(); /* unhandled rendering type */
break;
}
- ob_debug("%s %d\n", self->label, self->hilite);
XMoveResizeWindow(ob_display, self->item, 0, self->y,
menu->size.width, menu->item_h);
-
+ XMoveResizeWindow(ob_display, self->submenu_pic, menu->size.width - ob_rr_theme->bevel - 1, self->y,
+ 8, 8);
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 - 8;
+ s->surface.parenty = 0;
+ }
+
RrPaint(a, self->item, menu->size.width, menu->item_h);
+
+ if (s)
+ RrPaint(s, self->submenu_pic, 8, 8);
}
diff --git a/plugins/menu/fifo_menu.c b/plugins/menu/fifo_menu.c
index 3443294e..cb35579e 100644
--- a/plugins/menu/fifo_menu.c
+++ b/plugins/menu/fifo_menu.c
@@ -1,3 +1,25 @@
+/*
+ * $Header$
+ *
+ * FFIO menu plugin
+ * Provides a menu from a FIFO located in ~/.openbox/fifo_menu/id
+ * Example:
+ * rc3:
+ *
+ * Menu format
+ *
+ * -
+ *
+ *
+ * bsetbg "/home/woodblock/.openbox/backgrounds/GLOVE.png"
+ *
+ *
+ *
+ *
+ *
+ * If the attribute pid="true" is in the