зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1551912 [wpt PR 16802] - [LayoutNG] Fix shape exclusion tracking., a=testonly
Automatic update from web-platform-tests [LayoutNG] Fix shape exclusion tracking. The DerivedGeometry class gets moved from exclusion-space to exclusion-space as a fast way of determining layout opportunities (where lines, etc get placed). For speed we only allocate "NGShapeExclusions" if we've seen any shapes within the formatting context. This crash was due to an inconsistent state of the: NGExclusionSpaceInternal::track_shape_exclusions_ flag. "other" NGExclusionSpaceInternal - derived_geometry_ = (non-null) - track_shape_exclusions_ = false - num_exclusions_ = 1u "this" NGExclusionSpaceInternal - derived_geometry_ = null - track_shape_exclusions_ = true - num_exclusions_ = 2u (2nd exclusion has shape data). Within the NGExclusionSpaceInternal::MoveAndUpdateDerivedGeometry method we moved the derived geometry over to the "this" exclusion space. However we didn't also move the track_shape_exclusions_ flag as a result we'd try to add the 2nd shape exclusion, and a NPE was hit. Bug: 962135, 962272, 962052 Change-Id: Id095bd2924f83ba6b2dbe90446d1f4613de09933 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/1610021 Commit-Queue: Ian Kilpatrick <ikilpatrick@chromium.org> Reviewed-by: Morten Stenshorne <mstensho@chromium.org> Reviewed-by: Christian Biesinger <cbiesinger@chromium.org> Cr-Commit-Position: refs/heads/master@{#659678} -- wp5At-commits: b6546f28b56bbe5122dc0e639e79057507632a86 wpt-pr: 16802
This commit is contained in:
Родитель
c47e87c5f8
Коммит
ae58b78a55
|
@ -0,0 +1,19 @@
|
|||
<!DOCTYPE html>
|
||||
<link rel="match" href="../../../../reference/ref-filled-green-100px-square-only.html">
|
||||
<link rel="help" href="https://crbug.com/962135" />
|
||||
<meta name="assert" content="This test passes if the renderer does not crash."/>
|
||||
<p>Test passes if there is a filled green square.</p>
|
||||
<div style="width: 100px; height: 100px; display: flow-root; background: green;">
|
||||
<div style="width: 20px; height: 20px; float: right;"></div>
|
||||
<div style="width: 20px; height: 10px; display: inline-block;"></div>
|
||||
<div style="width: 40px; height: 20px; overflow: hidden;"></div>
|
||||
<div style="width: 20px; height: 10px; display: inline-block;"></div>
|
||||
<div style="width: 50px; height: 50px; float: left; shape-outside: inset(20px 0 0 0);"></div>
|
||||
<div id="target" style="height: 50px; margin: 10px 0;"></div>
|
||||
<div style="width: 20px; height: 10px; display: inline-block;"></div>
|
||||
</div>
|
||||
<script>
|
||||
document.body.offsetTop;
|
||||
document.getElementById('target').style.height = '10px';
|
||||
document.body.offsetTop;
|
||||
</script>
|
Загрузка…
Ссылка в новой задаче