Closed Bug 728908 Opened 13 years ago Closed 13 years ago

Make the Overflow lines property have a nsFrameList

Categories

(Core :: Layout: Block and Inline, defect)

defect
Not set
normal

Tracking

()

RESOLVED FIXED
mozilla13

People

(Reporter: MatsPalmgren_bugz, Assigned: MatsPalmgren_bugz)

References

Details

(Whiteboard: [inbound])

Attachments

(2 files, 1 obsolete file)

There's a number of nice things that falls out from this -- removing *all* line->LastChild() calls and some SetNextSibling() calls, and to support GetChildList() returning const nsFrameList&. The bad thing is that it uses memory for an extra nsFrameList per block, if the block has overflow lines. I think it's rare that it has, and it's transient - when the block is fully reflowed the property will have been deleted.
Attached patch part 1, overflow lines (obsolete) (deleted) — Splinter Review
Assignee: nobody → matspal
Attachment #598899 - Flags: review?(bzbarsky)
Attachment #598900 - Flags: review?(bzbarsky)
> removing some SetNextSibling() calls Well, all SetNextSibling() calls in nsBlockFrame.cpp, since they are illegal here now, but there's still a few SetNextSibling() elsewhere in the code is what I meant...
Comment on attachment 598899 [details] [diff] [review] part 1, overflow lines > nsBlockFrame::PushLines(nsBlockReflowState& aState, > nsLineList::iterator aLineBefore) > { >+ // NOTE: aLineBefore is always a normal line, not an overflow line. >+ // The following expression will assert otherwise. >+ DebugOnly<bool> check = aLineBefore == mLines.begin(); >+ What's asserting here?
"comparing iterators over different lists"
Comment on attachment 598900 [details] [diff] [review] part 2, make nsLineBox::LastChild() DEBUG-only Nice.
Attachment #598900 - Flags: review?(bzbarsky) → review+
Comment on attachment 598899 [details] [diff] [review] part 1, overflow lines >+++ b/layout/generic/nsBlockFrame.cpp >+ FrameLines* overflowLines = RemoveOverflowLines(); > if (overflowLines) { >- nsLineBox::DeleteLineList(presContext, *overflowLines, aDestructRoot); >+ nsLineBox::DeleteLineList(presContext, overflowLines->mLines, >+ aDestructRoot); > delete overflowLines; Should there be an assert that overflowLines->mFrames is empty? >+RemoveFirstLine(nsLineList* aFromLines, nsFrameList* aFromFrames, Make the in parameters non-const references, please? And document what the return value means (specifically, whether aFromLines is empty after this call). > nsBlockFrame::DrainOverflowLines() >+ for (nsFrameList::Enumerator e(overflowLines->mFrames); >+ !e.AtEnd(); e.Next()) { >+ ReparentFrame(e.get(), prevBlock, this); This can use your new ReparentFrames method. >+ for (nsFrameList::Enumerator e(oofs.mList); !e.AtEnd(); e.Next()) { >+ ReparentFrame(e.get(), prevBlock, this); This too. r=me. Looks nice!
Attachment #598899 - Flags: review?(bzbarsky) → review+
Attached patch part 1, overflow lines (deleted) — Splinter Review
(In reply to Boris Zbarsky (:bz) from comment #7) > >- nsLineBox::DeleteLineList(presContext, *overflowLines, aDestructRoot); > >+ nsLineBox::DeleteLineList(presContext, overflowLines->mLines, > >+ aDestructRoot); > > delete overflowLines; > > Should there be an assert that overflowLines->mFrames is empty? overflowLines->mFrames is invalid at this point because DeleteLineList use SetNextSibling. http://mxr.mozilla.org/mozilla-central/source/layout/generic/nsLineBox.cpp#341 I'll file a follow-up bug on fixing that (passing the frame list too probably) Fixed your other comments as suggested.
Attachment #598899 - Attachment is obsolete: true
Blocks: 733991
Whiteboard: [inbound]
Target Milestone: --- → mozilla13
Depends on: 734777
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: