| OLD | NEW |
| 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 /* | 5 /* |
| 6 * Copyright (C) 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. | 6 * Copyright (C) 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. |
| 7 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) | 7 * Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies) |
| 8 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. | 8 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. |
| 9 * (http://www.torchmobile.com/) | 9 * (http://www.torchmobile.com/) |
| 10 * | 10 * |
| (...skipping 17 matching lines...) Expand all Loading... |
| 28 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 28 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| 29 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 29 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| 30 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | 30 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| 31 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 31 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| 33 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 33 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 34 */ | 34 */ |
| 35 | 35 |
| 36 #include "content/renderer/history_controller.h" | 36 #include "content/renderer/history_controller.h" |
| 37 | 37 |
| 38 #include "content/common/navigation_params.h" |
| 38 #include "content/renderer/render_frame_impl.h" | 39 #include "content/renderer/render_frame_impl.h" |
| 39 #include "content/renderer/render_view_impl.h" | 40 #include "content/renderer/render_view_impl.h" |
| 40 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 41 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
| 41 | 42 |
| 42 using blink::WebFrame; | 43 using blink::WebFrame; |
| 43 using blink::WebHistoryCommitType; | 44 using blink::WebHistoryCommitType; |
| 44 using blink::WebHistoryItem; | 45 using blink::WebHistoryItem; |
| 45 using blink::WebURLRequest; | 46 using blink::WebURLRequest; |
| 46 | 47 |
| 47 namespace content { | 48 namespace content { |
| 48 | 49 |
| 49 HistoryController::HistoryController(RenderViewImpl* render_view) | 50 HistoryController::HistoryController(RenderViewImpl* render_view) |
| 50 : render_view_(render_view) { | 51 : render_view_(render_view) { |
| 51 } | 52 } |
| 52 | 53 |
| 53 HistoryController::~HistoryController() { | 54 HistoryController::~HistoryController() { |
| 54 } | 55 } |
| 55 | 56 |
| 56 void HistoryController::GoToEntry(scoped_ptr<HistoryEntry> target_entry, | 57 void HistoryController::GoToEntry( |
| 57 WebURLRequest::CachePolicy cache_policy) { | 58 scoped_ptr<HistoryEntry> target_entry, |
| 59 scoped_ptr<NavigationParams> navigation_params, |
| 60 WebURLRequest::CachePolicy cache_policy) { |
| 58 HistoryFrameLoadVector same_document_loads; | 61 HistoryFrameLoadVector same_document_loads; |
| 59 HistoryFrameLoadVector different_document_loads; | 62 HistoryFrameLoadVector different_document_loads; |
| 60 | 63 |
| 61 provisional_entry_ = target_entry.Pass(); | 64 provisional_entry_ = target_entry.Pass(); |
| 65 navigation_params_ = navigation_params.Pass(); |
| 62 | 66 |
| 63 WebFrame* main_frame = render_view_->GetMainRenderFrame()->GetWebFrame(); | 67 WebFrame* main_frame = render_view_->GetMainRenderFrame()->GetWebFrame(); |
| 64 if (current_entry_) { | 68 if (current_entry_) { |
| 65 RecursiveGoToEntry( | 69 RecursiveGoToEntry( |
| 66 main_frame, same_document_loads, different_document_loads); | 70 main_frame, same_document_loads, different_document_loads); |
| 67 } | 71 } |
| 68 | 72 |
| 69 if (same_document_loads.empty() && different_document_loads.empty()) { | 73 if (same_document_loads.empty() && different_document_loads.empty()) { |
| 70 // If we don't have any frames to navigate at this point, either | 74 // If we don't have any frames to navigate at this point, either |
| 71 // (1) there is no previous history entry to compare against, or | 75 // (1) there is no previous history entry to compare against, or |
| 72 // (2) we were unable to match any frames by name. In the first case, | 76 // (2) we were unable to match any frames by name. In the first case, |
| 73 // doing a different document navigation to the root item is the only valid | 77 // doing a different document navigation to the root item is the only valid |
| 74 // thing to do. In the second case, we should have been able to find a | 78 // thing to do. In the second case, we should have been able to find a |
| 75 // frame to navigate based on names if this were a same document | 79 // frame to navigate based on names if this were a same document |
| 76 // navigation, so we can safely assume this is the different document case. | 80 // navigation, so we can safely assume this is the different document case. |
| 77 different_document_loads.push_back( | 81 different_document_loads.push_back( |
| 78 std::make_pair(main_frame, provisional_entry_->root())); | 82 std::make_pair(main_frame, provisional_entry_->root())); |
| 79 } | 83 } |
| 80 | 84 |
| 81 for (size_t i = 0; i < same_document_loads.size(); ++i) { | 85 for (const auto& item : same_document_loads) { |
| 82 WebFrame* frame = same_document_loads[i].first; | 86 WebFrame* frame = item.first; |
| 83 if (!RenderFrameImpl::FromWebFrame(frame)) | 87 RenderFrameImpl* render_frame = RenderFrameImpl::FromWebFrame(frame); |
| 88 if (!render_frame) |
| 84 continue; | 89 continue; |
| 85 frame->loadHistoryItem(same_document_loads[i].second, | 90 render_frame->SetPendingNavigationParams(make_scoped_ptr( |
| 91 new NavigationParams(*navigation_params_.get()))); |
| 92 frame->loadHistoryItem(item.second, |
| 86 blink::WebHistorySameDocumentLoad, | 93 blink::WebHistorySameDocumentLoad, |
| 87 cache_policy); | 94 cache_policy); |
| 88 } | 95 } |
| 89 for (size_t i = 0; i < different_document_loads.size(); ++i) { | 96 for (const auto& item : different_document_loads) { |
| 90 WebFrame* frame = different_document_loads[i].first; | 97 WebFrame* frame = item.first; |
| 91 if (!RenderFrameImpl::FromWebFrame(frame)) | 98 RenderFrameImpl* render_frame = RenderFrameImpl::FromWebFrame(frame); |
| 99 if (!render_frame) |
| 92 continue; | 100 continue; |
| 93 frame->loadHistoryItem(different_document_loads[i].second, | 101 render_frame->SetPendingNavigationParams(make_scoped_ptr( |
| 102 new NavigationParams(*navigation_params_.get()))); |
| 103 frame->loadHistoryItem(item.second, |
| 94 blink::WebHistoryDifferentDocumentLoad, | 104 blink::WebHistoryDifferentDocumentLoad, |
| 95 cache_policy); | 105 cache_policy); |
| 96 } | 106 } |
| 97 } | 107 } |
| 98 | 108 |
| 99 void HistoryController::RecursiveGoToEntry( | 109 void HistoryController::RecursiveGoToEntry( |
| 100 WebFrame* frame, | 110 WebFrame* frame, |
| 101 HistoryFrameLoadVector& same_document_loads, | 111 HistoryFrameLoadVector& same_document_loads, |
| 102 HistoryFrameLoadVector& different_document_loads) { | 112 HistoryFrameLoadVector& different_document_loads) { |
| 103 DCHECK(provisional_entry_); | 113 DCHECK(provisional_entry_); |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 159 UpdateForInitialLoadInChildFrame(frame, item); | 169 UpdateForInitialLoadInChildFrame(frame, item); |
| 160 } | 170 } |
| 161 } | 171 } |
| 162 | 172 |
| 163 HistoryEntry* HistoryController::GetCurrentEntry() { | 173 HistoryEntry* HistoryController::GetCurrentEntry() { |
| 164 return current_entry_.get(); | 174 return current_entry_.get(); |
| 165 } | 175 } |
| 166 | 176 |
| 167 WebHistoryItem HistoryController::GetItemForNewChildFrame( | 177 WebHistoryItem HistoryController::GetItemForNewChildFrame( |
| 168 RenderFrameImpl* frame) const { | 178 RenderFrameImpl* frame) const { |
| 179 if (navigation_params_.get()) { |
| 180 frame->SetPendingNavigationParams(make_scoped_ptr( |
| 181 new NavigationParams(*navigation_params_.get()))); |
| 182 } |
| 183 |
| 169 if (!current_entry_) | 184 if (!current_entry_) |
| 170 return WebHistoryItem(); | 185 return WebHistoryItem(); |
| 171 return current_entry_->GetItemForFrame(frame); | 186 return current_entry_->GetItemForFrame(frame); |
| 172 } | 187 } |
| 173 | 188 |
| 174 void HistoryController::RemoveChildrenForRedirect(RenderFrameImpl* frame) { | 189 void HistoryController::RemoveChildrenForRedirect(RenderFrameImpl* frame) { |
| 175 if (!provisional_entry_) | 190 if (!provisional_entry_) |
| 176 return; | 191 return; |
| 177 if (HistoryEntry::HistoryNode* node = | 192 if (HistoryEntry::HistoryNode* node = |
| 178 provisional_entry_->GetHistoryNodeForFrame(frame)) | 193 provisional_entry_->GetHistoryNodeForFrame(frame)) |
| 179 node->RemoveChildren(); | 194 node->RemoveChildren(); |
| 180 } | 195 } |
| 181 | 196 |
| 182 void HistoryController::CreateNewBackForwardItem( | 197 void HistoryController::CreateNewBackForwardItem( |
| 183 RenderFrameImpl* target_frame, | 198 RenderFrameImpl* target_frame, |
| 184 const WebHistoryItem& new_item, | 199 const WebHistoryItem& new_item, |
| 185 bool clone_children_of_target) { | 200 bool clone_children_of_target) { |
| 186 if (!current_entry_) { | 201 if (!current_entry_) { |
| 187 current_entry_.reset( | 202 current_entry_.reset( |
| 188 new HistoryEntry(new_item, target_frame->GetRoutingID())); | 203 new HistoryEntry(new_item, target_frame->GetRoutingID())); |
| 189 } else { | 204 } else { |
| 190 current_entry_.reset(current_entry_->CloneAndReplace( | 205 current_entry_.reset(current_entry_->CloneAndReplace( |
| 191 new_item, clone_children_of_target, target_frame, render_view_)); | 206 new_item, clone_children_of_target, target_frame, render_view_)); |
| 192 } | 207 } |
| 193 } | 208 } |
| 194 | 209 |
| 195 } // namespace content | 210 } // namespace content |
| OLD | NEW |