1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* vim: set ts=8 sts=2 et sw=2 tw=80: */
3 /* This Source Code Form is subject to the terms of the Mozilla Public
4 * License, v. 2.0. If a copy of the MPL was not distributed with this
5 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
7 /* rendering object for CSS display:inline objects */
9 #ifndef nsInlineFrame_h___
10 #define nsInlineFrame_h___
12 #include "mozilla/Attributes.h"
13 #include "nsContainerFrame.h"
19 } // namespace mozilla
24 * This class manages a list of child frames that are inline frames. Working
25 * with nsLineLayout, the class will reflow and place inline frames on a line.
27 class nsInlineFrame
: public nsContainerFrame
{
30 NS_DECL_FRAMEARENA_HELPERS(nsInlineFrame
)
32 friend nsInlineFrame
* NS_NewInlineFrame(mozilla::PresShell
* aPresShell
,
33 ComputedStyle
* aStyle
);
36 virtual void BuildDisplayList(nsDisplayListBuilder
* aBuilder
,
37 const nsDisplayListSet
& aLists
) override
;
40 virtual mozilla::a11y::AccType
AccessibleType() override
;
43 #ifdef DEBUG_FRAME_DUMP
44 virtual nsresult
GetFrameName(nsAString
& aResult
) const override
;
47 virtual bool IsFrameOfType(uint32_t aFlags
) const override
{
48 if (aFlags
& (eSupportsCSSTransforms
| eSupportsContainLayoutAndPaint
|
49 eSupportsAspectRatio
)) {
52 return nsContainerFrame::IsFrameOfType(
54 ~(nsIFrame::eBidiInlineContainer
| nsIFrame::eLineParticipant
));
57 virtual void InvalidateFrame(uint32_t aDisplayItemKey
= 0,
58 bool aRebuildDisplayItems
= true) override
;
59 virtual void InvalidateFrameWithRect(
60 const nsRect
& aRect
, uint32_t aDisplayItemKey
= 0,
61 bool aRebuildDisplayItems
= true) override
;
63 virtual bool IsEmpty() override
;
64 virtual bool IsSelfEmpty() override
;
66 virtual FrameSearchResult
PeekOffsetCharacter(
67 bool aForward
, int32_t* aOffset
,
68 PeekOffsetCharacterOptions aOptions
=
69 PeekOffsetCharacterOptions()) override
;
71 virtual void DestroyFrom(nsIFrame
* aDestructRoot
,
72 PostDestroyData
& aPostDestroyData
) override
;
73 void StealFrame(nsIFrame
* aChild
) override
;
75 // nsIHTMLReflow overrides
76 virtual void AddInlineMinISize(gfxContext
* aRenderingContext
,
77 InlineMinISizeData
* aData
) override
;
78 virtual void AddInlinePrefISize(gfxContext
* aRenderingContext
,
79 InlinePrefISizeData
* aData
) override
;
80 SizeComputationResult
ComputeSize(
81 gfxContext
* aRenderingContext
, mozilla::WritingMode aWM
,
82 const mozilla::LogicalSize
& aCBSize
, nscoord aAvailableISize
,
83 const mozilla::LogicalSize
& aMargin
,
84 const mozilla::LogicalSize
& aBorderPadding
,
85 const mozilla::StyleSizeOverrides
& aSizeOverrides
,
86 mozilla::ComputeSizeFlags aFlags
) override
;
87 virtual nsRect
ComputeTightBounds(DrawTarget
* aDrawTarget
) const override
;
88 virtual void Reflow(nsPresContext
* aPresContext
, ReflowOutput
& aDesiredSize
,
89 const ReflowInput
& aReflowInput
,
90 nsReflowStatus
& aStatus
) override
;
92 virtual nsresult
AttributeChanged(int32_t aNameSpaceID
, nsAtom
* aAttribute
,
93 int32_t aModType
) override
;
95 virtual bool CanContinueTextRun() const override
;
97 virtual void PullOverflowsFromPrevInFlow() override
;
98 virtual nscoord
GetLogicalBaseline(
99 mozilla::WritingMode aWritingMode
) const override
;
100 virtual bool DrainSelfOverflowList() override
;
103 * Return true if the frame is first visual frame or first continuation
105 bool IsFirst() const {
106 // If the frame's bidi visual state is set, return is-first state
107 // else return true if it's the first continuation.
108 return HasAnyStateBits(NS_INLINE_FRAME_BIDI_VISUAL_STATE_IS_SET
)
109 ? HasAnyStateBits(NS_INLINE_FRAME_BIDI_VISUAL_IS_FIRST
)
114 * Return true if the frame is last visual frame or last continuation.
116 bool IsLast() const {
117 // If the frame's bidi visual state is set, return is-last state
118 // else return true if it's the last continuation.
119 return HasAnyStateBits(NS_INLINE_FRAME_BIDI_VISUAL_STATE_IS_SET
)
120 ? HasAnyStateBits(NS_INLINE_FRAME_BIDI_VISUAL_IS_LAST
)
124 // Restyles the block wrappers around our non-inline-outside kids.
125 // This will only be called when such wrappers in fact exist.
126 void UpdateStyleOfOwnedAnonBoxesForIBSplit(
127 mozilla::ServoRestyleState
& aRestyleState
);
130 // Additional reflow input used during our reflow methods
131 struct InlineReflowInput
{
132 nsIFrame
* mPrevFrame
;
133 nsInlineFrame
* mNextInFlow
;
134 nsIFrame
* mLineContainer
;
135 nsLineLayout
* mLineLayout
;
136 bool mSetParentPointer
; // when reflowing child frame first set its
137 // parent frame pointer
139 InlineReflowInput() {
140 mPrevFrame
= nullptr;
141 mNextInFlow
= nullptr;
142 mLineContainer
= nullptr;
143 mLineLayout
= nullptr;
144 mSetParentPointer
= false;
148 nsInlineFrame(ComputedStyle
* aStyle
, nsPresContext
* aPresContext
, ClassID aID
)
149 : nsContainerFrame(aStyle
, aPresContext
, aID
),
150 mBaseline(NS_INTRINSIC_ISIZE_UNKNOWN
) {}
152 LogicalSides
GetLogicalSkipSides() const override
;
154 void ReflowFrames(nsPresContext
* aPresContext
,
155 const ReflowInput
& aReflowInput
, InlineReflowInput
& rs
,
156 ReflowOutput
& aMetrics
, nsReflowStatus
& aStatus
);
158 void ReflowInlineFrame(nsPresContext
* aPresContext
,
159 const ReflowInput
& aReflowInput
, InlineReflowInput
& rs
,
160 nsIFrame
* aFrame
, nsReflowStatus
& aStatus
);
162 // Returns whether there's any frame that PullOneFrame would pull from
163 // aNextInFlow or any of aNextInFlow's next-in-flows.
164 static bool HasFramesToPull(nsInlineFrame
* aNextInFlow
);
166 virtual nsIFrame
* PullOneFrame(nsPresContext
*, InlineReflowInput
&);
168 virtual void PushFrames(nsPresContext
* aPresContext
, nsIFrame
* aFromChild
,
169 nsIFrame
* aPrevSibling
, InlineReflowInput
& aState
);
172 explicit nsInlineFrame(ComputedStyle
* aStyle
, nsPresContext
* aPresContext
)
173 : nsInlineFrame(aStyle
, aPresContext
, kClassID
) {}
176 * Move any frames on our overflow list to the end of our principal list.
177 * @param aInFirstLine whether we're in a first-line frame.
178 * @return true if there were any overflow frames
180 bool DrainSelfOverflowListInternal(bool aInFirstLine
);
186 //----------------------------------------------------------------------
189 * Variation on inline-frame used to manage lines for line layout in
190 * special situations (:first-line style in particular).
192 class nsFirstLineFrame final
: public nsInlineFrame
{
194 NS_DECL_FRAMEARENA_HELPERS(nsFirstLineFrame
)
196 friend nsFirstLineFrame
* NS_NewFirstLineFrame(mozilla::PresShell
* aPresShell
,
197 ComputedStyle
* aStyle
);
199 #ifdef DEBUG_FRAME_DUMP
200 virtual nsresult
GetFrameName(nsAString
& aResult
) const override
;
202 virtual void Reflow(nsPresContext
* aPresContext
, ReflowOutput
& aDesiredSize
,
203 const ReflowInput
& aReflowInput
,
204 nsReflowStatus
& aStatus
) override
;
206 virtual void Init(nsIContent
* aContent
, nsContainerFrame
* aParent
,
207 nsIFrame
* aPrevInFlow
) override
;
208 virtual void PullOverflowsFromPrevInFlow() override
;
209 virtual bool DrainSelfOverflowList() override
;
212 explicit nsFirstLineFrame(ComputedStyle
* aStyle
, nsPresContext
* aPresContext
)
213 : nsInlineFrame(aStyle
, aPresContext
, kClassID
) {}
215 nsIFrame
* PullOneFrame(nsPresContext
*, InlineReflowInput
&) override
;
218 #endif /* nsInlineFrame_h___ */