1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-25 16:27:35 +00:00

LibWeb: Use new StyleValue parsing for overflow

This commit is contained in:
Sam Atkins 2023-05-24 17:15:12 +01:00 committed by Andreas Kling
parent 2da15f987f
commit a7a61c4cd9

View file

@ -5979,28 +5979,20 @@ ErrorOr<RefPtr<StyleValue>> Parser::parse_list_style_value(Vector<ComponentValue
ErrorOr<RefPtr<StyleValue>> Parser::parse_overflow_value(Vector<ComponentValue> const& component_values) ErrorOr<RefPtr<StyleValue>> Parser::parse_overflow_value(Vector<ComponentValue> const& component_values)
{ {
auto tokens = TokenStream { component_values };
if (component_values.size() == 1) { if (component_values.size() == 1) {
auto maybe_value = TRY(parse_css_value(component_values.first())); auto maybe_value = TRY(parse_css_value_for_property(PropertyID::Overflow, tokens));
if (!maybe_value) if (!maybe_value)
return nullptr; return nullptr;
auto value = maybe_value.release_nonnull(); return OverflowStyleValue::create(*maybe_value, *maybe_value);
if (property_accepts_value(PropertyID::Overflow, *value))
return OverflowStyleValue::create(value, value);
return nullptr;
} }
if (component_values.size() == 2) { if (component_values.size() == 2) {
auto maybe_x_value = TRY(parse_css_value(component_values[0])); auto maybe_x_value = TRY(parse_css_value_for_property(PropertyID::OverflowX, tokens));
auto maybe_y_value = TRY(parse_css_value(component_values[1])); auto maybe_y_value = TRY(parse_css_value_for_property(PropertyID::OverflowY, tokens));
if (!maybe_x_value || !maybe_y_value) if (!maybe_x_value || !maybe_y_value)
return nullptr; return nullptr;
auto x_value = maybe_x_value.release_nonnull(); return OverflowStyleValue::create(maybe_x_value.release_nonnull(), maybe_y_value.release_nonnull());
auto y_value = maybe_y_value.release_nonnull();
if (!property_accepts_value(PropertyID::OverflowX, x_value) || !property_accepts_value(PropertyID::OverflowY, y_value)) {
return nullptr;
}
return OverflowStyleValue::create(x_value, y_value);
} }
return nullptr; return nullptr;