| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/layout/ng/ng_box.h" | 5 #include "core/layout/ng/ng_box.h" |
| 6 | 6 |
| 7 #include "core/layout/LayoutObject.h" | 7 #include "core/layout/LayoutObject.h" |
| 8 #include "core/layout/ng/ng_block_layout_algorithm.h" | 8 #include "core/layout/ng/ng_block_layout_algorithm.h" |
| 9 #include "core/layout/ng/ng_fragment.h" |
| 10 #include "core/layout/LayoutBox.h" |
| 9 | 11 |
| 10 namespace blink { | 12 namespace blink { |
| 11 | 13 |
| 12 NGFragment* NGBox::layout(const NGConstraintSpace& constraintSpace) { | 14 NGFragment* NGBox::layout(const NGConstraintSpace& constraintSpace) { |
| 13 NGBlockLayoutAlgorithm algorithm(style(), firstChild()); | 15 NGBlockLayoutAlgorithm algorithm(style(), iterator()); |
| 14 return algorithm.layout(constraintSpace); | 16 m_layoutBox->clearNeedsLayout(); |
| 17 NGFragment* fragment = algorithm.layout(constraintSpace); |
| 18 m_layoutBox->setLogicalWidth(fragment->inlineSize()); |
| 19 m_layoutBox->setLogicalHeight(fragment->blockSize()); |
| 20 return fragment; |
| 15 } | 21 } |
| 16 | 22 |
| 17 const ComputedStyle* NGBox::style() const { | 23 const ComputedStyle* NGBox::style() const { |
| 18 return m_layoutObject->style(); | 24 return m_layoutBox->style(); |
| 19 } | |
| 20 | |
| 21 const NGBox NGBox::firstChild() const { | |
| 22 return NGBox(m_layoutObject->slowFirstChild()); | |
| 23 } | |
| 24 | |
| 25 const NGBox NGBox::nextSibling() const { | |
| 26 return NGBox(m_layoutObject->nextSibling()); | |
| 27 } | 25 } |
| 28 | 26 |
| 29 } // namespace blink | 27 } // namespace blink |
| OLD | NEW |