| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/workers/ThreadedMessagingProxyBase.h" | 5 #include "core/workers/ThreadedMessagingProxyBase.h" |
| 6 | 6 |
| 7 #include "bindings/core/v8/SourceLocation.h" | 7 #include "bindings/core/v8/SourceLocation.h" |
| 8 #include "core/dom/Document.h" | 8 #include "core/dom/Document.h" |
| 9 #include "core/dom/ExecutionContextTask.h" | 9 #include "core/dom/ExecutionContextTask.h" |
| 10 #include "core/frame/Deprecation.h" | 10 #include "core/frame/Deprecation.h" |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 49 std::unique_ptr<WorkerThreadStartupData> startupData) { | 49 std::unique_ptr<WorkerThreadStartupData> startupData) { |
| 50 DCHECK(isParentContextThread()); | 50 DCHECK(isParentContextThread()); |
| 51 | 51 |
| 52 Document* document = toDocument(getExecutionContext()); | 52 Document* document = toDocument(getExecutionContext()); |
| 53 double originTime = | 53 double originTime = |
| 54 document->loader() ? document->loader()->timing().referenceMonotonicTime() | 54 document->loader() ? document->loader()->timing().referenceMonotonicTime() |
| 55 : monotonicallyIncreasingTime(); | 55 : monotonicallyIncreasingTime(); |
| 56 | 56 |
| 57 m_loaderProxy = WorkerLoaderProxy::create(this); | 57 m_loaderProxy = WorkerLoaderProxy::create(this); |
| 58 m_workerThread = createWorkerThread(originTime); | 58 m_workerThread = createWorkerThread(originTime); |
| 59 m_workerThread->start(std::move(startupData)); | 59 m_workerThread->start(std::move(startupData), getParentFrameTaskRunners()); |
| 60 workerThreadCreated(); | 60 workerThreadCreated(); |
| 61 } | 61 } |
| 62 | 62 |
| 63 void ThreadedMessagingProxyBase::postTaskToWorkerGlobalScope( | 63 void ThreadedMessagingProxyBase::postTaskToWorkerGlobalScope( |
| 64 const WebTraceLocation& location, | 64 const WebTraceLocation& location, |
| 65 std::unique_ptr<WTF::CrossThreadClosure> task) { | 65 std::unique_ptr<WTF::CrossThreadClosure> task) { |
| 66 if (m_askedToTerminate) | 66 if (m_askedToTerminate) |
| 67 return; | 67 return; |
| 68 | 68 |
| 69 DCHECK(m_workerThread); | 69 DCHECK(m_workerThread); |
| (...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 165 } | 165 } |
| 166 | 166 |
| 167 bool ThreadedMessagingProxyBase::isParentContextThread() const { | 167 bool ThreadedMessagingProxyBase::isParentContextThread() const { |
| 168 // TODO(nhiroki): Nested worker is not supported yet, so the parent context | 168 // TODO(nhiroki): Nested worker is not supported yet, so the parent context |
| 169 // thread should be equal to the main thread (http://crbug.com/31666). | 169 // thread should be equal to the main thread (http://crbug.com/31666). |
| 170 DCHECK(m_executionContext->isDocument()); | 170 DCHECK(m_executionContext->isDocument()); |
| 171 return isMainThread(); | 171 return isMainThread(); |
| 172 } | 172 } |
| 173 | 173 |
| 174 } // namespace blink | 174 } // namespace blink |
| OLD | NEW |