mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-07 11:56:51 +00:00
Bug 1632706: When updating AccGroupInfo, If a sibling has cached group info, assume it's visible. r=MarcoZ
This avoids unnecessary calls to States(). Differential Revision: https://phabricator.services.mozilla.com/D72265
This commit is contained in:
parent
b8fbb6ead5
commit
122d48f2b2
@ -40,9 +40,16 @@ void AccGroupInfo::Update() {
|
||||
// If the sibling is separator then the group is ended.
|
||||
if (siblingRole == roles::SEPARATOR) break;
|
||||
|
||||
// If sibling is not visible and hasn't the same base role.
|
||||
if (BaseRole(siblingRole) != mRole || sibling->State() & states::INVISIBLE)
|
||||
if (BaseRole(siblingRole) != mRole) {
|
||||
continue;
|
||||
}
|
||||
bool siblingHasGroupInfo =
|
||||
sibling->mBits.groupInfo && !sibling->HasDirtyGroupInfo();
|
||||
// Skip invisible siblings.
|
||||
// If the sibling has calculated group info, that means it's visible.
|
||||
if (!siblingHasGroupInfo && sibling->State() & states::INVISIBLE) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// Check if it's hierarchical flatten structure, i.e. if the sibling
|
||||
// level is lesser than this one then group is ended, if the sibling level
|
||||
@ -59,7 +66,7 @@ void AccGroupInfo::Update() {
|
||||
|
||||
// If the previous item in the group has calculated group information then
|
||||
// build group information for this item based on found one.
|
||||
if (sibling->mBits.groupInfo && !sibling->HasDirtyGroupInfo()) {
|
||||
if (siblingHasGroupInfo) {
|
||||
mPosInSet += sibling->mBits.groupInfo->mPosInSet;
|
||||
mParent = sibling->mBits.groupInfo->mParent;
|
||||
mSetSize = sibling->mBits.groupInfo->mSetSize;
|
||||
@ -80,9 +87,16 @@ void AccGroupInfo::Update() {
|
||||
// If the sibling is separator then the group is ended.
|
||||
if (siblingRole == roles::SEPARATOR) break;
|
||||
|
||||
// If sibling is visible and has the same base role
|
||||
if (BaseRole(siblingRole) != mRole || sibling->State() & states::INVISIBLE)
|
||||
if (BaseRole(siblingRole) != mRole) {
|
||||
continue;
|
||||
}
|
||||
bool siblingHasGroupInfo =
|
||||
sibling->mBits.groupInfo && !sibling->HasDirtyGroupInfo();
|
||||
// Skip invisible siblings.
|
||||
// If the sibling has calculated group info, that means it's visible.
|
||||
if (!siblingHasGroupInfo && sibling->State() & states::INVISIBLE) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// and check if it's hierarchical flatten structure.
|
||||
int32_t siblingLevel = nsAccUtils::GetARIAOrDefaultLevel(sibling);
|
||||
@ -93,7 +107,7 @@ void AccGroupInfo::Update() {
|
||||
|
||||
// If the next item in the group has calculated group information then
|
||||
// build group information for this item based on found one.
|
||||
if (sibling->mBits.groupInfo && !sibling->HasDirtyGroupInfo()) {
|
||||
if (siblingHasGroupInfo) {
|
||||
mParent = sibling->mBits.groupInfo->mParent;
|
||||
mSetSize = sibling->mBits.groupInfo->mSetSize;
|
||||
return;
|
||||
|
Loading…
Reference in New Issue
Block a user