Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(131)

Unified Diff: third_party/WebKit/Source/core/layout/LayoutGrid.h

Issue 2287533002: [css-grid] Remove a duplicated auto repeat computation for intrinsic sizes (Closed)
Patch Set: Patch Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/layout/LayoutGrid.h
diff --git a/third_party/WebKit/Source/core/layout/LayoutGrid.h b/third_party/WebKit/Source/core/layout/LayoutGrid.h
index 90a906943bc7771e8ee9cf0b3c659f27cb7605d5..e8c0f2f37a3faa03c8994fd26d26515224997a01 100644
--- a/third_party/WebKit/Source/core/layout/LayoutGrid.h
+++ b/third_party/WebKit/Source/core/layout/LayoutGrid.h
@@ -58,7 +58,7 @@ public:
void layoutBlock(bool relayoutChildren) override;
- void dirtyGrid();
+ void dirtyGrid() const;
Manuel Rego 2016/10/06 12:31:30 I still don't get why we want to make this method
svillar 2016/10/06 13:14:33 Because we want to use it in the intrinsic size co
Vector<LayoutUnit> trackSizesForComputedStyle(GridTrackSizingDirection) const;
@@ -125,6 +125,7 @@ private:
void ensureGridSize(size_t maximumRowSize, size_t maximumColumnSize);
void insertItemIntoGrid(LayoutBox&, const GridArea&);
+ void updateAutoRepeatTracksAndSetDirtyIfNeeded(SizingOperation) const;
size_t computeAutoRepeatTracksCount(GridTrackSizingDirection, SizingOperation) const;
typedef ListHashSet<size_t> OrderedTrackIndexSet;
@@ -133,7 +134,7 @@ private:
bool hasAutoRepeatEmptyTracks(GridTrackSizingDirection) const;
bool isEmptyAutoRepeatTrack(GridTrackSizingDirection, size_t lineNumber) const;
- void placeItemsOnGrid(SizingOperation);
+ void placeItemsOnGrid();
void populateExplicitGridAndOrderIterator();
std::unique_ptr<GridArea> createEmptyGridAreaAtSpecifiedPositionsOutsideGrid(const LayoutBox&, GridTrackSizingDirection, const GridSpan& specifiedPositions) const;
void placeSpecifiedMajorAxisItemsOnGrid(const Vector<LayoutBox*>&);
@@ -224,16 +225,16 @@ private:
bool cachedHasDefiniteLogicalHeight() const;
typedef Vector<Vector<GridCell>> GridRepresentation;
- GridRepresentation m_grid;
- bool m_gridIsDirty;
+ mutable GridRepresentation m_grid;
+ mutable bool m_gridIsDirty;
Vector<LayoutUnit> m_rowPositions;
Manuel Rego 2016/10/06 12:31:30 Why some attributes are mutables and other don't?
svillar 2016/10/06 13:14:33 Why do you want to make them all mutable or none?
Vector<LayoutUnit> m_columnPositions;
LayoutUnit m_offsetBetweenColumns;
LayoutUnit m_offsetBetweenRows;
- HashMap<const LayoutBox*, GridArea> m_gridItemArea;
+ mutable HashMap<const LayoutBox*, GridArea> m_gridItemArea;
OrderIterator m_orderIterator;
- Vector<LayoutBox*> m_gridItemsOverflowingGridArea;
- HashMap<const LayoutBox*, size_t> m_gridItemsIndexesMap;
+ mutable Vector<LayoutBox*> m_gridItemsOverflowingGridArea;
+ mutable HashMap<const LayoutBox*, size_t> m_gridItemsIndexesMap;
LayoutUnit m_minContentHeight { -1 };
LayoutUnit m_maxContentHeight { -1 };
@@ -241,13 +242,13 @@ private:
int m_smallestRowStart;
int m_smallestColumnStart;
- size_t m_autoRepeatColumns { 0 };
- size_t m_autoRepeatRows { 0 };
+ mutable size_t m_autoRepeatColumns { 0 };
+ mutable size_t m_autoRepeatRows { 0 };
bool m_hasAnyOrthogonalChild;
- std::unique_ptr<OrderedTrackIndexSet> m_autoRepeatEmptyColumns { nullptr };
- std::unique_ptr<OrderedTrackIndexSet> m_autoRepeatEmptyRows { nullptr };
+ mutable std::unique_ptr<OrderedTrackIndexSet> m_autoRepeatEmptyColumns { nullptr };
+ mutable std::unique_ptr<OrderedTrackIndexSet> m_autoRepeatEmptyRows { nullptr };
Optional<bool> m_hasDefiniteLogicalHeight;
};

Powered by Google App Engine
This is Rietveld 408576698