X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.c;h=503876655570f93d13d9e3462c1cc8a9ed95d25b;hb=de1559a09497ae4ead44a6e70b556123a5bab35c;hp=33a70b54d8c62a61768cd0e82484ddafbdaf9565;hpb=fa32adf16ce190fd20fc75cbe37551fc1cc3f89f;p=chaz%2Fopenbox diff --git a/openbox/menu.c b/openbox/menu.c index 33a70b54..50387665 100644 --- a/openbox/menu.c +++ b/openbox/menu.c @@ -299,23 +299,28 @@ void menu_show(gchar *name, gint x, gint y, ObClient *client) menu_frame_hide_all(); frame = menu_frame_new(self, client); - if (client && x < 0 && y < 0) - menu_frame_move(frame, - client->frame->area.x + client->frame->size.left, - client->frame->area.y + client->frame->size.top); - else + if (client && x < 0 && y < 0) { + x = client->frame->area.x + client->frame->size.left; + y = client->frame->area.y + client->frame->size.top; + menu_frame_move(frame, x, y); + } else menu_frame_move(frame, x - ob_rr_theme->bwidth, y - ob_rr_theme->bwidth); - frame->monitor = 0; for (i = 0; i < screen_num_monitors; ++i) { Rect *a = screen_physical_area_monitor(i); - if (RECT_CONTAINS(*a, frame->area.x, frame->area.y)) { + if (RECT_CONTAINS(*a, x, y)) { frame->monitor = i; break; } } if (!menu_frame_show(frame, NULL)) menu_frame_free(frame); + else if (frame->entries) { + ObMenuEntryFrame *e = frame->entries->data; + if (e->entry->type == OB_MENU_ENTRY_TYPE_NORMAL && + e->entry->data.normal.enabled) + menu_frame_select(frame, e); + } } static ObMenuEntry* menu_entry_new(ObMenu *menu, ObMenuEntryType type, gint id)