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

Side by Side Diff: components/contextual_search/renderer/overlay_js_render_frame_observer.cc

Issue 2079943002: Change RenderFrame to use InterfaceRegistry et al. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@a2
Patch Set: . Created 4 years, 6 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
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 "components/contextual_search/renderer/overlay_js_render_frame_observer .h" 5 #include "components/contextual_search/renderer/overlay_js_render_frame_observer .h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "components/contextual_search/renderer/contextual_search_wrapper.h" 10 #include "components/contextual_search/renderer/contextual_search_wrapper.h"
11 #include "components/contextual_search/renderer/overlay_page_notifier_service_im pl.h" 11 #include "components/contextual_search/renderer/overlay_page_notifier_service_im pl.h"
12 #include "content/public/common/service_registry.h"
13 #include "content/public/renderer/render_frame.h" 12 #include "content/public/renderer/render_frame.h"
13 #include "services/shell/public/cpp/interface_registry.h"
14 #include "v8/include/v8.h" 14 #include "v8/include/v8.h"
15 15
16 namespace contextual_search { 16 namespace contextual_search {
17 17
18 OverlayJsRenderFrameObserver::OverlayJsRenderFrameObserver( 18 OverlayJsRenderFrameObserver::OverlayJsRenderFrameObserver(
19 content::RenderFrame* render_frame) 19 content::RenderFrame* render_frame)
20 : RenderFrameObserver(render_frame), 20 : RenderFrameObserver(render_frame),
21 is_contextual_search_overlay_(false), 21 is_contextual_search_overlay_(false),
22 weak_factory_(this) {} 22 weak_factory_(this) {}
23 23
24 OverlayJsRenderFrameObserver::~OverlayJsRenderFrameObserver() {} 24 OverlayJsRenderFrameObserver::~OverlayJsRenderFrameObserver() {}
25 25
26 void OverlayJsRenderFrameObserver::DidStartProvisionalLoad() { 26 void OverlayJsRenderFrameObserver::DidStartProvisionalLoad() {
27 RegisterMojoService(); 27 RegisterMojoInterface();
28 } 28 }
29 29
30 void OverlayJsRenderFrameObserver::RegisterMojoService() { 30 void OverlayJsRenderFrameObserver::RegisterMojoInterface() {
31 render_frame()->GetServiceRegistry()->AddService(base::Bind( 31 render_frame()->GetInterfaceRegistry()->AddInterface(base::Bind(
32 &OverlayJsRenderFrameObserver::CreateOverlayPageNotifierService, 32 &OverlayJsRenderFrameObserver::CreateOverlayPageNotifierService,
33 weak_factory_.GetWeakPtr())); 33 weak_factory_.GetWeakPtr()));
34 } 34 }
35 35
36 void OverlayJsRenderFrameObserver::CreateOverlayPageNotifierService( 36 void OverlayJsRenderFrameObserver::CreateOverlayPageNotifierService(
37 mojo::InterfaceRequest<mojom::OverlayPageNotifierService> request) { 37 mojo::InterfaceRequest<mojom::OverlayPageNotifierService> request) {
38 // This is strongly bound to and owned by the pipe. 38 // This is strongly bound to and owned by the pipe.
39 new OverlayPageNotifierServiceImpl(this, std::move(request)); 39 new OverlayPageNotifierServiceImpl(this, std::move(request));
40 } 40 }
41 41
42 void OverlayJsRenderFrameObserver::SetIsContextualSearchOverlay() { 42 void OverlayJsRenderFrameObserver::SetIsContextualSearchOverlay() {
43 is_contextual_search_overlay_ = true; 43 is_contextual_search_overlay_ = true;
44 } 44 }
45 45
46 void OverlayJsRenderFrameObserver::DidClearWindowObject() { 46 void OverlayJsRenderFrameObserver::DidClearWindowObject() {
47 if (is_contextual_search_overlay_) { 47 if (is_contextual_search_overlay_) {
48 contextual_search::ContextualSearchWrapper::Install(render_frame()); 48 contextual_search::ContextualSearchWrapper::Install(render_frame());
49 } 49 }
50 } 50 }
51 51
52 void OverlayJsRenderFrameObserver::DidFinishLoad() { 52 void OverlayJsRenderFrameObserver::DidFinishLoad() {
53 // If no message about the Contextual Search overlay was received at this 53 // If no message about the Contextual Search overlay was received at this
54 // point, there will not be one; remove the OverlayPageNotifierService 54 // point, there will not be one; remove the OverlayPageNotifierService
55 // from the registry. 55 // from the registry.
56 render_frame() 56 render_frame()
57 ->GetServiceRegistry() 57 ->GetInterfaceRegistry()
58 ->RemoveService<mojom::OverlayPageNotifierService>(); 58 ->RemoveInterface<mojom::OverlayPageNotifierService>();
59 } 59 }
60 60
61 void OverlayJsRenderFrameObserver::OnDestruct() { 61 void OverlayJsRenderFrameObserver::OnDestruct() {
62 delete this; 62 delete this;
63 } 63 }
64 64
65 } // namespace contextual_search 65 } // namespace contextual_search
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698