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

LibWeb: Use separate structure to represent fragments in paintable tree

This is a part of refactoring towards making the paintable tree
independent of the layout tree. Now, instead of transferring text
fragments from the layout tree to the paintable tree during the layout
commit phase, we allocate separate PaintableFragments that contain only
the information necessary for painting. Doing this also allows us to
get rid LineBoxes, as they are used only during layout.
This commit is contained in:
Aliaksandr Kalenik 2024-01-12 21:25:05 +01:00 committed by Andreas Kling
parent 785fa60cca
commit de32b77ceb
401 changed files with 2122 additions and 3614 deletions

View file

@ -2,81 +2,65 @@ Viewport <#document> at (0,0) content-size 800x600 children: not-inline
BlockContainer <html> at (100,0) content-size 700x832 [BFC] children: not-inline
BlockContainer <body> at (200,8) content-size 592x816 children: not-inline
BlockContainer <div> at (301,9) content-size 100x100 children: inline
line 0 width: 79.96875, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 11, rect: [301,9 79.96875x17]
frag 0 from TextNode start: 0, length: 11, rect: [301,9 79.96875x17] baseline: 13.296875
"Well, hello"
line 1 width: 59.21875, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 12, length: 8, rect: [301,26 59.21875x17]
frag 1 from TextNode start: 12, length: 8, rect: [301,26 59.21875x17] baseline: 13.296875
"friends!"
TextNode <#text>
BlockContainer <(anonymous)> at (200,110) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (301,111) content-size 100x100 children: inline
line 0 width: 79.96875, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 11, rect: [301,111 79.96875x17]
frag 0 from TextNode start: 0, length: 11, rect: [301,111 79.96875x17] baseline: 13.296875
"Well, hello"
line 1 width: 59.21875, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 12, length: 8, rect: [301,128 59.21875x17]
frag 1 from TextNode start: 12, length: 8, rect: [301,128 59.21875x17] baseline: 13.296875
"friends!"
TextNode <#text>
BlockContainer <(anonymous)> at (200,212) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (401,213) content-size 100x100 children: inline
line 0 width: 79.96875, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 11, rect: [401,213 79.96875x17]
frag 0 from TextNode start: 0, length: 11, rect: [401,213 79.96875x17] baseline: 13.296875
"Well, hello"
line 1 width: 59.21875, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 12, length: 8, rect: [401,230 59.21875x17]
frag 1 from TextNode start: 12, length: 8, rect: [401,230 59.21875x17] baseline: 13.296875
"friends!"
TextNode <#text>
BlockContainer <(anonymous)> at (200,314) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (301,315) content-size 100x100 children: inline
line 0 width: 79.96875, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 11, rect: [301,315 79.96875x17]
frag 0 from TextNode start: 0, length: 11, rect: [301,315 79.96875x17] baseline: 13.296875
"Well, hello"
line 1 width: 59.21875, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 12, length: 8, rect: [301,332 59.21875x17]
frag 1 from TextNode start: 12, length: 8, rect: [301,332 59.21875x17] baseline: 13.296875
"friends!"
TextNode <#text>
BlockContainer <(anonymous)> at (200,416) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (301,417) content-size 100x100 children: inline
line 0 width: 86.125, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 26, rect: [301,417 86.125x17]
frag 0 from TextNode start: 0, length: 26, rect: [301,417 86.125x17] baseline: 13.296875
"حسنًا ، مرحباً"
line 1 width: 78.125, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 27, length: 25, rect: [301,434 78.125x17]
frag 1 from TextNode start: 27, length: 25, rect: [301,434 78.125x17] baseline: 13.296875
"أيها الأصدقاء"
TextNode <#text>
BlockContainer <(anonymous)> at (200,518) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (301,519) content-size 100x100 children: inline
line 0 width: 86.125, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 26, rect: [301,519 86.125x17]
frag 0 from TextNode start: 0, length: 26, rect: [301,519 86.125x17] baseline: 13.296875
"حسنًا ، مرحباً"
line 1 width: 78.125, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 27, length: 25, rect: [301,536 78.125x17]
frag 1 from TextNode start: 27, length: 25, rect: [301,536 78.125x17] baseline: 13.296875
"أيها الأصدقاء"
TextNode <#text>
BlockContainer <(anonymous)> at (200,620) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (401,621) content-size 100x100 children: inline
line 0 width: 86.125, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 26, rect: [401,621 86.125x17]
frag 0 from TextNode start: 0, length: 26, rect: [401,621 86.125x17] baseline: 13.296875
"حسنًا ، مرحباً"
line 1 width: 78.125, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 27, length: 25, rect: [401,638 78.125x17]
frag 1 from TextNode start: 27, length: 25, rect: [401,638 78.125x17] baseline: 13.296875
"أيها الأصدقاء"
TextNode <#text>
BlockContainer <(anonymous)> at (200,722) content-size 592x0 children: inline
TextNode <#text>
BlockContainer <div> at (401,723) content-size 100x100 children: inline
line 0 width: 86.125, height: 17, bottom: 17, baseline: 13.296875
frag 0 from TextNode start: 0, length: 26, rect: [401,723 86.125x17]
frag 0 from TextNode start: 0, length: 26, rect: [401,723 86.125x17] baseline: 13.296875
"حسنًا ، مرحباً"
line 1 width: 78.125, height: 17, bottom: 34, baseline: 13.296875
frag 0 from TextNode start: 27, length: 25, rect: [401,740 78.125x17]
frag 1 from TextNode start: 27, length: 25, rect: [401,740 78.125x17] baseline: 13.296875
"أيها الأصدقاء"
TextNode <#text>
BlockContainer <(anonymous)> at (200,824) content-size 592x0 children: inline