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/renderer/shared_worker_repository.h" | 5 #include "content/renderer/shared_worker_repository.h" |
6 | 6 |
7 #include "content/child/child_thread_impl.h" | 7 #include "content/child/child_thread_impl.h" |
8 #include "content/common/view_messages.h" | 8 #include "content/common/view_messages.h" |
9 #include "content/renderer/render_frame_impl.h" | 9 #include "content/renderer/render_frame_impl.h" |
10 #include "content/renderer/websharedworker_proxy.h" | 10 #include "content/renderer/websharedworker_proxy.h" |
(...skipping 24 matching lines...) Expand all Loading... |
35 params.name = name.utf16(); | 35 params.name = name.utf16(); |
36 params.content_security_policy = content_security_policy.utf16(); | 36 params.content_security_policy = content_security_policy.utf16(); |
37 params.security_policy_type = security_policy_type; | 37 params.security_policy_type = security_policy_type; |
38 params.document_id = document_id; | 38 params.document_id = document_id; |
39 params.render_frame_route_id = render_frame()->GetRoutingID(); | 39 params.render_frame_route_id = render_frame()->GetRoutingID(); |
40 params.creation_address_space = creation_address_space; | 40 params.creation_address_space = creation_address_space; |
41 params.creation_context_type = creation_context_type; | 41 params.creation_context_type = creation_context_type; |
42 ViewHostMsg_CreateWorker_Reply reply; | 42 ViewHostMsg_CreateWorker_Reply reply; |
43 Send(new ViewHostMsg_CreateWorker(params, &reply)); | 43 Send(new ViewHostMsg_CreateWorker(params, &reply)); |
44 *error = reply.error; | 44 *error = reply.error; |
45 if (reply.route_id == MSG_ROUTING_NONE) | |
46 return nullptr; | |
47 documents_with_workers_.insert(document_id); | 45 documents_with_workers_.insert(document_id); |
48 return base::MakeUnique<WebSharedWorkerProxy>( | 46 return base::MakeUnique<WebSharedWorkerProxy>( |
49 ChildThreadImpl::current()->GetRouter(), reply.route_id); | 47 ChildThreadImpl::current()->GetRouter(), reply.route_id); |
50 } | 48 } |
51 | 49 |
52 void SharedWorkerRepository::documentDetached(DocumentID document) { | 50 void SharedWorkerRepository::documentDetached(DocumentID document) { |
53 std::set<DocumentID>::iterator iter = documents_with_workers_.find(document); | 51 std::set<DocumentID>::iterator iter = documents_with_workers_.find(document); |
54 if (iter != documents_with_workers_.end()) { | 52 if (iter != documents_with_workers_.end()) { |
55 // Notify the browser process that the document has shut down. | 53 // Notify the browser process that the document has shut down. |
56 Send(new ViewHostMsg_DocumentDetached(document)); | 54 Send(new ViewHostMsg_DocumentDetached(document)); |
57 documents_with_workers_.erase(iter); | 55 documents_with_workers_.erase(iter); |
58 } | 56 } |
59 } | 57 } |
60 | 58 |
61 void SharedWorkerRepository::OnDestruct() { | 59 void SharedWorkerRepository::OnDestruct() { |
62 delete this; | 60 delete this; |
63 } | 61 } |
64 | 62 |
65 } // namespace content | 63 } // namespace content |
OLD | NEW |