Bug 877097: Check that the scrollable frame is still alive after each call to SetOpacityOnElement for the two scrollbars to avoid crashing. r=roc

This commit is contained in:
Stephen Pohl 2013-06-08 14:05:33 -07:00
parent d8379b657e
commit 800328cc02
2 changed files with 15 additions and 3 deletions

View File

@ -104,7 +104,9 @@ ScrollbarActivity::WillRefresh(TimeStamp aTime)
NS_ASSERTION(!IsActivityOngoing(), "why weren't we unregistered from the refresh driver when scrollbar activity started?");
NS_ASSERTION(mIsFading, "should only animate fading during fade");
UpdateOpacity(aTime);
if (!UpdateOpacity(aTime)) {
return;
}
if (!IsStillFading(aTime)) {
EndFade();
@ -304,13 +306,23 @@ SetOpacityOnElement(nsIContent* aContent, double aOpacity)
}
}
void
bool
ScrollbarActivity::UpdateOpacity(TimeStamp aTime)
{
double progress = (aTime - mFadeBeginTime) / FadeDuration();
double opacity = 1.0 - std::max(0.0, std::min(1.0, progress));
// 'this' may be getting destroyed during SetOpacityOnElement calls.
nsWeakFrame weakFrame((do_QueryFrame(mScrollableFrame)));
SetOpacityOnElement(GetHorizontalScrollbar(), opacity);
if (!weakFrame.IsAlive()) {
return false;
}
SetOpacityOnElement(GetVerticalScrollbar(), opacity);
if (!weakFrame.IsAlive()) {
return false;
}
return true;
}
static void

View File

@ -114,7 +114,7 @@ protected:
void RegisterWithRefreshDriver();
void UnregisterFromRefreshDriver();
void UpdateOpacity(TimeStamp aTime);
bool UpdateOpacity(TimeStamp aTime); // returns false if 'this' was destroyed
void HoveredScrollbar(nsIContent* aScrollbar);
nsRefreshDriver* GetRefreshDriver();