WeasyPrint
WeasyPrint copied to clipboard
Inline-block as child of display:flex element overflows since 54
When a parent has display:flex, a child with display:inline-block gets a base-width that far overflows both the parent and the current page. This behavior was introduced in 54 and still happens with 55. 53.4 is working correctly.
Oh, in case it matters, this is all on Windows.
I made a minimal example:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>empty</title>
<style>
.testbox {
display: flex;
background-color: #eee;
}
.testbox p {
display: inline-block;
}
</style>
</head>
<body>
<div class="testbox">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in
voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident,
sunt in culpa qui officia deserunt mollit anim id est laborum.
</p>
</div>
</body>
</html>
This results in

If I add a percentage width, it takes some other, unknown width as basis (width: 50%):

Changing it to display:block fixes everything:

Related issue #1563