mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-09 09:39:39 +00:00
LibWeb: Handle serialization of invalid border in all contexts
Some checks are pending
CI / macOS, arm64, Sanitizer, Clang (push) Waiting to run
CI / Linux, x86_64, Fuzzers, Clang (push) Waiting to run
CI / Linux, x86_64, Sanitizer, GNU (push) Waiting to run
CI / Linux, x86_64, Sanitizer, Clang (push) Waiting to run
Package the js repl as a binary artifact / Linux, arm64 (push) Waiting to run
Package the js repl as a binary artifact / macOS, arm64 (push) Waiting to run
Package the js repl as a binary artifact / Linux, x86_64 (push) Waiting to run
Run test262 and test-wasm / run_and_update_results (push) Waiting to run
Lint Code / lint (push) Waiting to run
Label PRs with merge conflicts / auto-labeler (push) Waiting to run
Push notes / build (push) Waiting to run
Some checks are pending
CI / macOS, arm64, Sanitizer, Clang (push) Waiting to run
CI / Linux, x86_64, Fuzzers, Clang (push) Waiting to run
CI / Linux, x86_64, Sanitizer, GNU (push) Waiting to run
CI / Linux, x86_64, Sanitizer, Clang (push) Waiting to run
Package the js repl as a binary artifact / Linux, arm64 (push) Waiting to run
Package the js repl as a binary artifact / macOS, arm64 (push) Waiting to run
Package the js repl as a binary artifact / Linux, x86_64 (push) Waiting to run
Run test262 and test-wasm / run_and_update_results (push) Waiting to run
Lint Code / lint (push) Waiting to run
Label PRs with merge conflicts / auto-labeler (push) Waiting to run
Push notes / build (push) Waiting to run
Previously as we handled this in `get_property_internal` there were some contexts that we missed, for instance `CSSStyleProperties::serialized`.
This commit is contained in:
parent
927cd969b2
commit
93f957051a
Notes:
github-actions[bot]
2025-07-15 13:27:17 +00:00
Author: https://github.com/Calme1709
Commit: 93f957051a
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/5386
Reviewed-by: https://github.com/AtkinsSJ ✅
4 changed files with 21 additions and 29 deletions
|
@ -60,5 +60,5 @@ bool Paintable::is_visible() const
|
||||||
## JavaScript
|
## JavaScript
|
||||||
|
|
||||||
Some properties have special rules for getting the computed value from JS. For these, you will need to add to
|
Some properties have special rules for getting the computed value from JS. For these, you will need to add to
|
||||||
`CSSStyleProperties::style_value_for_computed_property()`. Shorthands that are constructed in an unusual way (as in, not
|
`CSSStyleProperties::style_value_for_computed_property()`. Shorthands that are serialized in an unusual way
|
||||||
using `ShorthandStyleValue`) also need handling inside `CSSStyleProperties::get_property_internal()`.
|
also need handling inside `CSSShorthandStyleValue::to_string()`.
|
||||||
|
|
|
@ -430,30 +430,6 @@ Optional<StyleProperty> CSSStyleProperties::get_property_internal(PropertyID pro
|
||||||
{
|
{
|
||||||
// 2. If property is a shorthand property, then follow these substeps:
|
// 2. If property is a shorthand property, then follow these substeps:
|
||||||
if (property_is_shorthand(property_id)) {
|
if (property_is_shorthand(property_id)) {
|
||||||
|
|
||||||
// AD-HOC: Handle shorthands that require manual construction.
|
|
||||||
switch (property_id) {
|
|
||||||
case PropertyID::Border: {
|
|
||||||
auto width = get_property_internal(PropertyID::BorderWidth);
|
|
||||||
auto style = get_property_internal(PropertyID::BorderStyle);
|
|
||||||
auto color = get_property_internal(PropertyID::BorderColor);
|
|
||||||
// `border` only has a reasonable value if all four sides are the same.
|
|
||||||
if (!width.has_value() || width->value->is_value_list() || !style.has_value() || style->value->is_value_list() || !color.has_value() || color->value->is_value_list())
|
|
||||||
return {};
|
|
||||||
if (width->important != style->important || width->important != color->important)
|
|
||||||
return {};
|
|
||||||
return StyleProperty {
|
|
||||||
.important = width->important,
|
|
||||||
.property_id = property_id,
|
|
||||||
.value = ShorthandStyleValue::create(property_id,
|
|
||||||
{ PropertyID::BorderWidth, PropertyID::BorderStyle, PropertyID::BorderColor },
|
|
||||||
{ width->value, style->value, color->value })
|
|
||||||
};
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 1. Let list be a new empty array.
|
// 1. Let list be a new empty array.
|
||||||
Vector<ValueComparingNonnullRefPtr<CSSStyleValue const>> list;
|
Vector<ValueComparingNonnullRefPtr<CSSStyleValue const>> list;
|
||||||
Optional<Important> last_important_flag;
|
Optional<Important> last_important_flag;
|
||||||
|
|
|
@ -238,6 +238,22 @@ String ShorthandStyleValue::to_string(SerializationMode mode) const
|
||||||
|
|
||||||
return MUST(builder.to_string());
|
return MUST(builder.to_string());
|
||||||
}
|
}
|
||||||
|
case PropertyID::Border: {
|
||||||
|
auto all_longhands_same_value = [](ValueComparingRefPtr<CSSStyleValue const> const& shorthand) -> bool {
|
||||||
|
VERIFY(shorthand);
|
||||||
|
VERIFY(shorthand->is_shorthand());
|
||||||
|
|
||||||
|
auto longhands = shorthand->as_shorthand().values();
|
||||||
|
|
||||||
|
return all_of(longhands, [&](auto const& longhand) { return longhand == longhands[0]; });
|
||||||
|
};
|
||||||
|
|
||||||
|
// `border` only has a reasonable value if all four sides are the same.
|
||||||
|
if (!all_longhands_same_value(longhand(PropertyID::BorderWidth)) || !all_longhands_same_value(longhand(PropertyID::BorderStyle)) || !all_longhands_same_value(longhand(PropertyID::BorderColor)))
|
||||||
|
return ""_string;
|
||||||
|
|
||||||
|
return default_to_string();
|
||||||
|
}
|
||||||
case PropertyID::BorderImage: {
|
case PropertyID::BorderImage: {
|
||||||
auto source = longhand(PropertyID::BorderImageSource);
|
auto source = longhand(PropertyID::BorderImageSource);
|
||||||
auto slice = longhand(PropertyID::BorderImageSlice);
|
auto slice = longhand(PropertyID::BorderImageSlice);
|
||||||
|
|
|
@ -2,15 +2,15 @@ Harness status: OK
|
||||||
|
|
||||||
Found 20 tests
|
Found 20 tests
|
||||||
|
|
||||||
14 Pass
|
15 Pass
|
||||||
6 Fail
|
5 Fail
|
||||||
Pass The serialization of border: 1px; border-top: 1px; should be canonical.
|
Pass The serialization of border: 1px; border-top: 1px; should be canonical.
|
||||||
Pass The serialization of border: 1px solid red; should be canonical.
|
Pass The serialization of border: 1px solid red; should be canonical.
|
||||||
Pass The serialization of border: 1px red; should be canonical.
|
Pass The serialization of border: 1px red; should be canonical.
|
||||||
Pass The serialization of border: red; should be canonical.
|
Pass The serialization of border: red; should be canonical.
|
||||||
Fail The serialization of border-top: 1px; border-right: 1px; border-bottom: 1px; border-left: 1px; border-image: none; should be canonical.
|
Fail The serialization of border-top: 1px; border-right: 1px; border-bottom: 1px; border-left: 1px; border-image: none; should be canonical.
|
||||||
Fail The serialization of border-top: 1px; border-right: 1px; border-bottom: 1px; border-left: 1px; should be canonical.
|
Fail The serialization of border-top: 1px; border-right: 1px; border-bottom: 1px; border-left: 1px; should be canonical.
|
||||||
Fail The serialization of border-top: 1px; border-right: 2px; border-bottom: 3px; border-left: 4px; should be canonical.
|
Pass The serialization of border-top: 1px; border-right: 2px; border-bottom: 3px; border-left: 4px; should be canonical.
|
||||||
Fail The serialization of border: 1px; border-top: 2px; should be canonical.
|
Fail The serialization of border: 1px; border-top: 2px; should be canonical.
|
||||||
Fail The serialization of border: 1px; border-top: 1px !important; should be canonical.
|
Fail The serialization of border: 1px; border-top: 1px !important; should be canonical.
|
||||||
Fail The serialization of border: 1px; border-top-color: red; should be canonical.
|
Fail The serialization of border: 1px; border-top-color: red; should be canonical.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue