mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-09-16 14:32:18 +00:00
LibWeb: Fix size computation for elements with max-width and max-height
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
The specification [1] indicates that the tentative used width and height should be computed first, and if they exceed the `max-width` or `max-height`, the rules should be applied again using the computed values of `max-width` and `max-height`. The only required change to follow the spec is to remove the early `return` statements, in both `compute_width_for_replaced_element` and `compute_height_for_replaced_element`. Fixes #5100. [1] https://www.w3.org/TR/CSS22/visudet.html#min-max-widths
This commit is contained in:
parent
45127aee88
commit
89036dd70c
Notes:
github-actions[bot]
2025-07-20 15:35:28 +00:00
Author: https://github.com/adamantike
Commit: 89036dd70c
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/5526
Reviewed-by: https://github.com/gmta ✅
3 changed files with 23 additions and 3 deletions
|
@ -583,10 +583,9 @@ CSSPixels FormattingContext::compute_width_for_replaced_element(Box const& box,
|
|||
CSSPixels w = used_width;
|
||||
CSSPixels h = tentative_height_for_replaced_element(box, computed_height, available_space);
|
||||
used_width = solve_replaced_size_constraint(w, h, box, available_space).width();
|
||||
return used_width;
|
||||
}
|
||||
|
||||
// 2. The tentative used width is greater than 'max-width', the rules above are applied again,
|
||||
// 2. If the tentative used width is greater than 'max-width', the rules above are applied again,
|
||||
// but this time using the computed value of 'max-width' as the computed value for 'width'.
|
||||
if (!should_treat_max_width_as_none(box, available_space.width)) {
|
||||
auto const& computed_max_width = box.computed_values().max_width();
|
||||
|
@ -661,7 +660,6 @@ CSSPixels FormattingContext::compute_height_for_replaced_element(Box const& box,
|
|||
CSSPixels w = tentative_width_for_replaced_element(box, computed_width, available_space);
|
||||
CSSPixels h = used_height;
|
||||
used_height = solve_replaced_size_constraint(w, h, box, available_space).height();
|
||||
return used_height;
|
||||
}
|
||||
|
||||
// 2. If this tentative height is greater than 'max-height', the rules above are applied again,
|
||||
|
|
|
@ -0,0 +1,14 @@
|
|||
Viewport <#document> at (0,0) content-size 800x600 children: not-inline
|
||||
BlockContainer <html> at (1,1) content-size 798x70 [BFC] children: not-inline
|
||||
BlockContainer <body> at (10,10) content-size 780x52 children: inline
|
||||
frag 0 from ImageBox start: 0, length: 0, rect: [11,11 66.65625x50] baseline: 52
|
||||
ImageBox <img> at (11,11) content-size 66.65625x50 children: not-inline
|
||||
TextNode <#text>
|
||||
|
||||
ViewportPaintable (Viewport<#document>) [0,0 800x600]
|
||||
PaintableWithLines (BlockContainer<HTML>) [0,0 800x72]
|
||||
PaintableWithLines (BlockContainer<BODY>) [9,9 782x54]
|
||||
ImagePaintable (ImageBox<IMG>) [10,10 68.65625x52]
|
||||
|
||||
SC for Viewport<#document> [0,0 800x600] [children: 1] (z-index: auto)
|
||||
SC for BlockContainer<HTML> [1,1 798x70] [children: 0] (z-index: auto)
|
|
@ -0,0 +1,8 @@
|
|||
<!DOCTYPE html><style>
|
||||
* { border: 1px solid black; }
|
||||
body { background: #444; }
|
||||
img {
|
||||
max-height: 50px;
|
||||
max-width: 100px;
|
||||
}
|
||||
</style><img src="" />
|
Loading…
Add table
Add a link
Reference in a new issue