mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-10 11:55:49 +00:00
Bug 309099. Entire client area should not be repainted for each focus move. Patch by Robert O'Callahan (roc). r=aaronlev, sr=neil
This commit is contained in:
parent
159e0a2eab
commit
67ee0e846e
@ -2476,6 +2476,12 @@ nsDocShell::GetChildAt(PRInt32 aIndex, nsIDocShellTreeItem ** aChild)
|
|||||||
|
|
||||||
NS_WARN_IF_FALSE(aIndex >=0 && aIndex < mChildList.Count(),
|
NS_WARN_IF_FALSE(aIndex >=0 && aIndex < mChildList.Count(),
|
||||||
"index of child element is out of range!");
|
"index of child element is out of range!");
|
||||||
|
if (aIndex < 0) {
|
||||||
|
printf("Don't be so negative!");
|
||||||
|
}
|
||||||
|
else if (aIndex >= mChildList.Count()) {
|
||||||
|
printf("Don't be so unrealistic!");
|
||||||
|
}
|
||||||
|
|
||||||
nsIDocumentLoader* child = SafeChildAt(aIndex);
|
nsIDocumentLoader* child = SafeChildAt(aIndex);
|
||||||
NS_ENSURE_TRUE(child, NS_ERROR_UNEXPECTED);
|
NS_ENSURE_TRUE(child, NS_ERROR_UNEXPECTED);
|
||||||
@ -8345,16 +8351,8 @@ nsDocShell::SetCanvasHasFocus(PRBool aCanvasHasFocus)
|
|||||||
frame = frame->GetParent();
|
frame = frame->GetParent();
|
||||||
if (frame) {
|
if (frame) {
|
||||||
nsICanvasFrame* canvasFrame;
|
nsICanvasFrame* canvasFrame;
|
||||||
if (NS_SUCCEEDED(frame->QueryInterface(NS_GET_IID(nsICanvasFrame), (void**)&canvasFrame))) {
|
if (NS_SUCCEEDED(frame->QueryInterface(NS_GET_IID(nsICanvasFrame), (void**)&canvasFrame)))
|
||||||
canvasFrame->SetHasFocus(aCanvasHasFocus);
|
return canvasFrame->SetHasFocus(aCanvasHasFocus);
|
||||||
|
|
||||||
nsIViewManager* vm = presShell->GetViewManager();
|
|
||||||
if (vm) {
|
|
||||||
vm->UpdateAllViews(NS_VMREFRESH_NO_SYNC);
|
|
||||||
}
|
|
||||||
|
|
||||||
return NS_OK;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NS_ERROR_FAILURE;
|
return NS_ERROR_FAILURE;
|
||||||
|
@ -127,7 +127,7 @@ public:
|
|||||||
NS_IMETHOD ScrollPositionDidChange(nsIScrollableView* aScrollable, nscoord aX, nscoord aY);
|
NS_IMETHOD ScrollPositionDidChange(nsIScrollableView* aScrollable, nscoord aX, nscoord aY);
|
||||||
|
|
||||||
// nsICanvasFrame
|
// nsICanvasFrame
|
||||||
NS_IMETHOD SetHasFocus(PRBool aHasFocus) { mDoPaintFocus = aHasFocus; return NS_OK; }
|
NS_IMETHOD SetHasFocus(PRBool aHasFocus);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the "type" of the frame
|
* Get the "type" of the frame
|
||||||
@ -263,6 +263,19 @@ CanvasFrame::ScrollPositionDidChange(nsIScrollableView* aScrollable, nscoord aX,
|
|||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NS_IMETHODIMP
|
||||||
|
CanvasFrame::SetHasFocus(PRBool aHasFocus)
|
||||||
|
{
|
||||||
|
if (mDoPaintFocus != aHasFocus) {
|
||||||
|
mDoPaintFocus = aHasFocus;
|
||||||
|
nsIViewManager* vm = GetPresContext()->PresShell()->GetViewManager();
|
||||||
|
if (vm) {
|
||||||
|
vm->UpdateAllViews(NS_VMREFRESH_NO_SYNC);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NS_OK;
|
||||||
|
}
|
||||||
|
|
||||||
NS_IMETHODIMP
|
NS_IMETHODIMP
|
||||||
CanvasFrame::AppendFrames(nsIAtom* aListName,
|
CanvasFrame::AppendFrames(nsIAtom* aListName,
|
||||||
nsIFrame* aFrameList)
|
nsIFrame* aFrameList)
|
||||||
|
Loading…
Reference in New Issue
Block a user