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

Side by Side Diff: Source/platform/scheduler/DoubleBufferedDeque.h

Issue 439923006: Prioritizing input and compositor tasks in the blink scheduler. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Rebase + respond to Eric's feedback Created 6 years, 4 months 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 #ifndef DoubleBufferedDeque_h
6 #define DoubleBufferedDeque_h
7
8 #include "wtf/Deque.h"
9 #include "wtf/Noncopyable.h"
10
11 namespace blink {
12
13 template <typename T> class DoubleBufferedDeque {
eseidel 2014/08/11 15:19:14 Base datatypes like this probably belong in wtf.
alexclarke 2014/08/12 11:37:02 Done.
14 WTF_MAKE_NONCOPYABLE(DoubleBufferedDeque);
15 public:
16 DoubleBufferedDeque()
17 : m_activeIndex(0) { }
18
19 void append(const T& value)
20 {
21 m_queue[m_activeIndex].append(value);
22 }
23
24 bool isEmpty()
25 {
26 return m_queue[m_activeIndex].isEmpty();
27 }
28
29 WTF::Deque<T>& swapBuffers()
30 {
31 int oldIndex = m_activeIndex;
32 m_activeIndex ^= 1;
33 ASSERT(m_queue[m_activeIndex].isEmpty());
34 return m_queue[oldIndex];
35 }
36
37 private:
38 WTF::Deque<T> m_queue[2];
39 int m_activeIndex;
40 };
41
42 } // namespace blink
43
44 #endif // DoubleBufferedDeque_h
OLDNEW
« no previous file with comments | « Source/platform/blink_platform.gypi ('k') | Source/platform/scheduler/DoubleBufferedDequeTest.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698