OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010 Google, Inc. All Rights Reserved. | 2 * Copyright (C) 2010 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 | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 24 matching lines...) Expand all Loading... |
35 | 35 |
36 ScriptRunner::ScriptRunner(Document* document) | 36 ScriptRunner::ScriptRunner(Document* document) |
37 : m_document(document) | 37 : m_document(document) |
38 , m_timer(this, &ScriptRunner::timerFired) | 38 , m_timer(this, &ScriptRunner::timerFired) |
39 { | 39 { |
40 ASSERT(document); | 40 ASSERT(document); |
41 } | 41 } |
42 | 42 |
43 ScriptRunner::~ScriptRunner() | 43 ScriptRunner::~ScriptRunner() |
44 { | 44 { |
| 45 #if !ENABLE(OILPAN) |
45 // Make sure that ScriptLoaders don't keep their PendingScripts alive. | 46 // Make sure that ScriptLoaders don't keep their PendingScripts alive. |
46 for (size_t i = 0; i < m_scriptsToExecuteInOrder.size(); ++i) | 47 for (ScriptLoader* scriptLoader : m_scriptsToExecuteInOrder) |
47 m_scriptsToExecuteInOrder[i]->detach(); | 48 scriptLoader->detach(); |
48 for (size_t i = 0; i < m_scriptsToExecuteSoon.size(); ++i) | 49 for (ScriptLoader* scriptLoader : m_scriptsToExecuteSoon) |
49 m_scriptsToExecuteSoon[i]->detach(); | 50 scriptLoader->detach(); |
50 for (HashSet<ScriptLoader*>::iterator it = m_pendingAsyncScripts.begin(); it
!= m_pendingAsyncScripts.end(); ++it) | 51 for (ScriptLoader* scriptLoader : m_pendingAsyncScripts) |
51 (*it)->detach(); | 52 scriptLoader->detach(); |
| 53 #endif |
52 } | 54 } |
53 | 55 |
54 void ScriptRunner::addPendingAsyncScript(ScriptLoader* scriptLoader) | 56 void ScriptRunner::addPendingAsyncScript(ScriptLoader* scriptLoader) |
55 { | 57 { |
56 m_document->incrementLoadEventDelayCount(); | 58 m_document->incrementLoadEventDelayCount(); |
57 m_pendingAsyncScripts.add(scriptLoader); | 59 m_pendingAsyncScripts.add(scriptLoader); |
58 } | 60 } |
59 | 61 |
60 void ScriptRunner::queueScriptForExecution(ScriptLoader* scriptLoader, Execution
Type executionType) | 62 void ScriptRunner::queueScriptForExecution(ScriptLoader* scriptLoader, Execution
Type executionType) |
61 { | 63 { |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
124 m_document->decrementLoadEventDelayCount(); | 126 m_document->decrementLoadEventDelayCount(); |
125 } | 127 } |
126 } | 128 } |
127 | 129 |
128 void ScriptRunner::timerFired(Timer<ScriptRunner>* timer) | 130 void ScriptRunner::timerFired(Timer<ScriptRunner>* timer) |
129 { | 131 { |
130 ASSERT_UNUSED(timer, timer == &m_timer); | 132 ASSERT_UNUSED(timer, timer == &m_timer); |
131 | 133 |
132 RefPtrWillBeRawPtr<Document> protect(m_document.get()); | 134 RefPtrWillBeRawPtr<Document> protect(m_document.get()); |
133 | 135 |
134 Vector<ScriptLoader*> scriptLoaders; | 136 WillBeHeapVector<RawPtrWillBeMember<ScriptLoader> > scriptLoaders; |
135 scriptLoaders.swap(m_scriptsToExecuteSoon); | 137 scriptLoaders.swap(m_scriptsToExecuteSoon); |
136 | 138 |
137 size_t numInOrderScriptsToExecute = 0; | 139 size_t numInOrderScriptsToExecute = 0; |
138 for (; numInOrderScriptsToExecute < m_scriptsToExecuteInOrder.size() && m_sc
riptsToExecuteInOrder[numInOrderScriptsToExecute]->isReady(); ++numInOrderScript
sToExecute) | 140 for (; numInOrderScriptsToExecute < m_scriptsToExecuteInOrder.size() && m_sc
riptsToExecuteInOrder[numInOrderScriptsToExecute]->isReady(); ++numInOrderScript
sToExecute) |
139 scriptLoaders.append(m_scriptsToExecuteInOrder[numInOrderScriptsToExecut
e]); | 141 scriptLoaders.append(m_scriptsToExecuteInOrder[numInOrderScriptsToExecut
e]); |
140 if (numInOrderScriptsToExecute) | 142 if (numInOrderScriptsToExecute) |
141 m_scriptsToExecuteInOrder.remove(0, numInOrderScriptsToExecute); | 143 m_scriptsToExecuteInOrder.remove(0, numInOrderScriptsToExecute); |
142 | 144 |
143 size_t size = scriptLoaders.size(); | 145 size_t size = scriptLoaders.size(); |
144 for (size_t i = 0; i < size; ++i) { | 146 for (size_t i = 0; i < size; ++i) { |
145 scriptLoaders[i]->execute(); | 147 scriptLoaders[i]->execute(); |
146 m_document->decrementLoadEventDelayCount(); | 148 m_document->decrementLoadEventDelayCount(); |
147 } | 149 } |
148 } | 150 } |
149 | 151 |
150 void ScriptRunner::trace(Visitor* visitor) | 152 void ScriptRunner::trace(Visitor* visitor) |
151 { | 153 { |
152 #if ENABLE(OILPAN) | 154 #if ENABLE(OILPAN) |
153 visitor->trace(m_document); | 155 visitor->trace(m_document); |
154 visitor->trace(m_scriptsToExecuteInOrder); | 156 visitor->trace(m_scriptsToExecuteInOrder); |
155 visitor->trace(m_scriptsToExecuteSoon); | 157 visitor->trace(m_scriptsToExecuteSoon); |
156 visitor->trace(m_pendingAsyncScripts); | 158 visitor->trace(m_pendingAsyncScripts); |
157 #endif | 159 #endif |
158 } | 160 } |
159 | 161 |
160 } | 162 } |
OLD | NEW |