| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Apple Inc. All rights reserved. | 2 * Copyright (C) 2012 Apple Inc. 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 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 const MultiColumnFragmentainerGroup& fragmentainerGroupAtVisualPoint(const L
ayoutPoint&) const; | 75 const MultiColumnFragmentainerGroup& fragmentainerGroupAtVisualPoint(const L
ayoutPoint&) const; |
| 76 | 76 |
| 77 bool isOfType(LayoutObjectType type) const override { return type == LayoutO
bjectLayoutMultiColumnSet || LayoutBlockFlow::isOfType(type); } | 77 bool isOfType(LayoutObjectType type) const override { return type == LayoutO
bjectLayoutMultiColumnSet || LayoutBlockFlow::isOfType(type); } |
| 78 bool canHaveChildren() const final { return false; } | 78 bool canHaveChildren() const final { return false; } |
| 79 | 79 |
| 80 // Return the width and height of a single column or page in the set. | 80 // Return the width and height of a single column or page in the set. |
| 81 LayoutUnit pageLogicalWidth() const { return flowThread()->logicalWidth(); } | 81 LayoutUnit pageLogicalWidth() const { return flowThread()->logicalWidth(); } |
| 82 LayoutUnit pageLogicalHeightForOffset(LayoutUnit) const; | 82 LayoutUnit pageLogicalHeightForOffset(LayoutUnit) const; |
| 83 LayoutUnit pageRemainingLogicalHeightForOffset(LayoutUnit, PageBoundaryRule)
const; | 83 LayoutUnit pageRemainingLogicalHeightForOffset(LayoutUnit, PageBoundaryRule)
const; |
| 84 bool isPageLogicalHeightKnown() const; | 84 bool isPageLogicalHeightKnown() const; |
| 85 LayoutUnit tallestUnbreakableLogicalHeight() const { return m_tallestUnbreak
ableLogicalHeight; } |
| 86 void propagateTallestUnbreakableLogicalHeight(LayoutUnit value) { m_tallestU
nbreakableLogicalHeight = std::max(value, m_tallestUnbreakableLogicalHeight); } |
| 85 | 87 |
| 86 LayoutFlowThread* flowThread() const { return m_flowThread; } | 88 LayoutFlowThread* flowThread() const { return m_flowThread; } |
| 87 | 89 |
| 88 LayoutBlockFlow* multiColumnBlockFlow() const { return toLayoutBlockFlow(par
ent()); } | 90 LayoutBlockFlow* multiColumnBlockFlow() const { return toLayoutBlockFlow(par
ent()); } |
| 89 LayoutMultiColumnFlowThread* multiColumnFlowThread() const { return toLayout
MultiColumnFlowThread(flowThread()); } | 91 LayoutMultiColumnFlowThread* multiColumnFlowThread() const { return toLayout
MultiColumnFlowThread(flowThread()); } |
| 90 | 92 |
| 91 LayoutMultiColumnSet* nextSiblingMultiColumnSet() const; | 93 LayoutMultiColumnSet* nextSiblingMultiColumnSet() const; |
| 92 LayoutMultiColumnSet* previousSiblingMultiColumnSet() const; | 94 LayoutMultiColumnSet* previousSiblingMultiColumnSet() const; |
| 93 | 95 |
| 94 MultiColumnFragmentainerGroup& appendNewFragmentainerGroup(); | 96 MultiColumnFragmentainerGroup& appendNewFragmentainerGroup(); |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 161 | 163 |
| 162 void computeLogicalHeight(LayoutUnit logicalHeight, LayoutUnit logicalTop, L
ogicalExtentComputedValues&) const override; | 164 void computeLogicalHeight(LayoutUnit logicalHeight, LayoutUnit logicalTop, L
ogicalExtentComputedValues&) const override; |
| 163 PositionWithAffinity positionForPoint(const LayoutPoint&) override; | 165 PositionWithAffinity positionForPoint(const LayoutPoint&) override; |
| 164 | 166 |
| 165 void paintObject(const PaintInfo&, const LayoutPoint& paintOffset) const ove
rride; | 167 void paintObject(const PaintInfo&, const LayoutPoint& paintOffset) const ove
rride; |
| 166 | 168 |
| 167 void addOverflowFromChildren() override; | 169 void addOverflowFromChildren() override; |
| 168 | 170 |
| 169 MultiColumnFragmentainerGroupList m_fragmentainerGroups; | 171 MultiColumnFragmentainerGroupList m_fragmentainerGroups; |
| 170 LayoutFlowThread* m_flowThread; | 172 LayoutFlowThread* m_flowThread; |
| 173 |
| 174 // Height of the tallest piece of unbreakable content. This is the minimum c
olumn logical height |
| 175 // required to avoid fragmentation where it shouldn't occur (inside unbreaka
ble content, between |
| 176 // orphans and widows, etc.). We only store this so that outer fragmentation
contexts (if any) |
| 177 // can query this when calculating their own minimum. Note that we don't sto
re this value in |
| 178 // every fragmentainer group (but rather here, in the column set), since we
only need the |
| 179 // largest one among them. |
| 180 LayoutUnit m_tallestUnbreakableLogicalHeight; |
| 171 }; | 181 }; |
| 172 | 182 |
| 173 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutMultiColumnSet, isLayoutMultiColumnSet()); | 183 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutMultiColumnSet, isLayoutMultiColumnSet()); |
| 174 | 184 |
| 175 } // namespace blink | 185 } // namespace blink |
| 176 | 186 |
| 177 #endif // LayoutMultiColumnSet_h | 187 #endif // LayoutMultiColumnSet_h |
| 178 | 188 |
| OLD | NEW |