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

Side by Side Diff: extensions/shell/renderer/shell_content_renderer_client.h

Issue 2459143002: Avoid GURL allocations/copies/frees in RenderFrameImpl::willSendRequest (Closed)
Patch Set: compile fix Created 4 years, 1 month 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #ifndef EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_ 5 #ifndef EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_
6 #define EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_ 6 #define EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/compiler_specific.h" 10 #include "base/compiler_specific.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "content/public/renderer/content_renderer_client.h" 12 #include "content/public/renderer/content_renderer_client.h"
13 13
14 namespace blink {
15 class WebURL;
16 } // namespace blink
Devlin 2016/10/31 15:17:39 \n after this
Charlie Harrison 2016/10/31 15:46:13 Done.
14 namespace extensions { 17 namespace extensions {
15 18
16 class Dispatcher; 19 class Dispatcher;
17 class DispatcherDelegate; 20 class DispatcherDelegate;
18 class ExtensionsClient; 21 class ExtensionsClient;
19 class ExtensionsGuestViewContainerDispatcher; 22 class ExtensionsGuestViewContainerDispatcher;
20 class ShellExtensionsRendererClient; 23 class ShellExtensionsRendererClient;
21 class ShellRendererMainDelegate; 24 class ShellRendererMainDelegate;
22 25
23 // Renderer initialization and runtime support for app_shell. 26 // Renderer initialization and runtime support for app_shell.
24 class ShellContentRendererClient : public content::ContentRendererClient { 27 class ShellContentRendererClient : public content::ContentRendererClient {
25 public: 28 public:
26 ShellContentRendererClient(); 29 ShellContentRendererClient();
27 ~ShellContentRendererClient() override; 30 ~ShellContentRendererClient() override;
28 31
29 // content::ContentRendererClient implementation: 32 // content::ContentRendererClient implementation:
30 void RenderThreadStarted() override; 33 void RenderThreadStarted() override;
31 void RenderFrameCreated(content::RenderFrame* render_frame) override; 34 void RenderFrameCreated(content::RenderFrame* render_frame) override;
32 void RenderViewCreated(content::RenderView* render_view) override; 35 void RenderViewCreated(content::RenderView* render_view) override;
33 bool OverrideCreatePlugin(content::RenderFrame* render_frame, 36 bool OverrideCreatePlugin(content::RenderFrame* render_frame,
34 blink::WebLocalFrame* frame, 37 blink::WebLocalFrame* frame,
35 const blink::WebPluginParams& params, 38 const blink::WebPluginParams& params,
36 blink::WebPlugin** plugin) override; 39 blink::WebPlugin** plugin) override;
37 blink::WebPlugin* CreatePluginReplacement( 40 blink::WebPlugin* CreatePluginReplacement(
38 content::RenderFrame* render_frame, 41 content::RenderFrame* render_frame,
39 const base::FilePath& plugin_path) override; 42 const base::FilePath& plugin_path) override;
40 bool WillSendRequest(blink::WebFrame* frame, 43 bool WillSendRequest(blink::WebFrame* frame,
41 ui::PageTransition transition_type, 44 ui::PageTransition transition_type,
42 const GURL& url, 45 const blink::WebURL& url,
43 const GURL& first_party_for_cookies,
44 GURL* new_url) override; 46 GURL* new_url) override;
45 bool IsExternalPepperPlugin(const std::string& module_name) override; 47 bool IsExternalPepperPlugin(const std::string& module_name) override;
46 bool ShouldGatherSiteIsolationStats() const override; 48 bool ShouldGatherSiteIsolationStats() const override;
47 content::BrowserPluginDelegate* CreateBrowserPluginDelegate( 49 content::BrowserPluginDelegate* CreateBrowserPluginDelegate(
48 content::RenderFrame* render_frame, 50 content::RenderFrame* render_frame,
49 const std::string& mime_type, 51 const std::string& mime_type,
50 const GURL& original_url) override; 52 const GURL& original_url) override;
51 void RunScriptsAtDocumentStart(content::RenderFrame* render_frame) override; 53 void RunScriptsAtDocumentStart(content::RenderFrame* render_frame) override;
52 void RunScriptsAtDocumentEnd(content::RenderFrame* render_frame) override; 54 void RunScriptsAtDocumentEnd(content::RenderFrame* render_frame) override;
53 55
54 protected: 56 protected:
55 // app_shell embedders may need custom extensions client interfaces. 57 // app_shell embedders may need custom extensions client interfaces.
56 // This class takes ownership of the returned object. 58 // This class takes ownership of the returned object.
57 virtual ExtensionsClient* CreateExtensionsClient(); 59 virtual ExtensionsClient* CreateExtensionsClient();
58 60
59 private: 61 private:
60 std::unique_ptr<ExtensionsClient> extensions_client_; 62 std::unique_ptr<ExtensionsClient> extensions_client_;
61 std::unique_ptr<ShellExtensionsRendererClient> extensions_renderer_client_; 63 std::unique_ptr<ShellExtensionsRendererClient> extensions_renderer_client_;
62 std::unique_ptr<DispatcherDelegate> extension_dispatcher_delegate_; 64 std::unique_ptr<DispatcherDelegate> extension_dispatcher_delegate_;
63 std::unique_ptr<Dispatcher> extension_dispatcher_; 65 std::unique_ptr<Dispatcher> extension_dispatcher_;
64 std::unique_ptr<ExtensionsGuestViewContainerDispatcher> 66 std::unique_ptr<ExtensionsGuestViewContainerDispatcher>
65 guest_view_container_dispatcher_; 67 guest_view_container_dispatcher_;
66 68
67 DISALLOW_COPY_AND_ASSIGN(ShellContentRendererClient); 69 DISALLOW_COPY_AND_ASSIGN(ShellContentRendererClient);
68 }; 70 };
69 71
70 } // namespace extensions 72 } // namespace extensions
71 73
72 #endif // EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_ 74 #endif // EXTENSIONS_SHELL_RENDERER_SHELL_CONTENT_RENDERER_CLIENT_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698