Title: [275133] trunk
Revision
275133
Author
[email protected]
Date
2021-03-27 06:51:18 -0700 (Sat, 27 Mar 2021)

Log Message

[Multicolumn] Do not try to re-validate a multicol spanner when the renderer is moved internally
https://bugs.webkit.org/show_bug.cgi?id=223836
<rdar://75742694>

Reviewed by Ryosuke Niwa.

Source/WebCore:

When a renderer becomes a multicol spanner
1. it is moved out of its original tree position and placed as a sibling of the enclosing multicolumn flow and
2. a spanner placeholder is constructed and inserted at the original position

This patch fixes the case when an already placed multicol spanner is internally moved (e.g. collapsing an anonymous block parent)
and we attempt to re-insert this spanner to the multicolumn flow. No spanner state should change due to internal re-parenting.

Test: fast/multicol/spanner-get-re-added-on-move-crash.html

* rendering/updating/RenderTreeBuilder.cpp:
(WebCore::RenderTreeBuilder::attachToRenderElementInternal):

LayoutTests:

* TestExpectations:
* fast/multicol/spanner-get-re-added-on-move-crash-expected.txt: Added.
* fast/multicol/spanner-get-re-added-on-move-crash.html: Added.

Modified Paths

Added Paths

Diff

Modified: trunk/LayoutTests/ChangeLog (275132 => 275133)


--- trunk/LayoutTests/ChangeLog	2021-03-27 10:52:17 UTC (rev 275132)
+++ trunk/LayoutTests/ChangeLog	2021-03-27 13:51:18 UTC (rev 275133)
@@ -1,3 +1,15 @@
+2021-03-27  Zalan Bujtas  <[email protected]>
+
+        [Multicolumn] Do not try to re-validate a multicol spanner when the renderer is moved internally
+        https://bugs.webkit.org/show_bug.cgi?id=223836
+        <rdar://75742694>
+
+        Reviewed by Ryosuke Niwa.
+
+        * TestExpectations:
+        * fast/multicol/spanner-get-re-added-on-move-crash-expected.txt: Added.
+        * fast/multicol/spanner-get-re-added-on-move-crash.html: Added.
+
 2021-03-26  Robert Jenner  <[email protected]>
 
         [ macOS ] inspector/debugger/csp-exceptions.html is a flakey text failure

Modified: trunk/LayoutTests/TestExpectations (275132 => 275133)


--- trunk/LayoutTests/TestExpectations	2021-03-27 10:52:17 UTC (rev 275132)
+++ trunk/LayoutTests/TestExpectations	2021-03-27 13:51:18 UTC (rev 275133)
@@ -5002,3 +5002,4 @@
 imported/w3c/web-platform-tests/css/css-counter-styles/upper-roman/css3-counter-styles-024a.html [ ImageOnlyFailure ]
 
 webkit.org/b/223170 [ Debug ] fast/multicol/widow-relayout-with-border-fit.html [ Skip ]
+webkit.org/b/31278 [ Debug ] fast/multicol/spanner-get-re-added-on-move-crash.html [ Skip ]

Added: trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash-expected.txt (0 => 275133)


--- trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash-expected.txt	                        (rev 0)
+++ trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash-expected.txt	2021-03-27 13:51:18 UTC (rev 275133)
@@ -0,0 +1,2 @@
+PASS if no crash in release.
+

Added: trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash.html (0 => 275133)


--- trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash.html	                        (rev 0)
+++ trunk/LayoutTests/fast/multicol/spanner-get-re-added-on-move-crash.html	2021-03-27 13:51:18 UTC (rev 275133)
@@ -0,0 +1,49 @@
+<style>
+*:read-write {
+  -webkit-transform: skewX(180deg);
+  display: table-caption;
+  position: relative;
+  column-count: 2;
+}
+
+span {
+  list-style-image: url();
+}
+
+* {
+  position: fixed;
+  column-span: all;
+}
+
+#gradient {
+  display: table;
+}
+</style>
+
+<script>
+if (window.testRunner)
+  testRunner.dumpAsText();
+
+let callPrepend = true;
+
+function func() {
+  if (callPrepend) {
+    callPrepend = false;
+    fobject.prepend(gradient);
+  }
+  image.insertAdjacentHTML("beforebegin", fobject.outerHTML);
+  document.designMode = "off";
+}
+
+function runTest() {
+  document.documentElement._onselectstart_ = func;
+  document.designMode = "on";
+  document.execCommand("selectAll", false, null);
+}
+
+</script>
+
+<body _onload_="runTest()">
+<div></div>PASS if no crash in release.
+<svg><linearGradient id=gradient></linearGradient><foreignObject id=fobject></foreignObject><image id=image></svg>
+<span style="display: contents"><details _ontoggle_="func()" contenteditable="false" open="">
\ No newline at end of file

Modified: trunk/Source/WebCore/ChangeLog (275132 => 275133)


--- trunk/Source/WebCore/ChangeLog	2021-03-27 10:52:17 UTC (rev 275132)
+++ trunk/Source/WebCore/ChangeLog	2021-03-27 13:51:18 UTC (rev 275133)
@@ -1,3 +1,23 @@
+2021-03-27  Zalan Bujtas  <[email protected]>
+
+        [Multicolumn] Do not try to re-validate a multicol spanner when the renderer is moved internally
+        https://bugs.webkit.org/show_bug.cgi?id=223836
+        <rdar://75742694>
+
+        Reviewed by Ryosuke Niwa.
+
+        When a renderer becomes a multicol spanner 
+        1. it is moved out of its original tree position and placed as a sibling of the enclosing multicolumn flow and
+        2. a spanner placeholder is constructed and inserted at the original position
+
+        This patch fixes the case when an already placed multicol spanner is internally moved (e.g. collapsing an anonymous block parent)
+        and we attempt to re-insert this spanner to the multicolumn flow. No spanner state should change due to internal re-parenting. 
+
+        Test: fast/multicol/spanner-get-re-added-on-move-crash.html
+
+        * rendering/updating/RenderTreeBuilder.cpp:
+        (WebCore::RenderTreeBuilder::attachToRenderElementInternal):
+
 2021-03-26  Ian Gilbert  <[email protected]>
 
         Dirty layout for floating children of inline on full layout

Modified: trunk/Source/WebCore/rendering/updating/RenderTreeBuilder.cpp (275132 => 275133)


--- trunk/Source/WebCore/rendering/updating/RenderTreeBuilder.cpp	2021-03-27 10:52:17 UTC (rev 275132)
+++ trunk/Source/WebCore/rendering/updating/RenderTreeBuilder.cpp	2021-03-27 13:51:18 UTC (rev 275133)
@@ -447,14 +447,14 @@
     if (!parent.renderTreeBeingDestroyed()) {
         newChild->insertedIntoTree();
 
-        auto* fragmentedFlow = newChild->enclosingFragmentedFlow();
-        if (is<RenderMultiColumnFlow>(fragmentedFlow))
-            multiColumnBuilder().multiColumnDescendantInserted(downcast<RenderMultiColumnFlow>(*fragmentedFlow), *newChild);
+        auto needsStateReset = reinsertAfterMove == ReinsertAfterMove::No;
+        if (needsStateReset) {
+            if (auto* fragmentedFlow = newChild->enclosingFragmentedFlow(); is<RenderMultiColumnFlow>(fragmentedFlow))
+                multiColumnBuilder().multiColumnDescendantInserted(downcast<RenderMultiColumnFlow>(*fragmentedFlow), *newChild);
 
-        // FIXME: needsStateReset could probably be used for multicolumn as well.
-        auto needsStateReset = reinsertAfterMove == ReinsertAfterMove::No;
-        if (needsStateReset && is<RenderElement>(*newChild))
-            RenderCounter::rendererSubtreeAttached(downcast<RenderElement>(*newChild));
+            if (is<RenderElement>(*newChild))
+                RenderCounter::rendererSubtreeAttached(downcast<RenderElement>(*newChild));
+        }
     }
 
     newChild->setNeedsLayoutAndPrefWidthsRecalc();
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to