X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenuframe.c;h=5ece36c7250d4eeba9300e483484e1f450c74136;hb=fe2f637e2bda1803ea89ddb80201a3239f5ae284;hp=030f38bd0706feba6dfd242aa8eeaf12f02b57d5;hpb=3e7b4478ee8fdfd5c255723c006ac9292582e747;p=chaz%2Fopenbox diff --git a/openbox/menuframe.c b/openbox/menuframe.c index 030f38bd..5ece36c7 100644 --- a/openbox/menuframe.c +++ b/openbox/menuframe.c @@ -175,7 +175,7 @@ void menu_frame_move_on_screen(ObMenuFrame *self) if (RECT_INTERSECTS_RECT(*a, self->area)) break; } - if (a) a = screen_physical_area_monitor(0); + if (!a) a = screen_physical_area_monitor(0); dx = MIN(0, (a->x + a->width) - (self->area.x + self->area.width)); dy = MIN(0, (a->y + a->height) - (self->area.y + self->area.height)); @@ -361,6 +361,8 @@ static void menu_entry_frame_render(ObMenuEntryFrame *self) XMapWindow(ob_display, self->bullet); } else XUnmapWindow(ob_display, self->bullet); + + XFlush(ob_display); } static void menu_frame_render(ObMenuFrame *self) @@ -514,6 +516,8 @@ static void menu_frame_render(ObMenuFrame *self) h += ob_rr_theme->bwidth * 2; RECT_SET_SIZE(self->area, w, h); + + XFlush(ob_display); } static void menu_frame_update(ObMenuFrame *self) @@ -564,7 +568,7 @@ void menu_frame_show(ObMenuFrame *self, ObMenuFrame *parent) if (menu_frame_visible == NULL) { /* no menus shown yet */ - grab_pointer(TRUE, None); + grab_pointer(TRUE, OB_CURSOR_NONE); grab_keyboard(TRUE); } @@ -605,7 +609,7 @@ void menu_frame_hide(ObMenuFrame *self) if (menu_frame_visible == NULL) { /* last menu shown */ - grab_pointer(FALSE, None); + grab_pointer(FALSE, OB_CURSOR_NONE); grab_keyboard(FALSE); } @@ -711,7 +715,7 @@ void menu_entry_frame_show_submenu(ObMenuEntryFrame *self) menu_frame_show(f, self->frame); } -void menu_entry_frame_execute(ObMenuEntryFrame *self, gboolean hide) +void menu_entry_frame_execute(ObMenuEntryFrame *self, guint state) { if (self->entry->type == OB_MENU_ENTRY_TYPE_NORMAL && self->entry->data.normal.enabled) @@ -725,31 +729,16 @@ void menu_entry_frame_execute(ObMenuEntryFrame *self, gboolean hide) ObClient *client = self->frame->client; /* release grabs before executing the shit */ - if (hide) + if (!(state & ControlMask)) menu_frame_hide_all(); if (func) - func(entry, data); + func(entry, state, data); else { GSList *it; for (it = acts; it; it = g_slist_next(it)) - { - ObAction *act = it->data; - act->data.any.c = client; - - if (act->func == action_moveresize) - screen_pointer_pos(&act->data.moveresize.x, - &act->data.moveresize.y); - - if (!(act->func == action_cycle_windows || - act->func == action_desktop_dir || - act->func == action_send_to_desktop_dir || - act->func == action_showmenu)) - { - act->func(&act->data); - } - } + action_run(it->data, client, state); } } }