Index: Source/core/layout/LayoutBlockFlowLine.cpp |
diff --git a/Source/core/layout/LayoutBlockFlowLine.cpp b/Source/core/layout/LayoutBlockFlowLine.cpp |
index b382670640a5280839364f6f59a4f168f5a86df3..f6b4136431ff89f5da109c026f786c92636f339f 100644 |
--- a/Source/core/layout/LayoutBlockFlowLine.cpp |
+++ b/Source/core/layout/LayoutBlockFlowLine.cpp |
@@ -670,11 +670,11 @@ void LayoutBlockFlow::computeBlockDirectionPositionsForLine(RootInlineBox* lineB |
} |
} |
-void LayoutBlockFlow::appendFloatingObjectToLastLine(FloatingObject* floatingObject) |
+void LayoutBlockFlow::appendFloatingObjectToLastLine(FloatingObject& floatingObject) |
{ |
- ASSERT(!floatingObject->originatingLine()); |
- floatingObject->setOriginatingLine(lastRootBox()); |
- lastRootBox()->appendFloat(floatingObject->layoutObject()); |
+ ASSERT(!floatingObject.originatingLine()); |
+ floatingObject.setOriginatingLine(lastRootBox()); |
+ lastRootBox()->appendFloat(floatingObject.layoutObject()); |
} |
// This function constructs line boxes for all of the text runs in the resolver and computes their position. |
@@ -913,11 +913,11 @@ void LayoutBlockFlow::layoutRunsAndFloatsInRange(LineLayoutState& layoutState, |
it = lastFloatIterator; |
} |
for (; it != end; ++it) { |
- FloatingObject* f = it->get(); |
- appendFloatingObjectToLastLine(f); |
- ASSERT(f->layoutObject() == layoutState.floats()[layoutState.floatIndex()].object); |
+ FloatingObject& floatingObject = *it->get(); |
+ appendFloatingObjectToLastLine(floatingObject); |
+ ASSERT(floatingObject.layoutObject() == layoutState.floats()[layoutState.floatIndex()].object); |
// If a float's geometry has changed, give up on syncing with clean lines. |
- if (layoutState.floats()[layoutState.floatIndex()].rect != f->frameRect()) |
+ if (layoutState.floats()[layoutState.floatIndex()].rect != floatingObject.frameRect()) |
checkForEndLineMatch = false; |
layoutState.setFloatIndex(layoutState.floatIndex() + 1); |
} |
@@ -1062,7 +1062,7 @@ void LayoutBlockFlow::linkToEndLineIfNeeded(LineLayoutState& layoutState) |
} |
for (; it != end; ++it) |
- appendFloatingObjectToLastLine(it->get()); |
+ appendFloatingObjectToLastLine(*it->get()); |
} |
} |
@@ -1847,7 +1847,7 @@ bool LayoutBlockFlow::checkPaginationAndFloatsAtEndLine(LineLayoutState& layoutS |
const FloatingObjectSet& floatingObjectSet = m_floatingObjects->set(); |
FloatingObjectSetIterator end = floatingObjectSet.end(); |
for (FloatingObjectSetIterator it = floatingObjectSet.begin(); it != end; ++it) { |
- FloatingObject* floatingObject = it->get(); |
+ FloatingObject& floatingObject = *it->get(); |
if (logicalBottomForFloat(floatingObject) >= logicalTop && logicalBottomForFloat(floatingObject) < logicalBottom) |
return false; |
} |
@@ -1990,7 +1990,7 @@ void LayoutBlockFlow::checkLinesForTextOverflow() |
} |
} |
-bool LayoutBlockFlow::positionNewFloatOnLine(FloatingObject* newFloat, FloatingObject* lastFloatFromPreviousLine, LineInfo& lineInfo, LineWidth& width) |
+bool LayoutBlockFlow::positionNewFloatOnLine(FloatingObject& newFloat, FloatingObject* lastFloatFromPreviousLine, LineInfo& lineInfo, LineWidth& width) |
{ |
if (!positionNewFloats(&width)) |
return false; |
@@ -1998,14 +1998,14 @@ bool LayoutBlockFlow::positionNewFloatOnLine(FloatingObject* newFloat, FloatingO |
// We only connect floats to lines for pagination purposes if the floats occur at the start of |
// the line and the previous line had a hard break (so this line is either the first in the block |
// or follows a <br>). |
- if (!newFloat->paginationStrut() || !lineInfo.previousLineBrokeCleanly() || !lineInfo.isEmpty()) |
+ if (!newFloat.paginationStrut() || !lineInfo.previousLineBrokeCleanly() || !lineInfo.isEmpty()) |
return true; |
const FloatingObjectSet& floatingObjectSet = m_floatingObjects->set(); |
- ASSERT(floatingObjectSet.last() == newFloat); |
+ ASSERT(floatingObjectSet.last() == &newFloat); |
LayoutUnit floatLogicalTop = logicalTopForFloat(newFloat); |
- int paginationStrut = newFloat->paginationStrut(); |
+ int paginationStrut = newFloat.paginationStrut(); |
if (floatLogicalTop - paginationStrut != logicalHeight() + lineInfo.floatPaginationStrut()) |
return true; |
@@ -2018,7 +2018,7 @@ bool LayoutBlockFlow::positionNewFloatOnLine(FloatingObject* newFloat, FloatingO |
FloatingObject* floatingObject = it->get(); |
if (floatingObject == lastFloatFromPreviousLine) |
break; |
- if (logicalTopForFloat(floatingObject) == logicalHeight() + lineInfo.floatPaginationStrut()) { |
+ if (logicalTopForFloat(*floatingObject) == logicalHeight() + lineInfo.floatPaginationStrut()) { |
floatingObject->setPaginationStrut(paginationStrut + floatingObject->paginationStrut()); |
LayoutBox* floatBox = floatingObject->layoutObject(); |
setLogicalTopForChild(*floatBox, logicalTopForChild(*floatBox) + marginBeforeForChild(*floatBox) + paginationStrut); |
@@ -2028,9 +2028,9 @@ bool LayoutBlockFlow::positionNewFloatOnLine(FloatingObject* newFloat, FloatingO |
floatBox->layoutIfNeeded(); |
// Save the old logical top before calling removePlacedObject which will set |
// isPlaced to false. Otherwise it will trigger an assert in logicalTopForFloat. |
- LayoutUnit oldLogicalTop = logicalTopForFloat(floatingObject); |
+ LayoutUnit oldLogicalTop = logicalTopForFloat(*floatingObject); |
m_floatingObjects->removePlacedObject(floatingObject); |
- setLogicalTopForFloat(floatingObject, oldLogicalTop + paginationStrut); |
+ setLogicalTopForFloat(*floatingObject, oldLogicalTop + paginationStrut); |
m_floatingObjects->addPlacedObject(floatingObject); |
} |
} |