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

Side by Side Diff: views/animation/bounds_animator.cc

Issue 1512021: Revert 43692 - Adds some debugging info in hopes of tracking leak in... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 10 years, 8 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 | Annotate | Revision Log
« no previous file with comments | « tools/valgrind/memcheck/suppressions.txt ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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 "views/animation/bounds_animator.h" 5 #include "views/animation/bounds_animator.h"
6 6
7 #include "app/slide_animation.h" 7 #include "app/slide_animation.h"
8 #include "base/scoped_ptr.h" 8 #include "base/scoped_ptr.h"
9 #include "views/view.h" 9 #include "views/view.h"
10 10
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 animation->Show(); 80 animation->Show();
81 } 81 }
82 82
83 const SlideAnimation* BoundsAnimator::GetAnimationForView(View* view) { 83 const SlideAnimation* BoundsAnimator::GetAnimationForView(View* view) {
84 return data_.find(view) == data_.end() ? NULL : data_[view].animation; 84 return data_.find(view) == data_.end() ? NULL : data_[view].animation;
85 } 85 }
86 86
87 void BoundsAnimator::SetAnimationDelegate(View* view, 87 void BoundsAnimator::SetAnimationDelegate(View* view,
88 AnimationDelegate* delegate, 88 AnimationDelegate* delegate,
89 bool delete_when_done) { 89 bool delete_when_done) {
90 #if defined(OS_LINUX)
91 if (!IsAnimating(view))
92 LOG(ERROR) << "SetAnimationDelegate: not animating view";
93 if (data_[view].delegate)
94 LOG(ERROR) << "SetAnimationDelegate: delegate already set: leaking";
95 #endif
96
97 DCHECK(IsAnimating(view)); 90 DCHECK(IsAnimating(view));
98 data_[view].delegate = delegate; 91 data_[view].delegate = delegate;
99 data_[view].delete_delegate_when_done = delete_when_done; 92 data_[view].delete_delegate_when_done = delete_when_done;
100 } 93 }
101 94
102 void BoundsAnimator::StopAnimatingView(View* view) { 95 void BoundsAnimator::StopAnimatingView(View* view) {
103 if (data_.find(view) == data_.end()) 96 if (data_.find(view) == data_.end())
104 return; 97 return;
105 98
106 data_[view].animation->Stop(); 99 data_[view].animation->Stop();
107 } 100 }
108 101
109 bool BoundsAnimator::IsAnimating(View* view) const { 102 bool BoundsAnimator::IsAnimating(View* view) const {
110 return data_.find(view) != data_.end(); 103 return data_.find(view) != data_.end();
111 } 104 }
112 105
113 bool BoundsAnimator::IsAnimating() const { 106 bool BoundsAnimator::IsAnimating() const {
114 return !data_.empty(); 107 return !data_.empty();
115 } 108 }
116 109
117 void BoundsAnimator::Cancel() { 110 void BoundsAnimator::Cancel() {
118 if (data_.empty()) 111 if (data_.empty())
119 return; 112 return;
120 113
121 #if defined(OS_LINUX)
122 LOG(ERROR) << "Cancelling animations";
123 #endif
124
125 while (!data_.empty()) 114 while (!data_.empty())
126 data_.begin()->second.animation->Stop(); 115 data_.begin()->second.animation->Stop();
127 116
128 // Invoke AnimationContainerProgressed to force a repaint and notify delegate. 117 // Invoke AnimationContainerProgressed to force a repaint and notify delegate.
129 AnimationContainerProgressed(container_.get()); 118 AnimationContainerProgressed(container_.get());
130 } 119 }
131 120
132 SlideAnimation* BoundsAnimator::CreateAnimation() { 121 SlideAnimation* BoundsAnimator::CreateAnimation() {
133 SlideAnimation* animation = new SlideAnimation(this); 122 SlideAnimation* animation = new SlideAnimation(this);
134 animation->SetContainer(container_.get()); 123 animation->SetContainer(container_.get());
(...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after
235 // Notify here rather than from AnimationXXX to avoid deleting the animation 224 // Notify here rather than from AnimationXXX to avoid deleting the animation
236 // while the animaion is calling us. 225 // while the animaion is calling us.
237 observer_->OnBoundsAnimatorDone(this); 226 observer_->OnBoundsAnimatorDone(this);
238 } 227 }
239 } 228 }
240 229
241 void BoundsAnimator::AnimationContainerEmpty(AnimationContainer* container) { 230 void BoundsAnimator::AnimationContainerEmpty(AnimationContainer* container) {
242 } 231 }
243 232
244 } // namespace views 233 } // namespace views
OLDNEW
« no previous file with comments | « tools/valgrind/memcheck/suppressions.txt ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698