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

Side by Side Diff: chrome/browser/prerender/prerender_handle.cc

Issue 11316311: Make PrerenderHandle an observer of PrerenderContents. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: signal stop on match complete Created 8 years 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/prerender/prerender_handle.h" 5 #include "chrome/browser/prerender/prerender_handle.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "chrome/browser/prerender/prerender_contents.h" 9 #include "chrome/browser/prerender/prerender_contents.h"
10 10
11 namespace prerender { 11 namespace prerender {
12 12
13 PrerenderHandle::Observer::~Observer() {
14 }
15
16 PrerenderHandle::Observer::Observer() {
17 }
18
13 PrerenderHandle::~PrerenderHandle() { 19 PrerenderHandle::~PrerenderHandle() {
14 DCHECK(!IsValid()); 20 if (prerender_data_) {
15 // This shouldn't occur, but we also shouldn't leak if it does. 21 prerender_data_->contents()->RemoveObserver(this);
16 if (IsValid()) 22 prerender_data_->OnHandleCanceled(this);
17 OnCancel(); 23 }
18 } 24 }
19 25
20 void PrerenderHandle::OnNavigateAway() { 26 void PrerenderHandle::OnNavigateAway() {
21 DCHECK(CalledOnValidThread()); 27 DCHECK(CalledOnValidThread());
22 if (!IsValid()) 28 if (prerender_data_)
23 return; 29 prerender_data_->OnHandleNavigatedAway(this);
24 prerender_data_->OnNavigateAwayByHandle();
25 prerender_data_.reset();
26 }
27
28 void PrerenderHandle::OnCancel() {
29 DCHECK(CalledOnValidThread());
30 if (!IsValid())
31 return;
32 prerender_data_->OnCancelByHandle();
33 prerender_data_.reset();
34 }
35
36 bool PrerenderHandle::IsValid() const {
37 return prerender_data_ != NULL;
38 }
39
40 bool PrerenderHandle::IsPending() const {
41 DCHECK(CalledOnValidThread());
42 return prerender_data_ && !prerender_data_->contents();
43 } 30 }
44 31
45 bool PrerenderHandle::IsPrerendering() const { 32 bool PrerenderHandle::IsPrerendering() const {
46 DCHECK(CalledOnValidThread()); 33 DCHECK(CalledOnValidThread());
47 return prerender_data_ && prerender_data_->contents(); 34 return prerender_data_ != NULL;
48 } 35 }
49 36
50 bool PrerenderHandle::IsFinishedLoading() const { 37 bool PrerenderHandle::IsFinishedLoading() const {
51 DCHECK(CalledOnValidThread()); 38 DCHECK(CalledOnValidThread());
52 if (!prerender_data_ || IsPending()) 39 if (!prerender_data_)
53 return false; 40 return false;
54 return prerender_data_->contents()->has_finished_loading(); 41 return prerender_data_->contents()->has_finished_loading();
55 } 42 }
56 43
57 PrerenderHandle::PrerenderHandle( 44 PrerenderHandle::PrerenderHandle(
58 PrerenderManager::PrerenderData* prerender_data) 45 PrerenderManager::PrerenderData* prerender_data)
59 : prerender_data_(prerender_data->AsWeakPtr()), 46 : observer_(NULL),
60 weak_ptr_factory_(this) { 47 weak_ptr_factory_(this) {
61 prerender_data->OnNewHandle(); 48 if (prerender_data) {
49 prerender_data_ = prerender_data->AsWeakPtr();
50 prerender_data->OnHandleCreated(this);
51 }
62 } 52 }
63 53
64 void PrerenderHandle::SwapPrerenderDataWith( 54 void PrerenderHandle::AdoptPrerenderDataFrom(PrerenderHandle* other_handle) {
65 PrerenderHandle* other_prerender_handle) { 55 DCHECK_EQ(static_cast<PrerenderManager::PrerenderData*>(NULL),
56 prerender_data_);
57 if (other_handle->prerender_data_ &&
58 other_handle->prerender_data_->contents()) {
59 other_handle->prerender_data_->contents()->RemoveObserver(other_handle);
60 }
61
62 prerender_data_ = other_handle->prerender_data_;
63 other_handle->prerender_data_.reset();
64
65 if (prerender_data_) {
66 DCHECK_NE(static_cast<PrerenderContents*>(NULL),
67 prerender_data_->contents());
68 prerender_data_->contents()->AddObserver(this);
69 // We are joining a prerender that has already started so we fire off an
70 // extra start event at ourselves.
71 OnPrerenderStart(prerender_data_->contents());
72 }
73 }
74
75 void PrerenderHandle::OnPrerenderStart(PrerenderContents* prerender_contents) {
66 DCHECK(CalledOnValidThread()); 76 DCHECK(CalledOnValidThread());
67 DCHECK(other_prerender_handle); 77 DCHECK(prerender_data_);
68 std::swap(prerender_data_, other_prerender_handle->prerender_data_); 78 DCHECK_EQ(prerender_data_->contents(), prerender_contents);
79 if (observer_)
80 observer_->OnPrerenderStart(this);
81 }
82
83 void PrerenderHandle::OnPrerenderAddAlias(PrerenderContents* prerender_contents,
84 const GURL& alias_url) {
85 DCHECK(CalledOnValidThread());
86 DCHECK(prerender_data_);
87 DCHECK_EQ(prerender_data_->contents(), prerender_contents);
88 if (observer_)
89 observer_->OnPrerenderAddAlias(this, alias_url);
90 }
91
92 void PrerenderHandle::OnPrerenderStop(PrerenderContents* prerender_contents) {
93 DCHECK(CalledOnValidThread());
94 if (observer_)
95 observer_->OnPrerenderStop(this);
96 }
97
98 void PrerenderHandle::OnPrerenderCreatedMatchCompleteReplacement(
99 PrerenderContents* contents, PrerenderContents* replacement) {
100 DCHECK(CalledOnValidThread());
101
102 // This should occur in the middle of the surgery on the PrerenderData, and
103 // so we expect to not have our new contents in our PrerenderData yet. The
104 // switch occurs in
105 // PrerenderManager::PrerenderData::MakeIntoMatchCompleteReplacement, so
106 // this method only needs to switch observing.
107
108 contents->RemoveObserver(this);
109 replacement->AddObserver(this);
69 } 110 }
70 111
71 } // namespace prerender 112 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698