diff options
author | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-19 23:01:28 +0000 |
---|---|---|
committer | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-19 23:01:28 +0000 |
commit | f785ad125747f9125c952c7e74f2154098ee15a9 (patch) | |
tree | 69f59438f60dc382d7159d25e2cd34320b71c3c3 /chrome/views/chrome_menu.h | |
parent | ec322ff6c39bf30e9b3c1eb878a95507029c6002 (diff) | |
download | chromium_src-f785ad125747f9125c952c7e74f2154098ee15a9.zip chromium_src-f785ad125747f9125c952c7e74f2154098ee15a9.tar.gz chromium_src-f785ad125747f9125c952c7e74f2154098ee15a9.tar.bz2 |
Fixes crash when showing modal dialog from context menu. With this
sequence ContainerWin remains on the stack while the modal dialog is
showing. Prior to this fix we would delete the ContainerWin, so that
when the modal dialog closed control would return to a deleted
object. The fix is to effectively delay deleting of the ConatinerWins
used by menus.
BUG=4580
TEST=This is the sequence that triggered the crash: open a folder on
the bookmark bar, right child on a child folder that has more than 15
descendant URLs, click open all, a dialog should appear asking if you
really want to open all, click cancel and make sure it doesn't crash.
This is a subtle change to bookmark menus though, would be good to
thoroughly exercise the menus in as many permutations as you can
think of.
Review URL: http://codereview.chromium.org/11289
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@5724 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/views/chrome_menu.h')
-rw-r--r-- | chrome/views/chrome_menu.h | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/chrome/views/chrome_menu.h b/chrome/views/chrome_menu.h index a92a45c..dd17a84 100644 --- a/chrome/views/chrome_menu.h +++ b/chrome/views/chrome_menu.h @@ -528,14 +528,25 @@ class SubmenuView : public View { virtual bool OnMouseWheel(const MouseWheelEvent& e); // Returns true if the menu is showing. - bool IsShowing() const { return (host_ != NULL); } + bool IsShowing(); // Shows the menu at the specified location. Coordinates are in screen // coordinates. max_width gives the max width the view should be. void ShowAt(HWND parent, const gfx::Rect& bounds, bool do_capture); - // Closes the menu. If destroy_host is true, the host is deleted. - void Close(bool destroy_host); + // Closes the menu, destroying the host. + void Close(); + + // Hides the hosting window. + // + // The hosting window is hidden first, then deleted (Close) when the menu is + // done running. This is done to avoid deletion ordering dependencies. In + // particular, during drag and drop (and when a modal dialog is shown as + // a result of choosing a context menu) it is possible that an event is + // being processed by the host, so that host is on the stack when we need to + // close the window. If we closed the window immediately (and deleted it), + // when control returned back to host we would crash as host was deleted. + void Hide(); // If mouse capture was grabbed, it is released. Does nothing if mouse was // not captured. @@ -921,18 +932,6 @@ class MenuController : public MessageLoopForUI::Dispatcher { int drop_y_; int last_drop_operation_; - // If true, we've invoked DoDrag on the delegate. - // - // This is used to determine whether the windows used to show menus - // are hidden or destroyed. As drag and drop is initiated during a - // mouse gesture, and the call to initiate the drag is blocking, we - // can't destroy the window immediately (otherwise when the drag and - // drop call returns the window that initiated the call and is on - // the stack has been deleted). During drag and drop (in_drag_ is - // true) windows are hidden, once the drag and drop call completes - // MenuItemView takes care of destroying the windows. - bool in_drag_; - // If true, the mouse is over some menu. bool any_menu_contains_mouse_; |