| 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/TaskRunnerHelper.h" | 9 #include "core/dom/TaskRunnerHelper.h" |
| 10 #include "core/frame/Deprecation.h" | 10 #include "core/frame/Deprecation.h" |
| (...skipping 18 matching lines...) Expand all Loading... |
| 29 parent_frame_task_runners_(ParentFrameTaskRunners::Create( | 29 parent_frame_task_runners_(ParentFrameTaskRunners::Create( |
| 30 ToDocument(execution_context_.Get())->GetFrame())), | 30 ToDocument(execution_context_.Get())->GetFrame())), |
| 31 may_be_destroyed_(false), | 31 may_be_destroyed_(false), |
| 32 asked_to_terminate_(false) { | 32 asked_to_terminate_(false) { |
| 33 DCHECK(IsParentContextThread()); | 33 DCHECK(IsParentContextThread()); |
| 34 g_live_messaging_proxy_count++; | 34 g_live_messaging_proxy_count++; |
| 35 } | 35 } |
| 36 | 36 |
| 37 ThreadedMessagingProxyBase::~ThreadedMessagingProxyBase() { | 37 ThreadedMessagingProxyBase::~ThreadedMessagingProxyBase() { |
| 38 DCHECK(IsParentContextThread()); | 38 DCHECK(IsParentContextThread()); |
| 39 if (loader_proxy_) | |
| 40 loader_proxy_->DetachProvider(this); | |
| 41 g_live_messaging_proxy_count--; | 39 g_live_messaging_proxy_count--; |
| 42 } | 40 } |
| 43 | 41 |
| 44 int ThreadedMessagingProxyBase::ProxyCount() { | 42 int ThreadedMessagingProxyBase::ProxyCount() { |
| 45 DCHECK(IsMainThread()); | 43 DCHECK(IsMainThread()); |
| 46 return g_live_messaging_proxy_count; | 44 return g_live_messaging_proxy_count; |
| 47 } | 45 } |
| 48 | 46 |
| 49 void ThreadedMessagingProxyBase::SetWorkerThreadForTest( | 47 void ThreadedMessagingProxyBase::SetWorkerThreadForTest( |
| 50 std::unique_ptr<WorkerThread> worker_thread) { | 48 std::unique_ptr<WorkerThread> worker_thread) { |
| 51 worker_thread_ = std::move(worker_thread); | 49 worker_thread_ = std::move(worker_thread); |
| 52 } | 50 } |
| 53 | 51 |
| 54 void ThreadedMessagingProxyBase::InitializeWorkerThread( | 52 void ThreadedMessagingProxyBase::InitializeWorkerThread( |
| 55 std::unique_ptr<WorkerThreadStartupData> startup_data) { | 53 std::unique_ptr<WorkerThreadStartupData> startup_data) { |
| 56 DCHECK(IsParentContextThread()); | 54 DCHECK(IsParentContextThread()); |
| 57 | 55 |
| 58 Document* document = ToDocument(GetExecutionContext()); | 56 Document* document = ToDocument(GetExecutionContext()); |
| 59 double origin_time = | 57 double origin_time = |
| 60 document->Loader() | 58 document->Loader() |
| 61 ? document->Loader()->GetTiming().ReferenceMonotonicTime() | 59 ? document->Loader()->GetTiming().ReferenceMonotonicTime() |
| 62 : MonotonicallyIncreasingTime(); | 60 : MonotonicallyIncreasingTime(); |
| 63 | 61 |
| 64 loader_proxy_ = WorkerLoaderProxy::Create(this); | |
| 65 worker_thread_ = CreateWorkerThread(origin_time); | 62 worker_thread_ = CreateWorkerThread(origin_time); |
| 66 worker_thread_->Start(std::move(startup_data), GetParentFrameTaskRunners()); | 63 worker_thread_->Start(std::move(startup_data), GetParentFrameTaskRunners()); |
| 67 WorkerThreadCreated(); | 64 WorkerThreadCreated(); |
| 68 } | 65 } |
| 69 | 66 |
| 70 ThreadableLoadingContext* | 67 ThreadableLoadingContext* |
| 71 ThreadedMessagingProxyBase::GetThreadableLoadingContext() { | 68 ThreadedMessagingProxyBase::GetThreadableLoadingContext() { |
| 72 DCHECK(IsParentContextThread()); | 69 DCHECK(IsParentContextThread()); |
| 73 if (!loading_context_) { | 70 return ThreadableLoadingContext::Create(*ToDocument(execution_context_)); |
| 74 loading_context_ = | |
| 75 ThreadableLoadingContext::Create(*ToDocument(execution_context_)); | |
| 76 } | |
| 77 return loading_context_; | |
| 78 } | 71 } |
| 79 | 72 |
| 80 void ThreadedMessagingProxyBase::CountFeature(UseCounter::Feature feature) { | 73 void ThreadedMessagingProxyBase::CountFeature(UseCounter::Feature feature) { |
| 81 DCHECK(IsParentContextThread()); | 74 DCHECK(IsParentContextThread()); |
| 82 UseCounter::Count(execution_context_, feature); | 75 UseCounter::Count(execution_context_, feature); |
| 83 } | 76 } |
| 84 | 77 |
| 85 void ThreadedMessagingProxyBase::CountDeprecation(UseCounter::Feature feature) { | 78 void ThreadedMessagingProxyBase::CountDeprecation(UseCounter::Feature feature) { |
| 86 DCHECK(IsParentContextThread()); | 79 DCHECK(IsParentContextThread()); |
| 87 Deprecation::CountDeprecation(execution_context_, feature); | 80 Deprecation::CountDeprecation(execution_context_, feature); |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 160 } | 153 } |
| 161 | 154 |
| 162 bool ThreadedMessagingProxyBase::IsParentContextThread() const { | 155 bool ThreadedMessagingProxyBase::IsParentContextThread() const { |
| 163 // TODO(nhiroki): Nested worker is not supported yet, so the parent context | 156 // TODO(nhiroki): Nested worker is not supported yet, so the parent context |
| 164 // thread should be equal to the main thread (http://crbug.com/31666). | 157 // thread should be equal to the main thread (http://crbug.com/31666). |
| 165 DCHECK(execution_context_->IsDocument()); | 158 DCHECK(execution_context_->IsDocument()); |
| 166 return IsMainThread(); | 159 return IsMainThread(); |
| 167 } | 160 } |
| 168 | 161 |
| 169 } // namespace blink | 162 } // namespace blink |
| OLD | NEW |