Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 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 | 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 "chrome/browser/android/offline_pages/prerendering_loader.h" | 5 #include "chrome/browser/android/offline_pages/prerendering_loader.h" |
| 6 | 6 |
| 7 #include "base/location.h" | |
| 8 #include "chrome/browser/prerender/prerender_manager.h" | |
| 9 #include "chrome/browser/prerender/prerender_manager_factory.h" | |
| 10 #include "chrome/browser/profiles/profile.h" | |
| 11 #include "content/public/browser/browser_context.h" | |
| 7 #include "content/public/browser/web_contents.h" | 12 #include "content/public/browser/web_contents.h" |
| 8 #include "ui/gfx/geometry/size.h" | 13 #include "ui/gfx/geometry/size.h" |
| 9 | 14 |
| 10 namespace offline_pages { | 15 namespace offline_pages { |
| 11 | 16 |
| 12 PrerenderingLoader::PrerenderingLoader(PrerenderManager* prerender_manager) {} | 17 using PrerenderingAdapter = PrerenderingLoader::PrerenderingAdapter; |
| 13 | 18 |
| 14 PrerenderingLoader::~PrerenderingLoader() {} | 19 PrerenderingLoader::PrerenderingLoader(content::BrowserContext* browser_context) |
| 20 : browser_context_(browser_context) { | |
| 21 adapter_.reset(new PrerenderingAdapter()); | |
|
Pete Williamson
2016/05/10 20:00:27
If we pass in the adapter as an argument, we won't
dougarnett
2016/05/10 21:33:11
Maybe use factory methods then to inject appropria
fgorski
2016/05/10 21:36:27
also, if you are initializing in constructor, plea
dougarnett
2016/05/10 23:08:21
Revised to use initializer list for now - but have
| |
| 22 } | |
| 15 | 23 |
| 16 bool PrerenderingLoader::LoadPage( | 24 PrerenderingLoader::~PrerenderingLoader() { |
| 17 const GURL& url, | 25 ReleaseCurrentLoad(); |
| 18 content::SessionStorageNamespace* session_storage_namespace, | 26 } |
| 19 const gfx::Size& size, | 27 |
| 20 const LoadPageCallback& callback) { | 28 bool PrerenderingLoader::LoadPage(const GURL& url, |
| 21 // TODO(dougarnett): implement. | 29 const LoadPageCallback& callback) { |
| 22 return false; | 30 if (state_ != State::kIdle) { |
| 31 LOG(WARNING) << "Existing request pending"; | |
|
fgorski
2016/05/10 21:36:27
use DVLOG
LOG is too heavy.
dougarnett
2016/05/10 23:08:22
Done.
| |
| 32 return false; | |
| 33 } | |
| 34 if (!CanPrerender()) | |
| 35 return false; | |
| 36 | |
| 37 adapter_->AddPrerenderForOffline(browser_context_, url, | |
| 38 GetSessionStorageNamespace(), GetSize()); | |
| 39 if (!adapter_->IsActive()) | |
| 40 return false; | |
| 41 | |
| 42 callback_ = callback; | |
| 43 adapter_->SetObserver(this); | |
| 44 state_ = State::kLoading; | |
| 45 return true; | |
| 23 } | 46 } |
| 24 | 47 |
| 25 void PrerenderingLoader::StopLoading() { | 48 void PrerenderingLoader::StopLoading() { |
| 26 // TODO(dougarnett): implement. | 49 ReleaseCurrentLoad(); |
| 50 state_ = State::kIdle; | |
| 51 } | |
| 52 | |
| 53 bool PrerenderingLoader::CanPrerender() { | |
| 54 // First check if prerendering is enabled. | |
| 55 return adapter_->CanPrerender(); | |
| 56 } | |
| 57 | |
| 58 bool PrerenderingLoader::IsIdle() { | |
| 59 return state_ == State::kIdle; | |
| 60 } | |
| 61 | |
| 62 content::SessionStorageNamespace* | |
| 63 PrerenderingLoader::GetSessionStorageNamespace() { | |
| 64 // TODO(dougarnett): Create separate namespace from default. | |
|
Pete Williamson
2016/05/10 20:00:27
A comment should say *why* we use a separate sessi
dougarnett
2016/05/10 21:33:11
Done.
| |
| 65 return content::WebContents::Create( | |
| 66 content::WebContents::CreateParams(browser_context_)) | |
| 67 ->GetController() | |
|
Pete Williamson
2016/05/10 20:00:27
I don't think we need a newline here
dougarnett
2016/05/10 21:33:11
not my original edit - brought to you by "git cl f
fgorski
2016/05/10 21:36:27
Make sure to run git cl format
| |
| 68 .GetDefaultSessionStorageNamespace(); | |
| 69 } | |
| 70 | |
| 71 const gfx::Size PrerenderingLoader::GetSize() { | |
| 72 return content::WebContents::Create( | |
| 73 content::WebContents::CreateParams(browser_context_)) | |
| 74 ->GetContainerBounds() | |
|
Pete Williamson
2016/05/10 20:00:27
I think I normally see -> at the end of the line a
dougarnett
2016/05/10 21:33:11
ditto
| |
| 75 .size(); | |
|
Pete Williamson
2016/05/10 20:00:27
I don't think we need a newline here (before .size
dougarnett
2016/05/10 21:33:11
ditto
| |
| 76 } | |
| 77 | |
| 78 void PrerenderingLoader::ReportLoaded() { | |
| 79 if (state_ == State::kLoading) { | |
| 80 content::WebContents* contents = adapter_->GetPrerenderContents(); | |
| 81 if (contents) { | |
| 82 state_ = State::kLoaded; | |
| 83 callback_.Run(true, contents); | |
| 84 } else { | |
| 85 ReportLoadFailed(); | |
| 86 } | |
| 87 } | |
| 88 } | |
| 89 | |
| 90 void PrerenderingLoader::ReportLoadFailed() { | |
| 91 if (state_ != State::kLoaded && state_ != State::kIdle) { | |
| 92 if (adapter_->IsActive()) | |
| 93 DVLOG(1) << "Load failed: " << adapter_->GetFinalStatus(); | |
| 94 state_ = State::kIdle; | |
| 95 callback_.Run(false, nullptr); | |
|
fgorski
2016/05/10 21:36:27
add a todo, that you want to post it to the thread
dougarnett
2016/05/10 23:08:22
Done.
| |
| 96 } | |
| 97 } | |
| 98 | |
| 99 void PrerenderingLoader::ReleaseCurrentLoad() { | |
|
Pete Williamson
2016/05/10 20:00:27
Naming suggestion: CancelPrerender()
dougarnett
2016/05/10 21:33:11
Done.
| |
| 100 if (adapter_->IsPrerendering()) | |
| 101 adapter_->OnCancel(); | |
| 102 adapter_->DestroyActive(); | |
| 103 } | |
| 104 | |
| 105 void PrerenderingLoader::OnPrerenderStart(prerender::PrerenderHandle* handle) { | |
| 106 if (adapter_->IsActive(handle) && state_ == State::kPending) { | |
|
fgorski
2016/05/10 21:36:27
nit: skip {}
Also consider if this should be DCHE
dougarnett
2016/05/10 23:08:21
I've been wondering if there is some different pro
| |
| 107 state_ = State::kLoading; | |
| 108 } | |
| 109 } | |
| 110 | |
| 111 void PrerenderingLoader::OnPrerenderStopLoading( | |
| 112 prerender::PrerenderHandle* handle) { | |
| 113 if (adapter_->IsActive(handle)) { | |
| 114 // TODO(dougarnett): Implement/integrate to delay policy here. | |
| 115 ReportLoaded(); | |
|
Pete Williamson
2016/05/10 20:00:27
So we seem to return "loaded" for both stop loadin
dougarnett
2016/05/10 21:33:11
Not initially, the state change from kLoading to k
| |
| 116 } | |
| 117 } | |
| 118 | |
| 119 void PrerenderingLoader::OnPrerenderDomContentLoaded( | |
| 120 prerender::PrerenderHandle* handle) { | |
| 121 if (adapter_->IsActive(handle)) { | |
| 122 // TODO(dougarnett): Implement/integrate to delay policy here. | |
| 123 ReportLoaded(); | |
| 124 } | |
| 125 } | |
| 126 | |
| 127 void PrerenderingLoader::OnPrerenderStop(prerender::PrerenderHandle* handle) { | |
| 128 if (adapter_->IsActive(handle)) { | |
| 129 ReportLoadFailed(); | |
| 130 } | |
| 131 } | |
| 132 | |
| 133 void PrerenderingLoader::OnPrerenderCreatedMatchCompleteReplacement( | |
| 134 prerender::PrerenderHandle* handle) { | |
| 135 LOG(WARNING) << "Offlining prerender should never do replacement"; | |
|
fgorski
2016/05/10 21:36:27
dvlog
dougarnett
2016/05/10 23:08:22
Done
| |
| 136 } | |
| 137 | |
| 138 void PrerenderingLoader::SetAdapterForTesting( | |
| 139 PrerenderingAdapter* prerendering_adapter) { | |
| 140 adapter_.reset(prerendering_adapter); | |
| 141 } | |
| 142 | |
| 143 // Adapter implementation to prerender stack: | |
| 144 | |
| 145 bool PrerenderingAdapter::CanPrerender() const { | |
| 146 return prerender::PrerenderManager::ActuallyPrerendering(); | |
| 147 } | |
| 148 | |
| 149 bool PrerenderingAdapter::AddPrerenderForOffline( | |
| 150 content::BrowserContext* browser_context, | |
| 151 const GURL& url, | |
| 152 content::SessionStorageNamespace* session_storage_namespace, | |
| 153 const gfx::Size& size) { | |
| 154 DCHECK(!IsActive()); | |
| 155 Profile* profile = Profile::FromBrowserContext(browser_context); | |
| 156 prerender::PrerenderManager* manager = | |
| 157 prerender::PrerenderManagerFactory::GetForProfile(profile); | |
| 158 DCHECK(manager); | |
| 159 active_handle_.reset( | |
|
Pete Williamson
2016/05/10 20:00:27
// Start the prerender manager doing the render of
dougarnett
2016/05/10 21:33:11
Done.
| |
| 160 manager->AddPrerenderForOffline(url, session_storage_namespace, size)); | |
| 161 return active_handle_.get(); | |
| 162 } | |
| 163 | |
| 164 void PrerenderingAdapter::SetObserver( | |
| 165 prerender::PrerenderHandle::Observer* observer) { | |
| 166 active_handle_->SetObserver(observer); | |
| 167 } | |
| 168 | |
| 169 bool PrerenderingAdapter::IsPrerendering() const { | |
| 170 return active_handle_->IsPrerendering(); | |
| 171 } | |
| 172 | |
| 173 void PrerenderingAdapter::OnCancel() { | |
| 174 active_handle_->OnCancel(); | |
| 175 } | |
| 176 | |
| 177 content::WebContents* PrerenderingAdapter::GetPrerenderContents() const { | |
| 178 if (active_handle_->contents()) { | |
| 179 return active_handle_->contents()->prerender_contents(); | |
|
Pete Williamson
2016/05/10 20:00:27
Maybe add a comment about ownership of the web con
dougarnett
2016/05/10 21:33:11
Beefed up .h comment and added .cc comment as well
| |
| 180 } | |
| 181 return nullptr; | |
| 182 } | |
| 183 | |
| 184 prerender::FinalStatus PrerenderingAdapter::GetFinalStatus() const { | |
| 185 DCHECK(active_handle_->contents()); | |
| 186 return active_handle_->contents()->final_status(); | |
| 187 } | |
| 188 | |
| 189 bool PrerenderingAdapter::IsActive() const { | |
| 190 return active_handle_ ? true : false; | |
|
fgorski
2016/05/10 21:36:27
return active_handle_;
dougarnett
2016/05/10 23:08:22
Compiler not happy with that - but maybe return ac
| |
| 191 } | |
| 192 | |
| 193 bool PrerenderingAdapter::IsActive(prerender::PrerenderHandle* handle) const { | |
| 194 return active_handle_.get() == handle; | |
| 195 } | |
| 196 | |
| 197 void PrerenderingAdapter::DestroyActive() { | |
| 198 active_handle_.reset(nullptr); | |
| 27 } | 199 } |
| 28 | 200 |
| 29 } // namespace offline_pages | 201 } // namespace offline_pages |
| OLD | NEW |