| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/service_worker/embedded_worker_registry.h" | 5 #include "content/browser/service_worker/embedded_worker_registry.h" |
| 6 | 6 |
| 7 #include "base/bind_helpers.h" | 7 #include "base/bind_helpers.h" |
| 8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 9 #include "content/browser/renderer_host/render_widget_helper.h" | 9 #include "content/browser/renderer_host/render_widget_helper.h" |
| 10 #include "content/browser/service_worker/embedded_worker_instance.h" | 10 #include "content/browser/service_worker/embedded_worker_instance.h" |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 77 return; | 77 return; |
| 78 } | 78 } |
| 79 if (found->second->process_id() != process_id) { | 79 if (found->second->process_id() != process_id) { |
| 80 LOG(ERROR) << "Incorrect embedded_worker_id"; | 80 LOG(ERROR) << "Incorrect embedded_worker_id"; |
| 81 return; | 81 return; |
| 82 } | 82 } |
| 83 found->second->OnReadyForInspection(); | 83 found->second->OnReadyForInspection(); |
| 84 } | 84 } |
| 85 | 85 |
| 86 void EmbeddedWorkerRegistry::OnWorkerScriptLoaded(int process_id, | 86 void EmbeddedWorkerRegistry::OnWorkerScriptLoaded(int process_id, |
| 87 int embedded_worker_id) { | 87 int thread_id, |
| 88 int embedded_worker_id ) { |
| 88 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); | 89 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); |
| 89 if (found == worker_map_.end()) { | 90 if (found == worker_map_.end()) { |
| 90 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; | 91 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; |
| 91 return; | 92 return; |
| 92 } | 93 } |
| 93 if (found->second->process_id() != process_id) { | 94 if (found->second->process_id() != process_id) { |
| 94 LOG(ERROR) << "Incorrect embedded_worker_id"; | 95 LOG(ERROR) << "Incorrect embedded_worker_id"; |
| 95 return; | 96 return; |
| 96 } | 97 } |
| 97 found->second->OnScriptLoaded(); | 98 found->second->OnScriptLoaded(thread_id); |
| 98 } | 99 } |
| 99 | 100 |
| 100 void EmbeddedWorkerRegistry::OnWorkerScriptLoadFailed(int process_id, | 101 void EmbeddedWorkerRegistry::OnWorkerScriptLoadFailed(int process_id, |
| 101 int embedded_worker_id) { | 102 int embedded_worker_id) { |
| 102 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); | 103 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); |
| 103 if (found == worker_map_.end()) { | 104 if (found == worker_map_.end()) { |
| 104 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; | 105 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; |
| 105 return; | 106 return; |
| 106 } | 107 } |
| 107 if (found->second->process_id() != process_id) { | 108 if (found->second->process_id() != process_id) { |
| 108 LOG(ERROR) << "Incorrect embedded_worker_id"; | 109 LOG(ERROR) << "Incorrect embedded_worker_id"; |
| 109 return; | 110 return; |
| 110 } | 111 } |
| 111 found->second->OnScriptLoadFailed(); | 112 found->second->OnScriptLoadFailed(); |
| 112 } | 113 } |
| 113 | 114 |
| 114 void EmbeddedWorkerRegistry::OnWorkerStarted( | 115 void EmbeddedWorkerRegistry::OnWorkerStarted( |
| 115 int process_id, int thread_id, int embedded_worker_id) { | 116 int process_id, int embedded_worker_id) { |
| 116 DCHECK(!ContainsKey(worker_process_map_, process_id) || | 117 DCHECK(!ContainsKey(worker_process_map_, process_id) || |
| 117 worker_process_map_[process_id].count(embedded_worker_id) == 0); | 118 worker_process_map_[process_id].count(embedded_worker_id) == 0); |
| 118 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); | 119 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); |
| 119 if (found == worker_map_.end()) { | 120 if (found == worker_map_.end()) { |
| 120 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; | 121 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; |
| 121 return; | 122 return; |
| 122 } | 123 } |
| 123 if (found->second->process_id() != process_id) { | 124 if (found->second->process_id() != process_id) { |
| 124 LOG(ERROR) << "Incorrect embedded_worker_id"; | 125 LOG(ERROR) << "Incorrect embedded_worker_id"; |
| 125 return; | 126 return; |
| 126 } | 127 } |
| 127 worker_process_map_[process_id].insert(embedded_worker_id); | 128 worker_process_map_[process_id].insert(embedded_worker_id); |
| 128 found->second->OnStarted(thread_id); | 129 found->second->OnStarted(); |
| 129 } | 130 } |
| 130 | 131 |
| 131 void EmbeddedWorkerRegistry::OnWorkerStopped( | 132 void EmbeddedWorkerRegistry::OnWorkerStopped(int process_id, |
| 132 int process_id, int embedded_worker_id) { | 133 int embedded_worker_id) { |
| 133 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); | 134 WorkerInstanceMap::iterator found = worker_map_.find(embedded_worker_id); |
| 134 if (found == worker_map_.end()) { | 135 if (found == worker_map_.end()) { |
| 135 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; | 136 LOG(ERROR) << "Worker " << embedded_worker_id << " not registered"; |
| 136 return; | 137 return; |
| 137 } | 138 } |
| 138 if (found->second->process_id() != process_id) { | 139 if (found->second->process_id() != process_id) { |
| 139 LOG(ERROR) << "Incorrect embedded_worker_id"; | 140 LOG(ERROR) << "Incorrect embedded_worker_id"; |
| 140 return; | 141 return; |
| 141 } | 142 } |
| 142 worker_process_map_[process_id].erase(embedded_worker_id); | 143 worker_process_map_[process_id].erase(embedded_worker_id); |
| (...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 264 } | 265 } |
| 265 | 266 |
| 266 void EmbeddedWorkerRegistry::RemoveWorker(int process_id, | 267 void EmbeddedWorkerRegistry::RemoveWorker(int process_id, |
| 267 int embedded_worker_id) { | 268 int embedded_worker_id) { |
| 268 DCHECK(ContainsKey(worker_map_, embedded_worker_id)); | 269 DCHECK(ContainsKey(worker_map_, embedded_worker_id)); |
| 269 worker_map_.erase(embedded_worker_id); | 270 worker_map_.erase(embedded_worker_id); |
| 270 worker_process_map_.erase(process_id); | 271 worker_process_map_.erase(process_id); |
| 271 } | 272 } |
| 272 | 273 |
| 273 } // namespace content | 274 } // namespace content |
| OLD | NEW |