OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2013 Adobe Systems Incorporated. All rights reserved. | 2 * Copyright (C) 2013 Adobe Systems Incorporated. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * | 7 * |
8 * 1. Redistributions of source code must retain the above | 8 * 1. Redistributions of source code must retain the above |
9 * copyright notice, this list of conditions and the following | 9 * copyright notice, this list of conditions and the following |
10 * disclaimer. | 10 * disclaimer. |
(...skipping 12 matching lines...) Expand all Loading... |
23 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 23 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | 24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, |
25 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 25 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
26 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | 26 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED |
27 * OF THE POSSIBILITY OF SUCH DAMAGE. | 27 * OF THE POSSIBILITY OF SUCH DAMAGE. |
28 */ | 28 */ |
29 | 29 |
30 #ifndef LineWidth_h | 30 #ifndef LineWidth_h |
31 #define LineWidth_h | 31 #define LineWidth_h |
32 | 32 |
| 33 #include "core/layout/api/LineLayoutBlockFlow.h" |
33 #include "platform/LayoutUnit.h" | 34 #include "platform/LayoutUnit.h" |
34 | 35 |
35 namespace blink { | 36 namespace blink { |
36 | 37 |
37 class FloatingObject; | 38 class FloatingObject; |
38 class LayoutObject; | 39 class LayoutObject; |
39 class LayoutRubyRun; | 40 class LayoutRubyRun; |
40 class LayoutBlockFlow; | |
41 | 41 |
42 enum IndentTextOrNot { DoNotIndentText, IndentText }; | 42 enum IndentTextOrNot { DoNotIndentText, IndentText }; |
43 enum WhitespaceTreatment { ExcludeWhitespace, IncludeWhitespace }; | 43 enum WhitespaceTreatment { ExcludeWhitespace, IncludeWhitespace }; |
44 | 44 |
45 class LineWidth { | 45 class LineWidth { |
46 public: | 46 public: |
47 LineWidth(LayoutBlockFlow&, bool isFirstLine, IndentTextOrNot shouldIndentTe
xt); | 47 LineWidth(LineLayoutBlockFlow, bool isFirstLine, IndentTextOrNot shouldInden
tText); |
48 | 48 |
49 bool fitsOnLine() const { return currentWidth() <= (m_availableWidth + Layou
tUnit::epsilon()); } | 49 bool fitsOnLine() const { return currentWidth() <= (m_availableWidth + Layou
tUnit::epsilon()); } |
50 bool fitsOnLine(float extra) const { return currentWidth() + extra <= (m_ava
ilableWidth + LayoutUnit::epsilon()); } | 50 bool fitsOnLine(float extra) const { return currentWidth() + extra <= (m_ava
ilableWidth + LayoutUnit::epsilon()); } |
51 bool fitsOnLine(float extra, WhitespaceTreatment whitespaceTreatment) const | 51 bool fitsOnLine(float extra, WhitespaceTreatment whitespaceTreatment) const |
52 { | 52 { |
53 return currentWidth() - (whitespaceTreatment == ExcludeWhitespace ? trai
lingWhitespaceWidth() : 0) + extra <= (m_availableWidth + LayoutUnit::epsilon())
; | 53 return currentWidth() - (whitespaceTreatment == ExcludeWhitespace ? trai
lingWhitespaceWidth() : 0) + extra <= (m_availableWidth + LayoutUnit::epsilon())
; |
54 } | 54 } |
55 | 55 |
56 float currentWidth() const { return m_committedWidth + m_uncommittedWidth; } | 56 float currentWidth() const { return m_committedWidth + m_uncommittedWidth; } |
57 // FIXME: We should eventually replace these three functions by ones that wo
rk on a higher abstraction. | 57 // FIXME: We should eventually replace these three functions by ones that wo
rk on a higher abstraction. |
(...skipping 10 matching lines...) Expand all Loading... |
68 void fitBelowFloats(bool isFirstLine = false); | 68 void fitBelowFloats(bool isFirstLine = false); |
69 void setTrailingWhitespaceWidth(float width) { m_trailingWhitespaceWidth = w
idth; } | 69 void setTrailingWhitespaceWidth(float width) { m_trailingWhitespaceWidth = w
idth; } |
70 | 70 |
71 bool shouldIndentText() const { return m_shouldIndentText == IndentText; } | 71 bool shouldIndentText() const { return m_shouldIndentText == IndentText; } |
72 | 72 |
73 private: | 73 private: |
74 void computeAvailableWidthFromLeftAndRight(); | 74 void computeAvailableWidthFromLeftAndRight(); |
75 void updateLineDimension(LayoutUnit newLineTop, LayoutUnit newLineWidth, con
st float& newLineLeft, const float& newLineRight); | 75 void updateLineDimension(LayoutUnit newLineTop, LayoutUnit newLineWidth, con
st float& newLineLeft, const float& newLineRight); |
76 void wrapNextToShapeOutside(bool isFirstLine); | 76 void wrapNextToShapeOutside(bool isFirstLine); |
77 | 77 |
78 LayoutBlockFlow& m_block; | 78 LineLayoutBlockFlow m_block; |
79 float m_uncommittedWidth; | 79 float m_uncommittedWidth; |
80 float m_committedWidth; | 80 float m_committedWidth; |
81 float m_overhangWidth; // The amount by which |m_availableWidth| has been in
flated to account for possible contraction due to ruby overhang. | 81 float m_overhangWidth; // The amount by which |m_availableWidth| has been in
flated to account for possible contraction due to ruby overhang. |
82 float m_trailingWhitespaceWidth; | 82 float m_trailingWhitespaceWidth; |
83 float m_left; | 83 float m_left; |
84 float m_right; | 84 float m_right; |
85 float m_availableWidth; | 85 float m_availableWidth; |
86 bool m_isFirstLine; | 86 bool m_isFirstLine; |
87 IndentTextOrNot m_shouldIndentText; | 87 IndentTextOrNot m_shouldIndentText; |
88 }; | 88 }; |
89 | 89 |
90 } | 90 } |
91 | 91 |
92 #endif // LineWidth_h | 92 #endif // LineWidth_h |
OLD | NEW |