diff options
author | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-29 23:39:25 +0000 |
---|---|---|
committer | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-29 23:39:25 +0000 |
commit | c3a7368e76527e15c1f2d2f06801a371bb5374e3 (patch) | |
tree | c1aed1391f87dc6a3cb881efdd066622538ae530 /views/controls/menu | |
parent | 62e3b90b17781357161dd1e37d8dab99cb17b5c0 (diff) | |
download | chromium_src-c3a7368e76527e15c1f2d2f06801a371bb5374e3.zip chromium_src-c3a7368e76527e15c1f2d2f06801a371bb5374e3.tar.gz chromium_src-c3a7368e76527e15c1f2d2f06801a371bb5374e3.tar.bz2 |
Rework a loop in the native menu code to iterate over the vector of items we have, rather than the actual system menu.
I believe this may fix a crash where the code indexes out of bounds in the vector. The trouble is the assumption that the native menu index matches the index into the vector. If someone has installed a windows addon this may not be true. It's safer to restrict the iteration to the bounds of the vector and index into the menu based on that.
http://crbug.com/14600
TEST=none
Review URL: http://codereview.chromium.org/150061
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19558 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'views/controls/menu')
-rw-r--r-- | views/controls/menu/native_menu_win.cc | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/views/controls/menu/native_menu_win.cc b/views/controls/menu/native_menu_win.cc index 3ef158c..8de7621 100644 --- a/views/controls/menu/native_menu_win.cc +++ b/views/controls/menu/native_menu_win.cc @@ -346,16 +346,17 @@ void NativeMenuWin::Rebuild() { void NativeMenuWin::UpdateStates() { // A depth-first walk of the menu items, updating states. - for (int menu_index = first_item_index_; - menu_index < first_item_index_ + model_->GetItemCount(); ++menu_index) { - int model_index = menu_index - first_item_index_; + int model_index = 0; + std::vector<ItemData*>::const_iterator it; + for (it = items_.begin(); it != items_.end(); ++it, ++model_index) { + int menu_index = model_index + first_item_index_; SetMenuItemState(menu_index, model_->IsEnabledAt(model_index), model_->IsItemCheckedAt(model_index), false); if (model_->IsLabelDynamicAt(model_index)) { SetMenuItemLabel(menu_index, model_index, model_->GetLabelAt(model_index)); } - Menu2* submenu = items_[model_index]->submenu.get(); + Menu2* submenu = (*it)->submenu.get(); if (submenu) submenu->UpdateStates(); } |