Index: chrome/browser/prerender/prerender_handle.cc |
diff --git a/chrome/browser/prerender/prerender_handle.cc b/chrome/browser/prerender/prerender_handle.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0242f7dd684b34de2e4512985d58dfb5d3e1b117 |
--- /dev/null |
+++ b/chrome/browser/prerender/prerender_handle.cc |
@@ -0,0 +1,70 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/prerender/prerender_handle.h" |
+ |
+#include <algorithm> |
+ |
+#include "chrome/browser/prerender/prerender_contents.h" |
+ |
+namespace prerender { |
+ |
+PrerenderHandle::~PrerenderHandle() { |
+ OnCancel(); |
+} |
+ |
+void PrerenderHandle::OnNavigateAway() { |
+ DCHECK(CalledOnValidThread()); |
+ // TODO(gavinp): Implement reasonable behaviour for navigation away from |
+ // launcher. We can't just call OnCancel, because many cases have redirect |
+ // chains that will eventually lead to the correct prerendered page, and we |
+ // don't want to delete our prerender just as it is going to be used. |
+ prerender_data_.reset(); |
+} |
+ |
+void PrerenderHandle::OnCancel() { |
+ DCHECK(CalledOnValidThread()); |
+ if (!prerender_data_) |
+ return; |
+ |
+ prerender_data_->OnCancel(); |
+ prerender_data_.reset(); |
+} |
+ |
+bool PrerenderHandle::IsValid() const { |
+ return prerender_data_ != NULL; |
+} |
+ |
+bool PrerenderHandle::IsPending() const { |
+ DCHECK(CalledOnValidThread()); |
+ return prerender_data_ && !prerender_data_->contents(); |
+} |
+ |
+bool PrerenderHandle::IsPrerendering() const { |
+ DCHECK(CalledOnValidThread()); |
+ return prerender_data_ && prerender_data_->contents(); |
+} |
+ |
+bool PrerenderHandle::IsFinishedLoading() const { |
+ DCHECK(CalledOnValidThread()); |
+ if (!prerender_data_ || IsPending()) |
+ return false; |
+ return prerender_data_->contents()->has_finished_loading(); |
+} |
+ |
+PrerenderHandle::PrerenderHandle( |
+ PrerenderManager::PrerenderData* prerender_data) |
+ : prerender_data_(prerender_data->AsWeakPtr()), |
+ weak_ptr_factory_(this) { |
+ prerender_data->OnNewHandle(); |
+} |
+ |
+void PrerenderHandle::SwapPrerenderDataWith( |
+ PrerenderHandle* other_prerender_handle) { |
+ DCHECK(CalledOnValidThread()); |
+ DCHECK(other_prerender_handle); |
+ std::swap(prerender_data_, other_prerender_handle->prerender_data_); |
+} |
+ |
+} // namespace prerender |