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

Unified Diff: Source/core/workers/WorkerThread.cpp

Issue 307943002: Oilpan: Prepare moving InspectorController and InspectorAgents to oilpan. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Fixed Created 6 years, 6 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 side-by-side diff with in-line comments
Download patch
Index: Source/core/workers/WorkerThread.cpp
diff --git a/Source/core/workers/WorkerThread.cpp b/Source/core/workers/WorkerThread.cpp
index b04391a18c04666cd2b1d94e7c2d2366d1203f90..5e5781c72e2eb783385b08c16e6cc3879eb809f0 100644
--- a/Source/core/workers/WorkerThread.cpp
+++ b/Source/core/workers/WorkerThread.cpp
@@ -30,6 +30,8 @@
#include "bindings/v8/ScriptSourceCode.h"
#include "core/inspector/InspectorInstrumentation.h"
+#include "core/inspector/WorkerDebuggerAgent.h"
+#include "core/inspector/WorkerInspectorController.h"
#include "core/workers/DedicatedWorkerGlobalScope.h"
#include "core/workers/WorkerClients.h"
#include "core/workers/WorkerReportingProxy.h"
@@ -102,12 +104,20 @@ void WorkerThread::workerThreadStart(void* thread)
static_cast<WorkerThread*>(thread)->workerThread();
}
+void WorkerThread::interruptAndDispatchInspectorCommands()
+{
+ MutexLocker locker(m_threadShutdownMutex);
+ if (!m_workerGlobalScope)
+ return;
+ if (WorkerInspectorController* inspectorController = m_workerGlobalScope->workerInspectorController())
yurys 2014/06/26 11:04:30 WorkerGlobalScope::clearInspector may be executing
horo 2014/06/27 06:36:05 I agree with yurys. But it may be good to add "if
+ inspectorController->interruptAndDispatchInspectorCommands();
+}
+
void WorkerThread::workerThread()
{
KURL scriptURL = m_startupData->m_scriptURL;
String sourceCode = m_startupData->m_sourceCode;
WorkerThreadStartMode startMode = m_startupData->m_startMode;
-
{
MutexLocker lock(m_threadCreationMutex);
ThreadState::attach();
@@ -140,14 +150,17 @@ void WorkerThread::workerThread()
ThreadIdentifier threadID = m_threadID;
- // The below assignment will destroy the context, which will in turn notify messaging proxy.
- // We cannot let any objects survive past thread exit, because no other thread will run GC or otherwise destroy them.
- // If Oilpan is enabled, we detach of the context/global scope, with the final heap cleanup below sweeping it out.
+ {
+ MutexLocker locker(m_threadShutdownMutex);
+ // The below assignment will destroy the context, which will in turn notify messaging proxy.
+ // We cannot let any objects survive past thread exit, because no other thread will run GC or otherwise destroy them.
+ // If Oilpan is enabled, we detach of the context/global scope, with the final heap cleanup below sweeping it out.
#if !ENABLE(OILPAN)
- ASSERT(m_workerGlobalScope->hasOneRef());
+ ASSERT(m_workerGlobalScope->hasOneRef());
#endif
- m_workerGlobalScope->dispose();
- m_workerGlobalScope = nullptr;
+ m_workerGlobalScope->dispose();
+ m_workerGlobalScope = nullptr;
+ }
// Detach the ThreadState, cleaning out the thread's heap by
// performing a final GC. The cleanup operation will at the end
« no previous file with comments | « Source/core/workers/WorkerThread.h ('k') | Source/modules/device_orientation/DeviceOrientationInspectorAgent.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698