Skip to content

Commit ca16a1e

Browse files
committed
LibWeb: Store GridSize values as a Variant
A GridSize can't hold both a LengthPercentage and a Flex at the same time, so let's limit that.
1 parent b66ff21 commit ca16a1e

File tree

2 files changed

+26
-25
lines changed

2 files changed

+26
-25
lines changed

Userland/Libraries/LibWeb/CSS/GridTrackSize.cpp

Lines changed: 21 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -12,25 +12,26 @@ namespace Web::CSS {
1212

1313
GridSize::GridSize(LengthPercentage length_percentage)
1414
: m_type(Type::LengthPercentage)
15-
, m_length_percentage(length_percentage) {};
15+
, m_value(move(length_percentage))
16+
{
17+
}
1618

1719
GridSize::GridSize(Flex flex_factor)
1820
: m_type(Type::FlexibleLength)
19-
, m_length_percentage { Length::make_px(0) }
20-
, m_flex_factor(flex_factor)
21+
, m_value(move(flex_factor))
2122
{
2223
}
2324

2425
GridSize::GridSize(Type type)
25-
: m_length_percentage { Length::make_auto() }
26+
: m_value { Empty() }
2627
{
2728
VERIFY(type == Type::MinContent || type == Type::MaxContent);
2829
m_type = type;
2930
}
3031

3132
GridSize::GridSize()
3233
: m_type(Type::LengthPercentage)
33-
, m_length_percentage { Length::make_auto() }
34+
, m_value { Length::make_auto() }
3435
{
3536
}
3637

@@ -39,9 +40,10 @@ GridSize::~GridSize() = default;
3940
bool GridSize::is_auto(Layout::AvailableSize const& available_size) const
4041
{
4142
if (m_type == Type::LengthPercentage) {
42-
if (m_length_percentage.contains_percentage())
43+
auto& length_percentage = m_value.get<LengthPercentage>();
44+
if (length_percentage.contains_percentage())
4345
return !available_size.is_definite();
44-
return m_length_percentage.is_auto();
46+
return length_percentage.is_auto();
4547
}
4648

4749
return false;
@@ -50,9 +52,10 @@ bool GridSize::is_auto(Layout::AvailableSize const& available_size) const
5052
bool GridSize::is_fixed(Layout::AvailableSize const& available_size) const
5153
{
5254
if (m_type == Type::LengthPercentage) {
53-
if (m_length_percentage.contains_percentage())
55+
auto& length_percentage = m_value.get<LengthPercentage>();
56+
if (length_percentage.contains_percentage())
5457
return available_size.is_definite();
55-
return !m_length_percentage.is_auto();
58+
return !length_percentage.is_auto();
5659
}
5760

5861
return false;
@@ -71,23 +74,23 @@ GridSize GridSize::make_auto()
7174
Size GridSize::css_size() const
7275
{
7376
VERIFY(m_type == Type::LengthPercentage);
74-
if (m_length_percentage.is_auto())
77+
auto& length_percentage = m_value.get<LengthPercentage>();
78+
if (length_percentage.is_auto())
7579
return CSS::Size::make_auto();
76-
if (m_length_percentage.is_length())
77-
return CSS::Size::make_length(m_length_percentage.length());
78-
if (m_length_percentage.is_calculated()) {
79-
return CSS::Size::make_calculated(m_length_percentage.calculated());
80-
}
81-
return CSS::Size::make_percentage(m_length_percentage.percentage());
80+
if (length_percentage.is_length())
81+
return CSS::Size::make_length(length_percentage.length());
82+
if (length_percentage.is_calculated())
83+
return CSS::Size::make_calculated(length_percentage.calculated());
84+
return CSS::Size::make_percentage(length_percentage.percentage());
8285
}
8386

8487
String GridSize::to_string() const
8588
{
8689
switch (m_type) {
8790
case Type::LengthPercentage:
88-
return m_length_percentage.to_string();
91+
return m_value.get<LengthPercentage>().to_string();
8992
case Type::FlexibleLength:
90-
return m_flex_factor.to_string();
93+
return m_value.get<Flex>().to_string();
9194
case Type::MaxContent:
9295
return "max-content"_string;
9396
case Type::MinContent:

Userland/Libraries/LibWeb/CSS/GridTrackSize.h

Lines changed: 5 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -37,8 +37,8 @@ class GridSize {
3737
bool is_max_content() const { return m_type == Type::MaxContent; }
3838
bool is_min_content() const { return m_type == Type::MinContent; }
3939

40-
LengthPercentage length_percentage() const { return m_length_percentage; }
41-
double flex_factor() const { return m_flex_factor.to_fr(); }
40+
LengthPercentage length_percentage() const { return m_value.get<LengthPercentage>(); }
41+
double flex_factor() const { return m_value.get<Flex>().to_fr(); }
4242

4343
// https://www.w3.org/TR/css-grid-2/#layout-algorithm
4444
// An intrinsic sizing function (min-content, max-content, auto, fit-content()).
@@ -47,7 +47,7 @@ class GridSize {
4747

4848
bool is_definite() const
4949
{
50-
return type() == Type::LengthPercentage && !m_length_percentage.is_auto();
50+
return type() == Type::LengthPercentage && !length_percentage().is_auto();
5151
}
5252

5353
Size css_size() const;
@@ -56,14 +56,12 @@ class GridSize {
5656
bool operator==(GridSize const& other) const
5757
{
5858
return m_type == other.type()
59-
&& m_length_percentage == other.length_percentage()
60-
&& m_flex_factor == other.m_flex_factor;
59+
&& m_value == other.m_value;
6160
}
6261

6362
private:
6463
Type m_type;
65-
LengthPercentage m_length_percentage;
66-
Flex m_flex_factor { 0, Flex::Type::Fr };
64+
Variant<Empty, LengthPercentage, Flex> m_value;
6765
};
6866

6967
class GridMinMax {

0 commit comments

Comments
 (0)