Change logic for detecting whether two loads with the same URI (up to anchor)
are actually different to be smarter about dealing with postdata (both loads may have postdata and may be the same or different depending on what that post data is). Bug 227554, r=adamlock, sr=darin
This commit is contained in:
Родитель
1b20c441b4
Коммит
b68940b3af
|
@ -5106,11 +5106,24 @@ nsDocShell::InternalLoad(nsIURI * aURI,
|
|||
//
|
||||
// First:
|
||||
// Check to see if the new URI is an anchor in the existing document.
|
||||
// Skip this check if we're doing some sort of abnormal load, if
|
||||
// the new load is a non-history load and has postdata, or if
|
||||
// we're doing a history load and there are postdata differences
|
||||
// between what we plan to load and what we have loaded currently.
|
||||
//
|
||||
PRBool samePostData = PR_TRUE;
|
||||
if (!aSHEntry) {
|
||||
samePostData = (aPostData == nsnull);
|
||||
} else if (mOSHE) {
|
||||
nsCOMPtr<nsIInputStream> currentPostData;
|
||||
mOSHE->GetPostData(getter_AddRefs(currentPostData));
|
||||
samePostData = (currentPostData == aPostData);
|
||||
}
|
||||
|
||||
if ((aLoadType == LOAD_NORMAL ||
|
||||
aLoadType == LOAD_NORMAL_REPLACE ||
|
||||
aLoadType == LOAD_HISTORY ||
|
||||
aLoadType == LOAD_LINK) && (aPostData == nsnull)) {
|
||||
aLoadType == LOAD_LINK) && samePostData) {
|
||||
PRBool wasAnchor = PR_FALSE;
|
||||
nscoord cx, cy;
|
||||
NS_ENSURE_SUCCESS(ScrollIfAnchor(aURI, &wasAnchor, aLoadType, &cx, &cy), NS_ERROR_FAILURE);
|
||||
|
|
Загрузка…
Ссылка в новой задаче