OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * Copyright (C) 2011 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Neither the name of Google Inc. nor the names of its | 10 * * Neither the name of Google Inc. nor the names of its |
(...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
140 // ShadowRoot doesn't support custom callbacks. | 140 // ShadowRoot doesn't support custom callbacks. |
141 DCHECK(!hasCustomStyleCallbacks()); | 141 DCHECK(!hasCustomStyleCallbacks()); |
142 | 142 |
143 StyleSharingDepthScope sharingScope(*this); | 143 StyleSharingDepthScope sharingScope(*this); |
144 | 144 |
145 if (getStyleChangeType() >= SubtreeStyleChange) | 145 if (getStyleChangeType() >= SubtreeStyleChange) |
146 change = Force; | 146 change = Force; |
147 | 147 |
148 // There's no style to update so just calling recalcStyle means we're updated. | 148 // There's no style to update so just calling recalcStyle means we're updated. |
149 clearNeedsStyleRecalc(); | 149 clearNeedsStyleRecalc(); |
150 clearNeedsReattachLayoutTree(); | |
151 | 150 |
152 recalcDescendantStyles(change); | 151 recalcDescendantStyles(change); |
153 clearChildNeedsStyleRecalc(); | 152 clearChildNeedsStyleRecalc(); |
153 | |
154 if (!host().childNeedsReattachLayoutTree()) | |
155 clearNeedsReattachLayoutTree(); | |
esprehn
2017/02/15 02:01:00
this shouldn't be needed, how do we get here with
nainar
2017/02/15 06:04:46
Given the following test case:
<script>
onload =
| |
156 } | |
157 | |
158 void ShadowRoot::rebuildLayoutTree() { | |
159 // ShadowRoot doesn't support custom callbacks. | |
160 DCHECK(!hasCustomStyleCallbacks()); | |
161 | |
162 StyleSharingDepthScope sharingScope(*this); | |
163 | |
164 clearNeedsReattachLayoutTree(); | |
165 rebuildChildrenLayoutTrees(); | |
154 clearChildNeedsReattachLayoutTree(); | 166 clearChildNeedsReattachLayoutTree(); |
155 } | 167 } |
156 | 168 |
157 void ShadowRoot::attachLayoutTree(const AttachContext& context) { | 169 void ShadowRoot::attachLayoutTree(const AttachContext& context) { |
158 StyleSharingDepthScope sharingScope(*this); | 170 StyleSharingDepthScope sharingScope(*this); |
159 DocumentFragment::attachLayoutTree(context); | 171 DocumentFragment::attachLayoutTree(context); |
160 } | 172 } |
161 | 173 |
162 void ShadowRoot::detachLayoutTree(const AttachContext& context) { | 174 void ShadowRoot::detachLayoutTree(const AttachContext& context) { |
163 if (context.clearInvalidation) | 175 if (context.clearInvalidation) |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
334 ostream << "ShadowRootType::Open"; | 346 ostream << "ShadowRootType::Open"; |
335 break; | 347 break; |
336 case ShadowRootType::Closed: | 348 case ShadowRootType::Closed: |
337 ostream << "ShadowRootType::Closed"; | 349 ostream << "ShadowRootType::Closed"; |
338 break; | 350 break; |
339 } | 351 } |
340 return ostream; | 352 return ostream; |
341 } | 353 } |
342 | 354 |
343 } // namespace blink | 355 } // namespace blink |
OLD | NEW |