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

Side by Side Diff: Source/core/rendering/style/GridResolvedPosition.h

Issue 166623002: [CSS Grid Layout] Introduce an explicit type for resolved grid positions (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Apply suggested changes Created 6 years, 9 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef GridResolvedPosition_h
6 #define GridResolvedPosition_h
7
8 #include "core/rendering/style/GridPosition.h"
9
10 namespace WebCore {
11
12 class GridSpan;
13 class RenderBox;
14 class RenderStyle;
15
16 enum GridPositionSide {
17 ColumnStartSide,
18 ColumnEndSide,
19 RowStartSide,
20 RowEndSide
21 };
22
23 enum GridTrackSizingDirection {
24 ForColumns,
25 ForRows
26 };
27
28 // This class represents an index into one of the dimensions of the grid array.
29 // Wraps a size_t integer just for the purpose of knowing what we manipulate in the grid code.
30 class GridResolvedPosition {
31 public:
32 static size_t adjustGridPositionForAfterEndSide(size_t resolvedPosition)
33 {
34 return resolvedPosition ? resolvedPosition - 1 : 0;
35 }
36
37 static size_t adjustGridPositionForSide(size_t resolvedPosition, GridPositio nSide side)
38 {
39 // An item finishing on the N-th line belongs to the N-1-th cell.
40 if (side == ColumnEndSide || side == RowEndSide)
41 return adjustGridPositionForAfterEndSide(resolvedPosition);
42
43 return resolvedPosition;
44 }
45
46 static GridSpan resolveGridPositionsFromAutoPlacementPosition(const RenderBo x&, GridTrackSizingDirection, const GridResolvedPosition&);
47 static PassOwnPtr<GridSpan> resolveGridPositionsFromStyle(const RenderStyle& , const RenderBox&, GridTrackSizingDirection);
48 static GridResolvedPosition resolveNamedGridLinePositionFromStyle(const Rend erStyle&, const GridPosition&, GridPositionSide);
49 static GridResolvedPosition resolveGridPositionFromStyle(const RenderStyle&, const GridPosition&, GridPositionSide);
50 static PassOwnPtr<GridSpan> resolveGridPositionAgainstOppositePosition(const RenderStyle&, const GridResolvedPosition& resolvedOppositePosition, const GridP osition&, GridPositionSide);
51 static PassOwnPtr<GridSpan> resolveNamedGridLinePositionAgainstOppositePosit ion(const RenderStyle&, const GridResolvedPosition& resolvedOppositePosition, co nst GridPosition&, GridPositionSide);
52
53 GridResolvedPosition(size_t position)
54 : m_integerPosition(position)
55 {
56 }
57
58 GridResolvedPosition(const GridPosition& position, GridPositionSide side)
59 {
60 ASSERT(position.integerPosition());
61 size_t integerPosition = position.integerPosition() - 1;
62
63 m_integerPosition = adjustGridPositionForSide(integerPosition, side);
64 }
65
66 GridResolvedPosition& operator++()
67 {
68 m_integerPosition++;
69 return *this;
70 }
71
72 GridResolvedPosition& operator=(const GridResolvedPosition& other)
73 {
74 m_integerPosition = other.m_integerPosition;
75 return *this;
76 }
Julien - ping for review 2014/04/03 22:26:19 Shouldn't the default copy assignment do what we w
77
78 bool operator==(const GridResolvedPosition& other) const
79 {
80 return m_integerPosition == other.m_integerPosition;
81 }
82
83 bool operator<(const GridResolvedPosition& other) const
84 {
85 return m_integerPosition < other.m_integerPosition;
86 }
87
88 bool operator<=(const GridResolvedPosition& other) const
89 {
90 return m_integerPosition <= other.m_integerPosition;
91 }
92
93 bool operator<(size_t otherIntegerPosition) const
94 {
95 return m_integerPosition < otherIntegerPosition;
96 }
97
98 bool operator<=(size_t otherIntegerPosition) const
99 {
100 return m_integerPosition <= otherIntegerPosition;
101 }
102
103 operator size_t() const
104 {
105 return m_integerPosition;
106 }
107
108 static size_t explicitGridColumnCount(const RenderStyle&);
109 static size_t explicitGridRowCount(const RenderStyle&);
110
111 private:
112
113 static size_t explicitGridSizeForSide(const RenderStyle&, GridPositionSide);
114
115 size_t m_integerPosition;
116 };
117
118 } // namespace WebCore
119
120 #endif // GridResolvedPosition_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698