Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(550)

Side by Side Diff: chrome/browser/ui/views/extensions/browser_action_overflow_menu_controller.cc

Issue 379483003: Fix use-after-free in BrowserActionOverflowMenuController (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/views/extensions/browser_action_overflow_menu_contro ller.h" 5 #include "chrome/browser/ui/views/extensions/browser_action_overflow_menu_contro ller.h"
6 6
7 #include "base/message_loop/message_loop.h" 7 #include "base/message_loop/message_loop.h"
8 #include "base/strings/utf_string_conversions.h" 8 #include "base/strings/utf_string_conversions.h"
9 #include "chrome/browser/extensions/extension_action.h" 9 #include "chrome/browser/extensions/extension_action.h"
10 #include "chrome/browser/extensions/extension_action_manager.h" 10 #include "chrome/browser/extensions/extension_action_manager.h"
(...skipping 12 matching lines...) Expand all
23 23
24 // In the browser actions container's chevron menu, a menu item view's icon 24 // In the browser actions container's chevron menu, a menu item view's icon
25 // comes from BrowserActionView::GetIconWithBadge() (which comes from the 25 // comes from BrowserActionView::GetIconWithBadge() (which comes from the
26 // browser action button's icon) when the menu item view is created. But, the 26 // browser action button's icon) when the menu item view is created. But, the
27 // browser action button's icon may not be loaded in time because it is read 27 // browser action button's icon may not be loaded in time because it is read
28 // from file system in another thread. 28 // from file system in another thread.
29 // The IconUpdater will update the menu item view's icon when the browser 29 // The IconUpdater will update the menu item view's icon when the browser
30 // action button's icon has been updated. 30 // action button's icon has been updated.
31 class IconUpdater : public BrowserActionButton::IconObserver { 31 class IconUpdater : public BrowserActionButton::IconObserver {
32 public: 32 public:
33 IconUpdater(views::MenuItemView* menu_item_view, 33 IconUpdater(views::MenuItemView* menu_item_view, BrowserActionButton* button)
34 BrowserActionButton* button)
35 : menu_item_view_(menu_item_view), 34 : menu_item_view_(menu_item_view),
36 button_(button) { 35 button_(button) {
37 DCHECK(menu_item_view); 36 DCHECK(menu_item_view);
38 DCHECK(button); 37 DCHECK(button);
39 button->set_icon_observer(this); 38 button->set_icon_observer(this);
40 } 39 }
41 virtual ~IconUpdater() { 40 virtual ~IconUpdater() {
42 button_->set_icon_observer(NULL); 41 button_->set_icon_observer(NULL);
43 } 42 }
44 43
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
121 // command. 120 // command.
122 base::MessageLoop::current()->DeleteSoon(FROM_HERE, this); 121 base::MessageLoop::current()->DeleteSoon(FROM_HERE, this);
123 } 122 }
124 return true; 123 return true;
125 } 124 }
126 125
127 void BrowserActionOverflowMenuController::CancelMenu() { 126 void BrowserActionOverflowMenuController::CancelMenu() {
128 menu_->Cancel(); 127 menu_->Cancel();
129 } 128 }
130 129
130 void BrowserActionOverflowMenuController::NotifyBrowserActionViewsDeleting() {
131 icon_updaters_.clear();
132 }
133
131 bool BrowserActionOverflowMenuController::IsCommandEnabled(int id) const { 134 bool BrowserActionOverflowMenuController::IsCommandEnabled(int id) const {
132 BrowserActionView* view = (*views_)[start_index_ + id - 1]; 135 BrowserActionView* view = (*views_)[start_index_ + id - 1];
133 return view->button()->IsEnabled(owner_->GetCurrentTabId()); 136 return view->button()->IsEnabled(owner_->GetCurrentTabId());
134 } 137 }
135 138
136 void BrowserActionOverflowMenuController::ExecuteCommand(int id) { 139 void BrowserActionOverflowMenuController::ExecuteCommand(int id) {
137 BrowserActionView* view = (*views_)[start_index_ + id - 1]; 140 BrowserActionView* view = (*views_)[start_index_ + id - 1];
138 owner_->OnBrowserActionExecuted(view->button()); 141 owner_->OnBrowserActionExecuted(view->button());
139 } 142 }
140 143
(...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after
261 264
262 BrowserActionView* BrowserActionOverflowMenuController::ViewForId( 265 BrowserActionView* BrowserActionOverflowMenuController::ViewForId(
263 int id, size_t* index) { 266 int id, size_t* index) {
264 // The index of the view being dragged (GetCommand gives a 1-based index into 267 // The index of the view being dragged (GetCommand gives a 1-based index into
265 // the overflow menu). 268 // the overflow menu).
266 size_t view_index = owner_->VisibleBrowserActions() + id - 1; 269 size_t view_index = owner_->VisibleBrowserActions() + id - 1;
267 if (index) 270 if (index)
268 *index = view_index; 271 *index = view_index;
269 return owner_->GetBrowserActionViewAt(view_index); 272 return owner_->GetBrowserActionViewAt(view_index);
270 } 273 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698