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

Side by Side Diff: content/browser/web_contents/web_contents_interface_registry_impl.cc

Issue 2310563002: Adds routed interface support between RenderFrameHost and RenderFrame (Closed)
Patch Set: Created 4 years, 3 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
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "content/browser/web_contents/web_contents_interface_registry_impl.h"
6
7 #include "base/bind.h"
8 #include "base/memory/ptr_util.h"
9 #include "content/public/browser/render_frame_host.h"
10 #include "content/public/browser/web_contents.h"
11
12 namespace content {
13
14 WebContentsInterfaceRegistryImpl::WebContentsInterfaceRegistryImpl(
15 WebContents* web_contents) : WebContentsObserver(web_contents) {
16 }
17
18 WebContentsInterfaceRegistryImpl::~WebContentsInterfaceRegistryImpl() {
19 for (auto* frame : frames_)
20 RemoveInterfacesFromFrame(frame);
21 }
22
23 RenderFrameHost* WebContentsInterfaceRegistryImpl::GetCurrentTargetFrame() {
24 DCHECK(current_target_frame_host_);
25 return current_target_frame_host_;
26 }
27
28 void WebContentsInterfaceRegistryImpl::SetCurrentTargetFrameForTesting(
29 RenderFrameHost* render_frame_host) {
30 current_target_frame_host_ = render_frame_host;
31 }
32
33 void WebContentsInterfaceRegistryImpl::RenderFrameCreated(
34 RenderFrameHost* render_frame_host) {
35 AddInterfacesToFrame(render_frame_host);
36
37 auto result = frames_.insert(render_frame_host);
38 DCHECK(result.second);
39 }
40
41 void WebContentsInterfaceRegistryImpl::RenderFrameDeleted(
42 RenderFrameHost* render_frame_host) {
43 auto it = frames_.find(render_frame_host);
44 if (it == frames_.end())
45 return;
46
47 frames_.erase(it);
48 RemoveInterfacesFromFrame(render_frame_host);
49 }
50
51 void WebContentsInterfaceRegistryImpl::AddFrameInterface(
52 const std::string& name,
53 std::unique_ptr<FrameInterfaceBase> iface) {
54 for (auto* frame : frames_)
55 AddInterfaceToFrame(name, iface.get(), frame);
56
57 auto result =
58 frame_interfaces_.insert(std::make_pair(name, std::move(iface)));
59 DCHECK(result.second);
60 }
61
62 void WebContentsInterfaceRegistryImpl::WillDispatchForFrame(
63 RenderFrameHost* render_frame_host) {
64 current_target_frame_host_ = render_frame_host;
65 }
66
67 void WebContentsInterfaceRegistryImpl::AddInterfacesToFrame(
68 RenderFrameHost* render_frame_host) {
69 for (auto& entry : frame_interfaces_)
70 AddInterfaceToFrame(entry.first, entry.second.get(), render_frame_host);
71 }
72
73 void WebContentsInterfaceRegistryImpl::RemoveInterfacesFromFrame(
74 RenderFrameHost* render_frame_host) {
75 for (auto& entry : frame_interfaces_)
76 render_frame_host->RemoveRoutedInterface(entry.first);
77 }
78
79 // static
80 void WebContentsInterfaceRegistryImpl::AddInterfaceToFrame(
81 const std::string& name,
82 FrameInterfaceBase* iface,
83 RenderFrameHost* render_frame_host) {
84 render_frame_host->AddRoutedInterface(
85 name, base::Bind(&FrameInterfaceBase::AddBinding,
86 base::Unretained(iface), render_frame_host));
87 }
88
89 // static
90 std::unique_ptr<WebContentsInterfaceRegistry>
91 WebContentsInterfaceRegistry::Create(WebContents* web_contents) {
92 return base::MakeUnique<WebContentsInterfaceRegistryImpl>(web_contents);
93 }
94
95 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698