| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2011 Apple Inc. All rights reserved. | 2 * Copyright (C) 2011 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 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 public: | 52 public: |
| 53 explicit LayoutGrid(Element*); | 53 explicit LayoutGrid(Element*); |
| 54 ~LayoutGrid() override; | 54 ~LayoutGrid() override; |
| 55 | 55 |
| 56 const char* name() const override { return "LayoutGrid"; } | 56 const char* name() const override { return "LayoutGrid"; } |
| 57 | 57 |
| 58 void layoutBlock(bool relayoutChildren) override; | 58 void layoutBlock(bool relayoutChildren) override; |
| 59 | 59 |
| 60 void dirtyGrid(); | 60 void dirtyGrid(); |
| 61 | 61 |
| 62 Vector<LayoutUnit> trackSizesForComputedStyle(GridTrackSizingDirection) cons
t; |
| 63 |
| 62 const Vector<LayoutUnit>& columnPositions() const | 64 const Vector<LayoutUnit>& columnPositions() const |
| 63 { | 65 { |
| 64 ASSERT(!m_gridIsDirty); | 66 ASSERT(!m_gridIsDirty); |
| 65 return m_columnPositions; | 67 return m_columnPositions; |
| 66 } | 68 } |
| 67 | 69 |
| 68 const Vector<LayoutUnit>& rowPositions() const | 70 const Vector<LayoutUnit>& rowPositions() const |
| 69 { | 71 { |
| 70 ASSERT(!m_gridIsDirty); | 72 ASSERT(!m_gridIsDirty); |
| 71 return m_rowPositions; | 73 return m_rowPositions; |
| 72 } | 74 } |
| 73 | 75 |
| 74 LayoutUnit guttersSize(GridTrackSizingDirection, size_t span) const; | |
| 75 | |
| 76 LayoutUnit offsetBetweenTracks(GridTrackSizingDirection direction) const | |
| 77 { | |
| 78 return direction == ForColumns ? m_offsetBetweenColumns : m_offsetBetwee
nRows; | |
| 79 } | |
| 80 | |
| 81 typedef Vector<LayoutBox*, 1> GridCell; | 76 typedef Vector<LayoutBox*, 1> GridCell; |
| 82 const GridCell& gridCell(int row, int column) const | 77 const GridCell& gridCell(int row, int column) const |
| 83 { | 78 { |
| 84 ASSERT_WITH_SECURITY_IMPLICATION(!m_gridIsDirty); | 79 ASSERT_WITH_SECURITY_IMPLICATION(!m_gridIsDirty); |
| 85 return m_grid[row][column]; | 80 return m_grid[row][column]; |
| 86 } | 81 } |
| 87 | 82 |
| 88 const Vector<LayoutBox*>& itemsOverflowingGridArea() const | 83 const Vector<LayoutBox*>& itemsOverflowingGridArea() const |
| 89 { | 84 { |
| 90 ASSERT_WITH_SECURITY_IMPLICATION(!m_gridIsDirty); | 85 ASSERT_WITH_SECURITY_IMPLICATION(!m_gridIsDirty); |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 124 void computeUsedBreadthOfGridTracks(GridTrackSizingDirection, GridSizingData
&, LayoutUnit& baseSizesWithoutMaximization, LayoutUnit& growthLimitsWithoutMaxi
mization); | 119 void computeUsedBreadthOfGridTracks(GridTrackSizingDirection, GridSizingData
&, LayoutUnit& baseSizesWithoutMaximization, LayoutUnit& growthLimitsWithoutMaxi
mization); |
| 125 LayoutUnit computeUsedBreadthOfMinLength(const GridLength&, LayoutUnit maxBr
eadth) const; | 120 LayoutUnit computeUsedBreadthOfMinLength(const GridLength&, LayoutUnit maxBr
eadth) const; |
| 126 LayoutUnit computeUsedBreadthOfMaxLength(const GridLength&, LayoutUnit usedB
readth, LayoutUnit maxBreadth) const; | 121 LayoutUnit computeUsedBreadthOfMaxLength(const GridLength&, LayoutUnit usedB
readth, LayoutUnit maxBreadth) const; |
| 127 void resolveContentBasedTrackSizingFunctions(GridTrackSizingDirection, GridS
izingData&); | 122 void resolveContentBasedTrackSizingFunctions(GridTrackSizingDirection, GridS
izingData&); |
| 128 | 123 |
| 129 void ensureGridSize(size_t maximumRowSize, size_t maximumColumnSize); | 124 void ensureGridSize(size_t maximumRowSize, size_t maximumColumnSize); |
| 130 void insertItemIntoGrid(LayoutBox&, const GridArea&); | 125 void insertItemIntoGrid(LayoutBox&, const GridArea&); |
| 131 | 126 |
| 132 size_t computeAutoRepeatTracksCount(GridTrackSizingDirection) const; | 127 size_t computeAutoRepeatTracksCount(GridTrackSizingDirection) const; |
| 133 | 128 |
| 129 typedef HashSet<size_t, DefaultHash<size_t>::Hash, WTF::UnsignedWithZeroKeyH
ashTraits<size_t>> TrackIndexSet; |
| 130 std::unique_ptr<TrackIndexSet> computeEmptyTracksForAutoRepeat(GridTrackSizi
ngDirection) const; |
| 131 |
| 132 bool isEmptyAutoRepeatTrack(GridTrackSizingDirection, size_t lineNumber) con
st; |
| 133 |
| 134 void placeItemsOnGrid(); | 134 void placeItemsOnGrid(); |
| 135 void populateExplicitGridAndOrderIterator(); | 135 void populateExplicitGridAndOrderIterator(); |
| 136 std::unique_ptr<GridArea> createEmptyGridAreaAtSpecifiedPositionsOutsideGrid
(const LayoutBox&, GridTrackSizingDirection, const GridSpan& specifiedPositions)
const; | 136 std::unique_ptr<GridArea> createEmptyGridAreaAtSpecifiedPositionsOutsideGrid
(const LayoutBox&, GridTrackSizingDirection, const GridSpan& specifiedPositions)
const; |
| 137 void placeSpecifiedMajorAxisItemsOnGrid(const Vector<LayoutBox*>&); | 137 void placeSpecifiedMajorAxisItemsOnGrid(const Vector<LayoutBox*>&); |
| 138 void placeAutoMajorAxisItemsOnGrid(const Vector<LayoutBox*>&); | 138 void placeAutoMajorAxisItemsOnGrid(const Vector<LayoutBox*>&); |
| 139 void placeAutoMajorAxisItemOnGrid(LayoutBox&, std::pair<size_t, size_t>& aut
oPlacementCursor); | 139 void placeAutoMajorAxisItemOnGrid(LayoutBox&, std::pair<size_t, size_t>& aut
oPlacementCursor); |
| 140 GridTrackSizingDirection autoPlacementMajorAxisDirection() const; | 140 GridTrackSizingDirection autoPlacementMajorAxisDirection() const; |
| 141 GridTrackSizingDirection autoPlacementMinorAxisDirection() const; | 141 GridTrackSizingDirection autoPlacementMinorAxisDirection() const; |
| 142 | 142 |
| 143 void computeIntrinsicLogicalHeight(GridSizingData&); | 143 void computeIntrinsicLogicalHeight(GridSizingData&); |
| 144 LayoutUnit computeTrackBasedLogicalHeight(const GridSizingData&) const; | 144 LayoutUnit computeTrackBasedLogicalHeight(const GridSizingData&) const; |
| 145 void computeTrackSizesForDirection(GridTrackSizingDirection, GridSizingData&
, LayoutUnit freeSpace); | 145 void computeTrackSizesForDirection(GridTrackSizingDirection, GridSizingData&
, LayoutUnit freeSpace); |
| 146 | 146 |
| 147 void repeatTracksSizingIfNeeded(GridSizingData&, LayoutUnit availableSpaceFo
rColumns, LayoutUnit availableSpaceForRows); | 147 void repeatTracksSizingIfNeeded(GridSizingData&, LayoutUnit availableSpaceFo
rColumns, LayoutUnit availableSpaceForRows); |
| 148 | 148 |
| 149 void layoutGridItems(GridSizingData&); | 149 void layoutGridItems(GridSizingData&); |
| 150 void prepareChildForPositionedLayout(LayoutBox&); | 150 void prepareChildForPositionedLayout(LayoutBox&); |
| 151 void layoutPositionedObjects(bool relayoutChildren, PositionedLayoutBehavior
= DefaultLayout); | 151 void layoutPositionedObjects(bool relayoutChildren, PositionedLayoutBehavior
= DefaultLayout); |
| 152 void offsetAndBreadthForPositionedChild(const LayoutBox&, GridTrackSizingDir
ection, LayoutUnit& offset, LayoutUnit& breadth); | 152 void offsetAndBreadthForPositionedChild(const LayoutBox&, GridTrackSizingDir
ection, LayoutUnit& offset, LayoutUnit& breadth); |
| 153 void populateGridPositionsForDirection(GridSizingData&, GridTrackSizingDirec
tion); | 153 void populateGridPositionsForDirection(GridSizingData&, GridTrackSizingDirec
tion); |
| 154 | 154 |
| 155 typedef struct GridItemsSpanGroupRange GridItemsSpanGroupRange; | 155 typedef struct GridItemsSpanGroupRange GridItemsSpanGroupRange; |
| 156 LayoutUnit currentItemSizeForTrackSizeComputationPhase(TrackSizeComputationP
hase, LayoutBox&, GridTrackSizingDirection, GridSizingData&); | 156 LayoutUnit currentItemSizeForTrackSizeComputationPhase(TrackSizeComputationP
hase, LayoutBox&, GridTrackSizingDirection, GridSizingData&); |
| 157 void resolveContentBasedTrackSizingFunctionsForNonSpanningItems(GridTrackSiz
ingDirection, const GridSpan&, LayoutBox& gridItem, GridTrack&, GridSizingData&)
; | 157 void resolveContentBasedTrackSizingFunctionsForNonSpanningItems(GridTrackSiz
ingDirection, const GridSpan&, LayoutBox& gridItem, GridTrack&, GridSizingData&)
; |
| 158 template <TrackSizeComputationPhase> void resolveContentBasedTrackSizingFunc
tionsForItems(GridTrackSizingDirection, GridSizingData&, const GridItemsSpanGrou
pRange&); | 158 template <TrackSizeComputationPhase> void resolveContentBasedTrackSizingFunc
tionsForItems(GridTrackSizingDirection, GridSizingData&, const GridItemsSpanGrou
pRange&); |
| 159 template <TrackSizeComputationPhase> void distributeSpaceToTracks(Vector<Gri
dTrack*>&, const Vector<GridTrack*>* growBeyondGrowthLimitsTracks, GridSizingDat
a&, LayoutUnit& availableLogicalSpace); | 159 template <TrackSizeComputationPhase> void distributeSpaceToTracks(Vector<Gri
dTrack*>&, const Vector<GridTrack*>* growBeyondGrowthLimitsTracks, GridSizingDat
a&, LayoutUnit& availableLogicalSpace); |
| 160 | 160 |
| 161 typedef HashSet<size_t, DefaultHash<size_t>::Hash, WTF::UnsignedWithZeroKeyH
ashTraits<size_t>> TrackIndexSet; | |
| 162 double computeFlexFactorUnitSize(const Vector<GridTrack>&, GridTrackSizingDi
rection, double flexFactorSum, LayoutUnit& leftOverSpace, const Vector<size_t, 8
>& flexibleTracksIndexes, std::unique_ptr<TrackIndexSet> tracksToTreatAsInflexib
le = nullptr) const; | 161 double computeFlexFactorUnitSize(const Vector<GridTrack>&, GridTrackSizingDi
rection, double flexFactorSum, LayoutUnit& leftOverSpace, const Vector<size_t, 8
>& flexibleTracksIndexes, std::unique_ptr<TrackIndexSet> tracksToTreatAsInflexib
le = nullptr) const; |
| 163 double findFlexFactorUnitSize(const Vector<GridTrack>&, const GridSpan&, Gri
dTrackSizingDirection, LayoutUnit leftOverSpace) const; | 162 double findFlexFactorUnitSize(const Vector<GridTrack>&, const GridSpan&, Gri
dTrackSizingDirection, LayoutUnit leftOverSpace) const; |
| 164 | 163 |
| 165 const GridTrackSize& rawGridTrackSize(GridTrackSizingDirection, size_t) cons
t; | 164 const GridTrackSize& rawGridTrackSize(GridTrackSizingDirection, size_t) cons
t; |
| 166 GridTrackSize gridTrackSize(GridTrackSizingDirection, size_t, SizingOperatio
n = TrackSizing) const; | 165 GridTrackSize gridTrackSize(GridTrackSizingDirection, size_t, SizingOperatio
n = TrackSizing) const; |
| 167 | 166 |
| 168 bool updateOverrideContainingBlockContentSizeForChild(LayoutBox&, GridTrackS
izingDirection, GridSizingData&); | 167 bool updateOverrideContainingBlockContentSizeForChild(LayoutBox&, GridTrackS
izingDirection, GridSizingData&); |
| 169 LayoutUnit logicalHeightForChild(LayoutBox&, GridSizingData&); | 168 LayoutUnit logicalHeightForChild(LayoutBox&, GridSizingData&); |
| 170 LayoutUnit minSizeForChild(LayoutBox&, GridTrackSizingDirection, GridSizingD
ata&); | 169 LayoutUnit minSizeForChild(LayoutBox&, GridTrackSizingDirection, GridSizingD
ata&); |
| 171 LayoutUnit minContentForChild(LayoutBox&, GridTrackSizingDirection, GridSizi
ngData&); | 170 LayoutUnit minContentForChild(LayoutBox&, GridTrackSizingDirection, GridSizi
ngData&); |
| (...skipping 21 matching lines...) Expand all Loading... |
| 193 void applyStretchAlignmentToChildIfNeeded(LayoutBox&); | 192 void applyStretchAlignmentToChildIfNeeded(LayoutBox&); |
| 194 bool hasAutoMarginsInColumnAxis(const LayoutBox&) const; | 193 bool hasAutoMarginsInColumnAxis(const LayoutBox&) const; |
| 195 bool hasAutoMarginsInRowAxis(const LayoutBox&) const; | 194 bool hasAutoMarginsInRowAxis(const LayoutBox&) const; |
| 196 void updateAutoMarginsInColumnAxisIfNeeded(LayoutBox&); | 195 void updateAutoMarginsInColumnAxisIfNeeded(LayoutBox&); |
| 197 void updateAutoMarginsInRowAxisIfNeeded(LayoutBox&); | 196 void updateAutoMarginsInRowAxisIfNeeded(LayoutBox&); |
| 198 | 197 |
| 199 #if ENABLE(ASSERT) | 198 #if ENABLE(ASSERT) |
| 200 bool tracksAreWiderThanMinTrackBreadth(GridTrackSizingDirection, GridSizingD
ata&); | 199 bool tracksAreWiderThanMinTrackBreadth(GridTrackSizingDirection, GridSizingD
ata&); |
| 201 #endif | 200 #endif |
| 202 | 201 |
| 202 LayoutUnit gridGapForDirection(GridTrackSizingDirection) const; |
| 203 LayoutUnit guttersSize(GridTrackSizingDirection, size_t startLine, size_t sp
an) const; |
| 204 |
| 203 size_t gridItemSpan(const LayoutBox&, GridTrackSizingDirection); | 205 size_t gridItemSpan(const LayoutBox&, GridTrackSizingDirection); |
| 204 bool spanningItemCrossesFlexibleSizedTracks(const GridSpan&, GridTrackSizing
Direction, SizingOperation) const; | 206 bool spanningItemCrossesFlexibleSizedTracks(const GridSpan&, GridTrackSizing
Direction, SizingOperation) const; |
| 205 | 207 |
| 206 size_t gridColumnCount() const; | 208 size_t gridColumnCount() const; |
| 207 size_t gridRowCount() const; | 209 size_t gridRowCount() const; |
| 208 | 210 |
| 209 bool isOrthogonalChild(const LayoutBox&) const; | 211 bool isOrthogonalChild(const LayoutBox&) const; |
| 210 GridTrackSizingDirection flowAwareDirectionForChild(const LayoutBox&, GridTr
ackSizingDirection) const; | 212 GridTrackSizingDirection flowAwareDirectionForChild(const LayoutBox&, GridTr
ackSizingDirection) const; |
| 211 | 213 |
| 212 typedef Vector<Vector<GridCell>> GridRepresentation; | 214 typedef Vector<Vector<GridCell>> GridRepresentation; |
| (...skipping 11 matching lines...) Expand all Loading... |
| 224 LayoutUnit m_minContentHeight { -1 }; | 226 LayoutUnit m_minContentHeight { -1 }; |
| 225 LayoutUnit m_maxContentHeight { -1 }; | 227 LayoutUnit m_maxContentHeight { -1 }; |
| 226 | 228 |
| 227 int m_smallestRowStart; | 229 int m_smallestRowStart; |
| 228 int m_smallestColumnStart; | 230 int m_smallestColumnStart; |
| 229 | 231 |
| 230 size_t m_autoRepeatColumns { 0 }; | 232 size_t m_autoRepeatColumns { 0 }; |
| 231 size_t m_autoRepeatRows { 0 }; | 233 size_t m_autoRepeatRows { 0 }; |
| 232 | 234 |
| 233 bool m_hasAnyOrthogonalChild; | 235 bool m_hasAnyOrthogonalChild; |
| 236 |
| 237 std::unique_ptr<TrackIndexSet> m_autoRepeatEmptyColumns { nullptr }; |
| 238 std::unique_ptr<TrackIndexSet> m_autoRepeatEmptyRows { nullptr }; |
| 234 }; | 239 }; |
| 235 | 240 |
| 236 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutGrid, isLayoutGrid()); | 241 DEFINE_LAYOUT_OBJECT_TYPE_CASTS(LayoutGrid, isLayoutGrid()); |
| 237 | 242 |
| 238 } // namespace blink | 243 } // namespace blink |
| 239 | 244 |
| 240 #endif // LayoutGrid_h | 245 #endif // LayoutGrid_h |
| OLD | NEW |