diff --git a/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp b/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp index c367dd1b95..509c5594b0 100644 --- a/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp +++ b/Userland/Libraries/LibWeb/CSS/Parser/Parser.cpp @@ -1777,6 +1777,13 @@ RefPtr Parser::parse_box_shadow_value(ParsingContext const& context, return BoxShadowStyleValue::create(offset_x, offset_y, blur_radius, color); } +RefPtr Parser::parse_as_css_value(PropertyID property_id) +{ + auto component_values = parse_as_list_of_component_values(); + auto tokens = TokenStream(component_values); + return parse_css_value(property_id, tokens); +} + RefPtr Parser::parse_css_value(PropertyID property_id, TokenStream& tokens) { Vector component_values; @@ -2405,3 +2412,46 @@ OwnPtr Parser::parse_calc_sum(ParsingContext cons } } + +namespace Web { + +RefPtr parse_css(CSS::ParsingContext const& context, StringView const& css) +{ + if (css.is_empty()) + return CSS::CSSStyleSheet::create({}); + CSS::Parser parser(context, css); + return parser.parse_as_stylesheet(); +} + +RefPtr parse_css_declaration(CSS::ParsingContext const& context, StringView const& css) +{ + if (css.is_empty()) + return CSS::CSSStyleDeclaration::create({}, {}); + CSS::Parser parser(context, css); + return parser.parse_as_list_of_declarations(); +} + +RefPtr parse_css_value(CSS::ParsingContext const& context, StringView const& string, CSS::PropertyID property_id) +{ + if (string.is_empty()) + return {}; + CSS::Parser parser(context, string); + return parser.parse_as_css_value(property_id); +} + +Optional parse_selector(CSS::ParsingContext const& context, StringView const& selector_text) +{ + CSS::Parser parser(context, selector_text); + return parser.parse_as_selector(); +} + +RefPtr parse_html_length(DOM::Document const& document, StringView const& string) +{ + auto integer = string.to_int(); + if (integer.has_value()) + return CSS::LengthStyleValue::create(CSS::Length::make_px(integer.value())); + // FIXME: The const_cast is a hack. + return parse_css_value(CSS::ParsingContext(const_cast(document)), string); +} + +} diff --git a/Userland/Libraries/LibWeb/CSS/Parser/Parser.h b/Userland/Libraries/LibWeb/CSS/Parser/Parser.h index 2e2f35a34d..ffe7d7c223 100644 --- a/Userland/Libraries/LibWeb/CSS/Parser/Parser.h +++ b/Userland/Libraries/LibWeb/CSS/Parser/Parser.h @@ -93,6 +93,8 @@ public: Optional parse_as_selector(); Optional parse_as_relative_selector(); + RefPtr parse_as_css_value(PropertyID); + // FIXME: These want to be private, but StyleResolver still uses them for now. RefPtr parse_css_value(PropertyID, TokenStream&); static RefPtr parse_css_value(ParsingContext const&, PropertyID, StyleComponentValueRule const&); @@ -206,3 +208,14 @@ private: }; } + +namespace Web { + +RefPtr parse_css(CSS::ParsingContext const&, StringView const&); +RefPtr parse_css_declaration(CSS::ParsingContext const&, StringView const&); +RefPtr parse_css_value(CSS::ParsingContext const&, StringView const&, CSS::PropertyID property_id = CSS::PropertyID::Invalid); +Optional parse_selector(CSS::ParsingContext const&, StringView const&); + +RefPtr parse_html_length(DOM::Document const&, StringView const&); + +}