[LFC] LayoutContext::displayBoxForLayoutBox() should return a Display::Box&
[WebKit-https.git] / Source / WebCore / layout / inlineformatting / InlineFormattingContext.cpp
1 /*
2  * Copyright (C) 2018 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #include "config.h"
27 #include "InlineFormattingContext.h"
28
29 #if ENABLE(LAYOUT_FORMATTING_CONTEXT)
30
31 #include "FloatingState.h"
32 #include "InlineFormattingState.h"
33 #include "LayoutBox.h"
34 #include "LayoutContainer.h"
35 #include "LayoutContext.h"
36 #include "LayoutInlineBox.h"
37 #include "LayoutInlineContainer.h"
38 #include "Logging.h"
39 #include "SimpleLineBreaker.h"
40 #include "TextContentProvider.h"
41 #include <wtf/IsoMallocInlines.h>
42 #include <wtf/text/TextStream.h>
43
44 namespace WebCore {
45 namespace Layout {
46
47 WTF_MAKE_ISO_ALLOCATED_IMPL(InlineFormattingContext);
48
49 InlineFormattingContext::InlineFormattingContext(const Box& formattingContextRoot)
50     : FormattingContext(formattingContextRoot)
51 {
52 }
53
54 void InlineFormattingContext::layout(LayoutContext& layoutContext, FormattingState& inlineFormattingState) const
55 {
56     if (!is<Container>(root()))
57         return;
58
59     LOG_WITH_STREAM(FormattingContextLayout, stream << "[Start] -> inline formatting context -> layout context(" << &layoutContext << ") formatting root(" << &root() << ")");
60
61     TextContentProvider textContentProvider;
62     auto& formattingRoot = downcast<Container>(root());
63     auto* layoutBox = formattingRoot.firstInFlowOrFloatingChild();
64     // Casually walk through the block's descendants and place the inline boxes one after the other as much as we can (yeah, I am looking at you floats).
65     while (layoutBox) {
66         if (is<Container>(layoutBox)) {
67             ASSERT(is<InlineContainer>(layoutBox));
68             layoutBox = downcast<Container>(*layoutBox).firstInFlowOrFloatingChild();
69             continue;
70         }
71         auto& inlineBox = downcast<InlineBox>(*layoutBox);
72         // Only text content at this point.
73         if (inlineBox.textContent())
74             textContentProvider.appendText(*inlineBox.textContent(), inlineBox.style(), true);
75
76         for (; layoutBox; layoutBox = layoutBox->containingBlock()) {
77             if (layoutBox == &formattingRoot) {
78                 layoutBox = nullptr;
79                 break;
80             }
81             if (auto* nextSibling = layoutBox->nextInFlowOrFloatingSibling()) {
82                 layoutBox = nextSibling;
83                 break;
84             }
85         }
86         ASSERT(!layoutBox || layoutBox->isDescendantOf(formattingRoot));
87     }
88
89     auto& formattingRootDisplayBox = layoutContext.displayBoxForLayoutBox(formattingRoot);
90     auto lineLeft = formattingRootDisplayBox.contentBoxLeft();
91     auto lineRight = formattingRootDisplayBox.contentBoxRight();
92
93     SimpleLineBreaker::LineConstraintList constraints;
94     constraints.append({ { }, lineLeft, lineRight });
95     auto textRunList = textContentProvider.textRuns();
96     SimpleLineBreaker simpleLineBreaker(textRunList, textContentProvider, WTFMove(constraints), formattingRoot.style());
97
98     // Since we don't yet have a display tree context for inline boxes, let's just cache the runs on the state so that they can be verified against the sll/inline tree runs later.
99     ASSERT(is<InlineFormattingState>(inlineFormattingState));
100     downcast<InlineFormattingState>(inlineFormattingState).addLayoutRuns(simpleLineBreaker.runs());
101
102     LOG_WITH_STREAM(FormattingContextLayout, stream << "[End] -> inline formatting context -> layout context(" << &layoutContext << ") formatting root(" << &root() << ")");
103 }
104
105 void InlineFormattingContext::computeStaticPosition(LayoutContext&, const Box&) const
106 {
107 }
108
109 void InlineFormattingContext::computeInFlowPositionedPosition(LayoutContext&, const Box&) const
110 {
111 }
112
113 FormattingContext::InstrinsicWidthConstraints InlineFormattingContext::instrinsicWidthConstraints(LayoutContext&, const Box&) const
114 {
115     return { };
116 }
117
118 }
119 }
120
121 #endif