mirror of
https://github.com/roytam1/UXP.git
synced 2026-05-26 14:54:25 +00:00
Only disallow lazy frame construction for direct children of display: contents elements
This commit is contained in:
@@ -7021,8 +7021,11 @@ nsCSSFrameConstructor::MaybeConstructLazily(Operation aOperation,
|
||||
nsIContent* aContainer,
|
||||
nsIContent* aChild)
|
||||
{
|
||||
// XXXmats no lazy frames for display:contents direct descendants yet
|
||||
// (Mozilla bug 979782).
|
||||
if (mPresShell->GetPresContext()->IsChrome() || !aContainer ||
|
||||
aContainer->IsInNativeAnonymousSubtree() || aContainer->IsXULElement()) {
|
||||
aContainer->IsInNativeAnonymousSubtree() || aContainer->IsXULElement() ||
|
||||
GetDisplayContentsStyleFor(aContainer)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -7056,6 +7059,10 @@ nsCSSFrameConstructor::MaybeConstructLazily(Operation aOperation,
|
||||
// ignore anonymous children (eg framesets) make this complicated. So we set
|
||||
// these two booleans if we encounter these situations and unset them if we
|
||||
// hit a node with a leaf frame.
|
||||
//
|
||||
// Also, it's fine if one of the nodes without primary frame is a display:
|
||||
// contents node except if it's the direct ancestor of the children we're
|
||||
// recreating frames for.
|
||||
bool noPrimaryFrame = false;
|
||||
bool needsFrameBitSet = false;
|
||||
#endif
|
||||
@@ -7065,17 +7072,14 @@ nsCSSFrameConstructor::MaybeConstructLazily(Operation aOperation,
|
||||
if (content->GetPrimaryFrame() && content->GetPrimaryFrame()->IsLeaf()) {
|
||||
noPrimaryFrame = needsFrameBitSet = false;
|
||||
}
|
||||
if (!noPrimaryFrame && !content->GetPrimaryFrame()) {
|
||||
if (!noPrimaryFrame && !content->GetPrimaryFrame() &&
|
||||
!GetDisplayContentsStyleFor(content)) {
|
||||
noPrimaryFrame = true;
|
||||
}
|
||||
if (!needsFrameBitSet && content->HasFlag(NODE_NEEDS_FRAME)) {
|
||||
needsFrameBitSet = true;
|
||||
}
|
||||
#endif
|
||||
// XXXmats no lazy frames for display:contents descendants yet (bug 979782).
|
||||
if (GetDisplayContentsStyleFor(content)) {
|
||||
return false;
|
||||
}
|
||||
content->SetFlags(NODE_DESCENDANTS_NEED_FRAMES);
|
||||
content = content->GetFlattenedTreeParent();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user