[Mac] WebInspectorUI.framework does not need to be soft-linked anymore
[WebKit-https.git] / Tools / DumpRenderTree / WorkQueue.cpp
1 /*
2  * Copyright (C) 2007, 2009 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * 1.  Redistributions of source code must retain the above copyright
9  *     notice, this list of conditions and the following disclaimer. 
10  * 2.  Redistributions in binary form must reproduce the above copyright
11  *     notice, this list of conditions and the following disclaimer in the
12  *     documentation and/or other materials provided with the distribution. 
13  * 3.  Neither the name of Apple Inc. ("Apple") nor the names of
14  *     its contributors may be used to endorse or promote products derived
15  *     from this software without specific prior written permission. 
16  *
17  * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
21  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28
29 #include "config.h"
30 #include "WorkQueue.h"
31
32 #include "WorkQueueItem.h"
33 #include <wtf/Assertions.h>
34 #include <wtf/NeverDestroyed.h>
35
36 namespace DRT {
37
38 static const unsigned queueLength = 1024;
39
40 static WorkQueueItem* theQueue[queueLength];
41 static unsigned startOfQueue;
42 static unsigned endOfQueue;
43
44 WorkQueue& WorkQueue::singleton()
45 {
46     static NeverDestroyed<WorkQueue> sharedInstance;
47     return sharedInstance;
48 }
49
50 WorkQueue::WorkQueue()
51     : m_frozen(false)
52 {
53 }
54
55 void WorkQueue::queue(WorkQueueItem* item)
56 {
57     ASSERT(endOfQueue < queueLength);
58     ASSERT(endOfQueue >= startOfQueue);
59
60     if (m_frozen) {
61         delete item;
62         return;
63     }
64
65     theQueue[endOfQueue++] = item;
66 }
67
68 WorkQueueItem* WorkQueue::dequeue()
69 {
70     ASSERT(endOfQueue >= startOfQueue);
71
72     if (startOfQueue == endOfQueue)
73         return 0;
74
75     return theQueue[startOfQueue++];
76 }
77
78 unsigned WorkQueue::count()
79 {
80     return endOfQueue - startOfQueue;
81 }
82
83 void WorkQueue::clear()
84 {
85     for (unsigned i = startOfQueue; i < endOfQueue; ++i) {
86         delete theQueue[i];
87         theQueue[i] = 0;
88     }
89
90     startOfQueue = 0;
91     endOfQueue = 0;
92 }
93
94 bool WorkQueue::processWork()
95 {
96     bool startedLoad = false;
97
98     while (!startedLoad && count()) {
99         WorkQueueItem* item = dequeue();
100         ASSERT(item);
101         startedLoad = item->invoke();
102         delete item;
103     }
104
105     // If we're done and we didn't start a load, then we're really done, so return true.
106     return !startedLoad;
107 }
108
109 }