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

Side by Side Diff: content/browser/service_worker/service_worker_client_utils.cc

Issue 2656163004: Convert service_worker_client_utils to use the new navigation callbacks. (Closed)
Patch Set: Created 3 years, 10 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/service_worker_client_utils.h" 5 #include "content/browser/service_worker/service_worker_client_utils.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <tuple> 8 #include <tuple>
9 9
10 #include "base/location.h" 10 #include "base/location.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/memory/ptr_util.h" 12 #include "base/memory/ptr_util.h"
13 #include "base/single_thread_task_runner.h" 13 #include "base/single_thread_task_runner.h"
14 #include "base/threading/thread_task_runner_handle.h" 14 #include "base/threading/thread_task_runner_handle.h"
15 #include "content/browser/frame_host/frame_tree_node.h" 15 #include "content/browser/frame_host/frame_tree_node.h"
16 #include "content/browser/frame_host/render_frame_host_impl.h" 16 #include "content/browser/frame_host/render_frame_host_impl.h"
17 #include "content/browser/service_worker/service_worker_context_core.h" 17 #include "content/browser/service_worker/service_worker_context_core.h"
18 #include "content/browser/service_worker/service_worker_context_wrapper.h" 18 #include "content/browser/service_worker/service_worker_context_wrapper.h"
19 #include "content/browser/service_worker/service_worker_provider_host.h" 19 #include "content/browser/service_worker/service_worker_provider_host.h"
20 #include "content/browser/service_worker/service_worker_version.h" 20 #include "content/browser/service_worker/service_worker_version.h"
21 #include "content/browser/storage_partition_impl.h" 21 #include "content/browser/storage_partition_impl.h"
22 #include "content/browser/web_contents/web_contents_impl.h" 22 #include "content/browser/web_contents/web_contents_impl.h"
23 #include "content/common/service_worker/service_worker_client_info.h" 23 #include "content/common/service_worker/service_worker_client_info.h"
24 #include "content/common/service_worker/service_worker_types.h" 24 #include "content/common/service_worker/service_worker_types.h"
25 #include "content/public/browser/browser_thread.h" 25 #include "content/public/browser/browser_thread.h"
26 #include "content/public/browser/content_browser_client.h" 26 #include "content/public/browser/content_browser_client.h"
27 #include "content/public/browser/navigation_handle.h"
27 #include "content/public/browser/page_navigator.h" 28 #include "content/public/browser/page_navigator.h"
28 #include "content/public/browser/render_frame_host.h" 29 #include "content/public/browser/render_frame_host.h"
29 #include "content/public/browser/render_widget_host_view.h" 30 #include "content/public/browser/render_widget_host_view.h"
30 #include "content/public/browser/web_contents.h" 31 #include "content/public/browser/web_contents.h"
31 #include "content/public/browser/web_contents_observer.h" 32 #include "content/public/browser/web_contents_observer.h"
32 #include "content/public/common/child_process_host.h" 33 #include "content/public/common/child_process_host.h"
33 #include "url/gurl.h" 34 #include "url/gurl.h"
34 35
35 namespace content { 36 namespace content {
36 namespace service_worker_client_utils { 37 namespace service_worker_client_utils {
(...skipping 12 matching lines...) Expand all
49 // The callback will be called in the IO thread. 50 // The callback will be called in the IO thread.
50 class OpenURLObserver : public WebContentsObserver { 51 class OpenURLObserver : public WebContentsObserver {
51 public: 52 public:
52 OpenURLObserver(WebContents* web_contents, 53 OpenURLObserver(WebContents* web_contents,
53 int frame_tree_node_id, 54 int frame_tree_node_id,
54 const OpenURLCallback& callback) 55 const OpenURLCallback& callback)
55 : WebContentsObserver(web_contents), 56 : WebContentsObserver(web_contents),
56 frame_tree_node_id_(frame_tree_node_id), 57 frame_tree_node_id_(frame_tree_node_id),
57 callback_(callback) {} 58 callback_(callback) {}
58 59
59 void DidCommitProvisionalLoadForFrame( 60 void DidFinishNavigation(NavigationHandle* navigation_handle) override {
60 RenderFrameHost* render_frame_host,
61 const GURL& validated_url,
62 ui::PageTransition transition_type) override {
63 DCHECK(web_contents()); 61 DCHECK(web_contents());
64 62 if (!navigation_handle->HasCommitted())
65 RenderFrameHostImpl* rfhi =
66 static_cast<RenderFrameHostImpl*>(render_frame_host);
67 if (rfhi->frame_tree_node()->frame_tree_node_id() != frame_tree_node_id_)
68 return; 63 return;
69 64
65 if (navigation_handle->GetFrameTreeNodeId() != frame_tree_node_id_)
66 return;
67
68 RenderFrameHost* render_frame_host =
69 navigation_handle->GetRenderFrameHost();
70 RunCallback(render_frame_host->GetProcess()->GetID(), 70 RunCallback(render_frame_host->GetProcess()->GetID(),
71 render_frame_host->GetRoutingID()); 71 render_frame_host->GetRoutingID());
72 } 72 }
73 73
74 void RenderProcessGone(base::TerminationStatus status) override { 74 void RenderProcessGone(base::TerminationStatus status) override {
75 RunCallback(ChildProcessHost::kInvalidUniqueID, MSG_ROUTING_NONE); 75 RunCallback(ChildProcessHost::kInvalidUniqueID, MSG_ROUTING_NONE);
76 } 76 }
77 77
78 void WebContentsDestroyed() override { 78 void WebContentsDestroyed() override {
79 RunCallback(ChildProcessHost::kInvalidUniqueID, MSG_ROUTING_NONE); 79 RunCallback(ChildProcessHost::kInvalidUniqueID, MSG_ROUTING_NONE);
(...skipping 425 matching lines...) Expand 10 before | Expand all | Expand 10 after
505 GetWindowClients(controller, options, callback); 505 GetWindowClients(controller, options, callback);
506 return; 506 return;
507 } 507 }
508 508
509 GetNonWindowClients(controller, options, &clients); 509 GetNonWindowClients(controller, options, &clients);
510 DidGetClients(callback, &clients); 510 DidGetClients(callback, &clients);
511 } 511 }
512 512
513 } // namespace service_worker_client_utils 513 } // namespace service_worker_client_utils
514 } // namespace content 514 } // namespace content
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698