Reset performance object on navigation.
This commit is contained in:
parent
ec5b99da7e
commit
fdec53dc93
|
@ -3224,6 +3224,12 @@ nsGlobalWindow::SetNewDocument(nsIDocument* aDocument,
|
||||||
newInnerWindow->mLocalStorage = nullptr;
|
newInnerWindow->mLocalStorage = nullptr;
|
||||||
newInnerWindow->mSessionStorage = nullptr;
|
newInnerWindow->mSessionStorage = nullptr;
|
||||||
|
|
||||||
|
newInnerWindow->mPerformance = nullptr;
|
||||||
|
|
||||||
|
// This must be called after nulling the internal objects because
|
||||||
|
// we might recreate them here by calling the getter methods, and
|
||||||
|
// store them into the JS slots. If we null them after, the slot
|
||||||
|
// values and the objects will be out of sync.
|
||||||
newInnerWindow->ClearDocumentDependentSlots(cx);
|
newInnerWindow->ClearDocumentDependentSlots(cx);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -3364,10 +3370,16 @@ nsGlobalWindow::InnerSetNewDocument(JSContext* aCx, nsIDocument* aDocument)
|
||||||
}
|
}
|
||||||
|
|
||||||
mDoc = aDocument;
|
mDoc = aDocument;
|
||||||
ClearDocumentDependentSlots(aCx);
|
|
||||||
mFocusedNode = nullptr;
|
mFocusedNode = nullptr;
|
||||||
mLocalStorage = nullptr;
|
mLocalStorage = nullptr;
|
||||||
mSessionStorage = nullptr;
|
mSessionStorage = nullptr;
|
||||||
|
mPerformance = nullptr;
|
||||||
|
|
||||||
|
// This must be called after nulling the internal objects because we might
|
||||||
|
// recreate them here by calling the getter methods, and store them into the JS
|
||||||
|
// slots. If we null them after, the slot values and the objects will be
|
||||||
|
// out of sync.
|
||||||
|
ClearDocumentDependentSlots(aCx);
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
mLastOpenedURI = aDocument->GetDocumentURI();
|
mLastOpenedURI = aDocument->GetDocumentURI();
|
||||||
|
|
Loading…
Reference in New Issue
Block a user