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

Side by Side Diff: content/child/service_worker/service_worker_message_filter.cc

Issue 261533003: Populate .current when navigator.serviceWorker is accessed (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/child/service_worker/service_worker_message_filter.h" 5 #include "content/child/service_worker/service_worker_message_filter.h"
6 6
7 #include "base/message_loop/message_loop_proxy.h" 7 #include "base/message_loop/message_loop_proxy.h"
8 #include "content/child/service_worker/service_worker_dispatcher.h" 8 #include "content/child/service_worker/service_worker_dispatcher.h"
9 #include "content/child/thread_safe_sender.h" 9 #include "content/child/thread_safe_sender.h"
10 #include "content/child/worker_thread_task_runner.h" 10 #include "content/child/worker_thread_task_runner.h"
11 #include "content/common/service_worker/service_worker_messages.h" 11 #include "content/common/service_worker/service_worker_messages.h"
12 #include "ipc/ipc_message_macros.h" 12 #include "ipc/ipc_message_macros.h"
13 13
14 namespace content { 14 namespace content {
15 15
16 namespace { 16 namespace {
17 17
18 // Sends a ServiceWorkerObjectDestroyed message to the browser so it can delete 18 // Sends a ServiceWorkerObjectDestroyed message to the browser so it can delete
19 // the ServiceWorker handle. 19 // the ServiceWorker handle.
20 void SendServiceWorkerObjectDestroyed( 20 void SendServiceWorkerObjectDestroyed(
21 scoped_refptr<ThreadSafeSender> sender, 21 scoped_refptr<ThreadSafeSender> sender,
22 int handle_id) { 22 int handle_id) {
23 if (handle_id == kInvalidServiceWorkerHandleId) 23 if (handle_id == kInvalidServiceWorkerHandleId)
24 return; 24 return;
25 sender->Send( 25 sender->Send(
26 new ServiceWorkerHostMsg_ServiceWorkerObjectDestroyed(handle_id)); 26 new ServiceWorkerHostMsg_DecrementServiceWorkerRefCount(handle_id));
27 } 27 }
28 28
29 } // namespace 29 } // namespace
30 30
31 ServiceWorkerMessageFilter::ServiceWorkerMessageFilter(ThreadSafeSender* sender) 31 ServiceWorkerMessageFilter::ServiceWorkerMessageFilter(ThreadSafeSender* sender)
32 : main_thread_loop_proxy_(base::MessageLoopProxy::current()), 32 : main_thread_loop_proxy_(base::MessageLoopProxy::current()),
33 thread_safe_sender_(sender) {} 33 thread_safe_sender_(sender) {}
34 34
35 ServiceWorkerMessageFilter::~ServiceWorkerMessageFilter() {} 35 ServiceWorkerMessageFilter::~ServiceWorkerMessageFilter() {}
36 36
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
74 } 74 }
75 75
76 void ServiceWorkerMessageFilter::OnStaleSetCurrentServiceWorker( 76 void ServiceWorkerMessageFilter::OnStaleSetCurrentServiceWorker(
77 int thread_id, 77 int thread_id,
78 int provider_id, 78 int provider_id,
79 const ServiceWorkerObjectInfo& info) { 79 const ServiceWorkerObjectInfo& info) {
80 SendServiceWorkerObjectDestroyed(thread_safe_sender_, info.handle_id); 80 SendServiceWorkerObjectDestroyed(thread_safe_sender_, info.handle_id);
81 } 81 }
82 82
83 } // namespace content 83 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698