X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fevent.c;h=15a7a4790569a5d510b9f59c701a9cbdbcc3e21f;hb=efc9d9708e3e746a9744a6175a4d3a1259d69991;hp=e198eaa1aacfacaea51e32ba19ff03862ffe846c;hpb=8f988b2bef5af05f0b5cddbc11b05c833158df5a;p=chaz%2Fopenbox diff --git a/openbox/event.c b/openbox/event.c index e198eaa1..15a7a479 100644 --- a/openbox/event.c +++ b/openbox/event.c @@ -2006,6 +2006,20 @@ static void event_handle_menu(ObMenuFrame *frame, XEvent *ev) ObMenuEntryFrame *e; switch (ev->type) { + case MotionNotify: + // We need to catch MotionNotify in addition to EnterNotify because + // it is possible for the menu to be opened under the mouse cursor, and + // moving the mouse should select the item. + if ((e = g_hash_table_lookup(menu_frame_map, &ev->xmotion.window))) { + if (e->ignore_enters) + --e->ignore_enters; + else if (!(f = find_active_menu()) || + f == e->frame || + f->parent == e->frame || + f->child == e->frame) + menu_frame_select(e->frame, e, FALSE); + } + break; case EnterNotify: if ((e = g_hash_table_lookup(menu_frame_map, &ev->xcrossing.window))) { if (e->ignore_enters)