Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(905)

Side by Side Diff: cc/test/delayed_raster_trigger.cc

Issue 671653005: SetNeedsRedraw directly when updating a visible tile. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: pinchblurmerge-test: tweak Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "cc/test/delayed_raster_trigger.h"
6
7 #include "base/bind.h"
8
9 namespace cc {
10
11 DelayedRasterTrigger::DelayedRasterTrigger() : should_delay_(false) {
12 }
13
14 DelayedRasterTrigger::~DelayedRasterTrigger() {
15 }
16
17 void DelayedRasterTrigger::Delay() {
18 base::WaitableEvent waiter(false /* manual_reset */,
19 false /* initially_signaled */);
20 {
21 base::AutoLock lock(lock_);
22 if (!should_delay_)
23 return;
24 delayed_raster_tasks_.push_back(&waiter);
25 }
26 waiter.Wait();
27 }
28
29 void DelayedRasterTrigger::BeginDelay() {
30 base::AutoLock lock(lock_);
31 should_delay_ = true;
32 }
33
34 void DelayedRasterTrigger::EndDelay() {
35 base::AutoLock lock(lock_);
36 should_delay_ = false;
37 for (const auto& waiter : delayed_raster_tasks_)
38 waiter->Signal();
39 }
40
41 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698