Replace WTF::move with WTFMove
[WebKit-https.git] / Source / WebCore / rendering / RenderRubyText.cpp
1 /*
2  * Copyright (C) 2009 Google Inc. All rights reserved.
3  * Copyright (C) 2011 Apple Inc. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are
7  * met:
8  *
9  *     * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  *     * Redistributions in binary form must reproduce the above
12  * copyright notice, this list of conditions and the following disclaimer
13  * in the documentation and/or other materials provided with the
14  * distribution.
15  *     * Neither the name of Google Inc. nor the names of its
16  * contributors may be used to endorse or promote products derived from
17  * this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  */
31
32 #include "config.h"
33
34 #include "RenderRubyText.h"
35 #include "RenderRubyRun.h"
36
37 namespace WebCore {
38
39 RenderRubyText::RenderRubyText(Element& element, Ref<RenderStyle>&& style)
40     : RenderBlockFlow(element, WTFMove(style))
41 {
42 }
43
44 RenderRubyText::~RenderRubyText()
45 {
46 }
47
48 RenderRubyRun* RenderRubyText::rubyRun() const
49 {
50     ASSERT(parent());
51     return downcast<RenderRubyRun>(parent());
52 }
53
54 bool RenderRubyText::isChildAllowed(const RenderObject& child, const RenderStyle&) const
55 {
56     return child.isInline();
57 }
58
59 ETextAlign RenderRubyText::textAlignmentForLine(bool endsWithSoftBreak) const
60 {
61     ETextAlign textAlign = style().textAlign();
62     // FIXME: This check is bogus since user can set the initial value.
63     if (textAlign != RenderStyle::initialTextAlign())
64         return RenderBlockFlow::textAlignmentForLine(endsWithSoftBreak);
65
66     // The default behavior is to allow ruby text to expand if it is shorter than the ruby base.
67     return JUSTIFY;
68 }
69
70 void RenderRubyText::adjustInlineDirectionLineBounds(int expansionOpportunityCount, float& logicalLeft, float& logicalWidth) const
71 {
72     ETextAlign textAlign = style().textAlign();
73     // FIXME: This check is bogus since user can set the initial value.
74     if (textAlign != RenderStyle::initialTextAlign())
75         return RenderBlockFlow::adjustInlineDirectionLineBounds(expansionOpportunityCount, logicalLeft, logicalWidth);
76
77     int maxPreferredLogicalWidth = this->maxPreferredLogicalWidth();
78     if (maxPreferredLogicalWidth >= logicalWidth)
79         return;
80
81     // Inset the ruby text by half the inter-ideograph expansion amount, but no more than a full-width
82     // ruby character on each side.
83     float inset = (logicalWidth - maxPreferredLogicalWidth) / (expansionOpportunityCount + 1);
84     if (expansionOpportunityCount)
85         inset = std::min<float>(2 * style().fontSize(), inset);
86
87     logicalLeft += inset / 2;
88     logicalWidth -= inset;
89 }
90
91 bool RenderRubyText::avoidsFloats() const
92 {
93     return true;
94 }
95
96 bool RenderRubyText::canBreakBefore(const LazyLineBreakIterator& iterator) const
97 {
98     // FIXME: It would be nice to improve this so that it isn't just hard-coded, but lookahead in this
99     // case is particularly problematic.
100
101     if (!iterator.priorContextLength())
102         return true;
103     UChar ch = iterator.lastCharacter();
104     ULineBreak lineBreak = (ULineBreak)u_getIntPropertyValue(ch, UCHAR_LINE_BREAK);
105     // UNICODE LINE BREAKING ALGORITHM
106     // http://www.unicode.org/reports/tr14/
107     // And Requirements for Japanese Text Layout, 3.1.7 Characters Not Starting a Line
108     // http://www.w3.org/TR/2012/NOTE-jlreq-20120403/#characters_not_starting_a_line
109     switch (lineBreak) {
110     case U_LB_NONSTARTER:
111     case U_LB_CLOSE_PARENTHESIS:
112     case U_LB_CLOSE_PUNCTUATION:
113     case U_LB_EXCLAMATION:
114     case U_LB_BREAK_SYMBOLS:
115     case U_LB_INFIX_NUMERIC:
116     case U_LB_ZWSPACE:
117     case U_LB_WORD_JOINER:
118         return false;
119     default:
120         break;
121     }
122     // Special care for Requirements for Japanese Text Layout
123     switch (ch) {
124     case 0x2019: // RIGHT SINGLE QUOTATION MARK
125     case 0x201D: // RIGHT DOUBLE QUOTATION MARK
126     case 0x00BB: // RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK
127     case 0x2010: // HYPHEN
128     case 0x2013: // EN DASH
129     case 0x300C: // LEFT CORNER BRACKET
130         return false;
131     default:
132         break;
133     }
134     return true;
135 }
136
137 } // namespace WebCore