Chromium Code Reviews| OLD | NEW | 
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "core/page/PageAnimator.h" | 5 #include "core/page/PageAnimator.h" | 
| 6 | 6 | 
| 7 #include "core/animation/DocumentAnimations.h" | 7 #include "core/animation/DocumentAnimations.h" | 
| 8 #include "core/frame/FrameView.h" | 8 #include "core/frame/FrameView.h" | 
| 9 #include "core/frame/LocalFrame.h" | 9 #include "core/frame/LocalFrame.h" | 
| 10 #include "core/page/ChromeClient.h" | 10 #include "core/page/ChromeClient.h" | 
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 66 } | 66 } | 
| 67 SVGDocumentExtensions::serviceOnAnimationFrame(*document); | 67 SVGDocumentExtensions::serviceOnAnimationFrame(*document); | 
| 68 } | 68 } | 
| 69 // TODO(skyostil): This function should not run for documents without views. | 69 // TODO(skyostil): This function should not run for documents without views. | 
| 70 DocumentLifecycle::DisallowThrottlingScope noThrottlingScope( | 70 DocumentLifecycle::DisallowThrottlingScope noThrottlingScope( | 
| 71 document->lifecycle()); | 71 document->lifecycle()); | 
| 72 document->serviceScriptedAnimations(monotonicAnimationStartTime); | 72 document->serviceScriptedAnimations(monotonicAnimationStartTime); | 
| 73 } | 73 } | 
| 74 } | 74 } | 
| 75 | 75 | 
| 76 void PageAnimator::setSuppressFrameRequestsWorkaroundFor704763Only( | |
| 77 bool suppressFrameRequests) { | |
| 78 // If we are enabling the suppression and it was already enabled then we must | |
| 79 // have missed disabling it at the end of a previous frame. | |
| 80 DCHECK(!m_suppressFrameRequestsWorkaroundFor704763Only || | |
| 
 
esprehn
2017/04/05 08:33:02
This could be != Instead of the or I think?
 
alancutter (OOO until 2018)
2017/04/05 10:04:18
It used to be but some tests call UpdateVisualStat
 
 | |
| 81 !suppressFrameRequests); | |
| 82 m_suppressFrameRequestsWorkaroundFor704763Only = suppressFrameRequests; | |
| 83 } | |
| 84 | |
| 76 DISABLE_CFI_PERF | 85 DISABLE_CFI_PERF | 
| 77 void PageAnimator::scheduleVisualUpdate(LocalFrame* frame) { | 86 void PageAnimator::scheduleVisualUpdate(LocalFrame* frame) { | 
| 78 if (m_servicingAnimations || m_updatingLayoutAndStyleForPainting) | 87 if (m_servicingAnimations || m_updatingLayoutAndStyleForPainting || | 
| 88 m_suppressFrameRequestsWorkaroundFor704763Only) { | |
| 79 return; | 89 return; | 
| 90 } | |
| 80 m_page->chromeClient().scheduleAnimation(frame->view()); | 91 m_page->chromeClient().scheduleAnimation(frame->view()); | 
| 81 } | 92 } | 
| 82 | 93 | 
| 83 void PageAnimator::updateAllLifecyclePhases(LocalFrame& rootFrame) { | 94 void PageAnimator::updateAllLifecyclePhases(LocalFrame& rootFrame) { | 
| 84 FrameView* view = rootFrame.view(); | 95 FrameView* view = rootFrame.view(); | 
| 85 AutoReset<bool> servicing(&m_updatingLayoutAndStyleForPainting, true); | 96 AutoReset<bool> servicing(&m_updatingLayoutAndStyleForPainting, true); | 
| 86 view->updateAllLifecyclePhases(); | 97 view->updateAllLifecyclePhases(); | 
| 87 } | 98 } | 
| 88 | 99 | 
| 89 } // namespace blink | 100 } // namespace blink | 
| OLD | NEW |