summaryrefslogtreecommitdiffstats
path: root/ui
diff options
context:
space:
mode:
authorgene@chromium.org <gene@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-08-08 00:33:40 +0000
committergene@chromium.org <gene@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-08-08 00:33:40 +0000
commit55ce288f21207b58778bbd39b171eb02ed62be95 (patch)
tree939e865b6478286704dcba891fa8cde307438abc /ui
parent7a801a64f1533207dcd591035c9ade1d8ddf144e (diff)
downloadchromium_src-55ce288f21207b58778bbd39b171eb02ed62be95.zip
chromium_src-55ce288f21207b58778bbd39b171eb02ed62be95.tar.gz
chromium_src-55ce288f21207b58778bbd39b171eb02ed62be95.tar.bz2
Fixed memory leak. Untangled confusing code with menu initialization and ownership.
BUG=141037 TEST=Make sure memory bots passed. Review URL: https://chromiumcodereview.appspot.com/10832184 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@150469 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ui')
-rw-r--r--ui/views/controls/button/button_dropdown.cc4
-rw-r--r--ui/views/controls/button/button_dropdown.h3
-rw-r--r--ui/views/view_unittest.cc3
3 files changed, 5 insertions, 5 deletions
diff --git a/ui/views/controls/button/button_dropdown.cc b/ui/views/controls/button/button_dropdown.cc
index 5ee98b3..236eca4 100644
--- a/ui/views/controls/button/button_dropdown.cc
+++ b/ui/views/controls/button/button_dropdown.cc
@@ -175,8 +175,8 @@ void ButtonDropDown::ShowDropDownMenu() {
menu_showing_ = true;
// Create and run menu. Display an empty menu if model is NULL.
- if (model_) {
- MenuModelAdapter menu_delegate(model_);
+ if (model_.get()) {
+ MenuModelAdapter menu_delegate(model_.get());
menu_delegate.set_triggerable_event_flags(triggerable_event_flags());
menu_runner_.reset(new MenuRunner(menu_delegate.CreateMenu()));
MenuRunner::RunResult result =
diff --git a/ui/views/controls/button/button_dropdown.h b/ui/views/controls/button/button_dropdown.h
index d58e640..8e57222 100644
--- a/ui/views/controls/button/button_dropdown.h
+++ b/ui/views/controls/button/button_dropdown.h
@@ -29,6 +29,7 @@ class VIEWS_EXPORT ButtonDropDown : public ImageButton {
// The button's class name.
static const char kViewClassName[];
+ // Takes ownership of the |model|.
ButtonDropDown(ButtonListener* listener, ui::MenuModel* model);
virtual ~ButtonDropDown();
@@ -67,7 +68,7 @@ class VIEWS_EXPORT ButtonDropDown : public ImageButton {
private:
// The model that populates the attached menu.
- ui::MenuModel* model_;
+ scoped_ptr<ui::MenuModel> model_;
// Indicates if menu is currently showing.
bool menu_showing_;
diff --git a/ui/views/view_unittest.cc b/ui/views/view_unittest.cc
index ef607be..3759915 100644
--- a/ui/views/view_unittest.cc
+++ b/ui/views/view_unittest.cc
@@ -1762,7 +1762,7 @@ class ButtonDropDownTest : public ViewTest {
virtual void SetUp() OVERRIDE {
ViewTest::SetUp();
- test_dialog_ = new TestDialog(&mock_menu_model_);
+ test_dialog_ = new TestDialog(new MockMenuModel());
Widget* window =
Widget::CreateWindowWithBounds(test_dialog_, gfx::Rect(0, 0, 100, 100));
test_dialog_->widget_ = window;
@@ -1779,7 +1779,6 @@ class ButtonDropDownTest : public ViewTest {
}
TestDialog* test_dialog_;
- MockMenuModel mock_menu_model_;
// This is owned by test_dialog_.
View* button_as_view_;