OLD | NEW |
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 #ifndef COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ | 5 #ifndef COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ |
6 #define COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ | 6 #define COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
11 #include "components/dom_distiller/core/distiller_page.h" | 11 #include "components/dom_distiller/core/distiller_page.h" |
12 #include "content/public/browser/web_contents.h" | 12 #include "content/public/browser/web_contents.h" |
13 #include "content/public/browser/web_contents_observer.h" | 13 #include "content/public/browser/web_contents_observer.h" |
14 #include "url/gurl.h" | 14 #include "url/gurl.h" |
15 | 15 |
16 namespace content { | 16 namespace content { |
17 class RenderViewHost; | 17 class RenderViewHost; |
18 } | 18 } |
19 | 19 |
20 using content::RenderViewHost; | 20 using content::RenderViewHost; |
21 | 21 |
22 namespace dom_distiller { | 22 namespace dom_distiller { |
23 | 23 |
24 class DistillerContext; | 24 class SourcePageHandleWebContents : public SourcePageHandle { |
| 25 public: |
| 26 explicit SourcePageHandleWebContents( |
| 27 scoped_ptr<content::WebContents> web_contents); |
| 28 virtual ~SourcePageHandleWebContents(); |
| 29 |
| 30 scoped_ptr<content::WebContents> GetWebContents(); |
| 31 |
| 32 private: |
| 33 // The WebContents this class owns. |
| 34 scoped_ptr<content::WebContents> web_contents_; |
| 35 }; |
25 | 36 |
26 class DistillerPageWebContentsFactory : public DistillerPageFactory { | 37 class DistillerPageWebContentsFactory : public DistillerPageFactory { |
27 public: | 38 public: |
28 explicit DistillerPageWebContentsFactory( | 39 explicit DistillerPageWebContentsFactory( |
29 content::BrowserContext* browser_context) | 40 content::BrowserContext* browser_context) |
30 : DistillerPageFactory(), browser_context_(browser_context) {} | 41 : DistillerPageFactory(), browser_context_(browser_context) {} |
31 virtual ~DistillerPageWebContentsFactory() {} | 42 virtual ~DistillerPageWebContentsFactory() {} |
32 | 43 |
33 virtual scoped_ptr<DistillerPage> CreateDistillerPage() const OVERRIDE; | 44 virtual scoped_ptr<DistillerPage> CreateDistillerPage() const OVERRIDE; |
| 45 virtual scoped_ptr<DistillerPage> CreateDistillerPageWithHandle( |
| 46 scoped_ptr<SourcePageHandle> handle) const OVERRIDE; |
34 | 47 |
35 private: | 48 private: |
36 content::BrowserContext* browser_context_; | 49 content::BrowserContext* browser_context_; |
37 }; | 50 }; |
38 | 51 |
39 class DistillerPageWebContents : public DistillerPage, | 52 class DistillerPageWebContents : public DistillerPage, |
40 public content::WebContentsObserver { | 53 public content::WebContentsObserver { |
41 public: | 54 public: |
42 DistillerPageWebContents(content::BrowserContext* browser_context); | 55 DistillerPageWebContents( |
| 56 content::BrowserContext* browser_context, |
| 57 scoped_ptr<SourcePageHandleWebContents> optional_web_contents_handle); |
43 virtual ~DistillerPageWebContents(); | 58 virtual ~DistillerPageWebContents(); |
44 | 59 |
45 // content::WebContentsObserver implementation. | 60 // content::WebContentsObserver implementation. |
46 virtual void DocumentLoadedInFrame(int64 frame_id, | 61 virtual void DocumentLoadedInFrame(int64 frame_id, |
47 RenderViewHost* render_view_host) OVERRIDE; | 62 RenderViewHost* render_view_host) OVERRIDE; |
48 | 63 |
49 virtual void DidFailLoad(int64 frame_id, | 64 virtual void DidFailLoad(int64 frame_id, |
50 const GURL& validated_url, | 65 const GURL& validated_url, |
51 bool is_main_frame, | 66 bool is_main_frame, |
52 int error_code, | 67 int error_code, |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
85 std::string script_; | 100 std::string script_; |
86 | 101 |
87 scoped_ptr<content::WebContents> web_contents_; | 102 scoped_ptr<content::WebContents> web_contents_; |
88 content::BrowserContext* browser_context_; | 103 content::BrowserContext* browser_context_; |
89 DISALLOW_COPY_AND_ASSIGN(DistillerPageWebContents); | 104 DISALLOW_COPY_AND_ASSIGN(DistillerPageWebContents); |
90 }; | 105 }; |
91 | 106 |
92 } // namespace dom_distiller | 107 } // namespace dom_distiller |
93 | 108 |
94 #endif // COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ | 109 #endif // COMPONENTS_DOM_DISTILLER_CONTENT_DISTILLER_PAGE_WEB_CONTENTS_H_ |
OLD | NEW |