Index: ui/views/controls/menu/menu_event_dispatcher_linux.cc |
diff --git a/ui/views/controls/menu/menu_event_dispatcher_linux.cc b/ui/views/controls/menu/menu_event_dispatcher_linux.cc |
index 716c6bb51bb3f0bd167f87f8ab58b9d64ed4f3ff..6985cd9c1ac6b5505b71282aef3ea4589c3d78db 100644 |
--- a/ui/views/controls/menu/menu_event_dispatcher_linux.cc |
+++ b/ui/views/controls/menu/menu_event_dispatcher_linux.cc |
@@ -22,35 +22,49 @@ bool MenuEventDispatcher::CanDispatchEvent(const ui::PlatformEvent& event) { |
} |
uint32_t MenuEventDispatcher::DispatchEvent(const ui::PlatformEvent& event) { |
+ bool should_quit = false; |
+ bool should_perform_default = true; |
if (menu_controller_->exit_type() == MenuController::EXIT_ALL || |
- menu_controller_->exit_type() == MenuController::EXIT_DESTROYED) |
- return (ui::POST_DISPATCH_QUIT_LOOP | ui::POST_DISPATCH_PERFORM_DEFAULT); |
- |
- switch (ui::EventTypeFromNative(event)) { |
- case ui::ET_KEY_PRESSED: { |
- if (!menu_controller_->OnKeyDown(ui::KeyboardCodeFromNative(event))) |
- return ui::POST_DISPATCH_QUIT_LOOP; |
- |
- // Do not check mnemonics if the Alt or Ctrl modifiers are pressed. |
- int flags = ui::EventFlagsFromNative(event); |
- if ((flags & (ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN)) == 0) { |
- char c = ui::GetCharacterFromKeyCode(ui::KeyboardCodeFromNative(event), |
- flags); |
- if (menu_controller_->SelectByChar(c)) |
- return ui::POST_DISPATCH_QUIT_LOOP; |
+ menu_controller_->exit_type() == MenuController::EXIT_DESTROYED) { |
+ should_quit = true; |
+ } else { |
+ switch (ui::EventTypeFromNative(event)) { |
+ case ui::ET_KEY_PRESSED: { |
+ if (!menu_controller_->OnKeyDown(ui::KeyboardCodeFromNative(event))) { |
+ should_quit = true; |
+ should_perform_default = false; |
+ break; |
+ } |
+ |
+ // Do not check mnemonics if the Alt or Ctrl modifiers are pressed. |
+ int flags = ui::EventFlagsFromNative(event); |
+ if ((flags & (ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN)) == 0) { |
+ char c = ui::GetCharacterFromKeyCode( |
+ ui::KeyboardCodeFromNative(event), flags); |
+ if (menu_controller_->SelectByChar(c)) { |
+ should_quit = true; |
+ should_perform_default = false; |
+ break; |
+ } |
+ } |
+ should_quit = false; |
+ should_perform_default = false; |
+ break; |
} |
- return ui::POST_DISPATCH_NONE; |
+ case ui::ET_KEY_RELEASED: |
+ should_quit = false; |
+ should_perform_default = false; |
+ break; |
+ default: |
+ break; |
} |
- case ui::ET_KEY_RELEASED: |
- return ui::POST_DISPATCH_NONE; |
- default: |
- break; |
} |
- return ui::POST_DISPATCH_PERFORM_DEFAULT | |
- (menu_controller_->exit_type() == MenuController::EXIT_NONE |
- ? ui::POST_DISPATCH_NONE |
- : ui::POST_DISPATCH_QUIT_LOOP); |
+ if (should_quit || menu_controller_->exit_type() != MenuController::EXIT_NONE) |
+ menu_controller_->TerminateNestedMessageLoop(); |
+ |
+ return should_perform_default ? ui::POST_DISPATCH_PERFORM_DEFAULT |
+ : ui::POST_DISPATCH_NONE; |
} |
} // namespace internal |