Chromium Code Reviews| 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 #include "content/browser/frame_host/navigator.h" | 5 #include "content/browser/frame_host/navigator.h" |
| 6 | 6 |
| 7 #include "content/browser/frame_host/frame_tree_node.h" | |
| 8 #include "content/browser/frame_host/navigation_controller_impl.h" | |
| 9 #include "content/browser/frame_host/navigation_entry_impl.h" | |
| 7 #include "content/browser/frame_host/navigator_delegate.h" | 10 #include "content/browser/frame_host/navigator_delegate.h" |
| 11 #include "content/browser/frame_host/render_frame_host_impl.h" | |
| 12 #include "content/browser/renderer_host/render_view_host_impl.h" | |
| 13 #include "content/browser/site_instance_impl.h" | |
| 14 #include "content/public/browser/browser_context.h" | |
| 15 #include "content/public/browser/invalidate_type.h" | |
| 16 #include "content/public/browser/navigation_controller.h" | |
| 17 #include "content/public/browser/render_view_host.h" | |
| 18 #include "content/public/common/url_constants.h" | |
| 8 | 19 |
| 9 namespace content { | 20 namespace content { |
| 10 | 21 |
| 11 Navigator::Navigator( | 22 Navigator::Navigator( |
| 12 NavigationControllerImpl* nav_controller, | 23 NavigationControllerImpl* nav_controller, |
| 13 NavigatorDelegate* delegate) | 24 NavigatorDelegate* delegate) |
| 14 : controller_(nav_controller), | 25 : controller_(nav_controller), |
| 15 delegate_(delegate) { | 26 delegate_(delegate) { |
| 16 } | 27 } |
| 17 | 28 |
| 29 void Navigator::DidStartProvisionalLoad( | |
| 30 RenderFrameHostImpl* render_frame_host, | |
| 31 int64 frame_id, | |
| 32 int64 parent_frame_id, | |
| 33 bool is_main_frame, | |
| 34 const GURL& url) { | |
| 35 bool is_error_page = (url.spec() == kUnreachableWebDataURL); | |
| 36 bool is_iframe_srcdoc = (url.spec() == kAboutSrcDocURL); | |
| 37 GURL validated_url(url); | |
| 38 RenderProcessHost* render_process_host = render_frame_host->GetProcess(); | |
| 39 RenderViewHost::FilterURL(render_process_host, false, &validated_url); | |
| 40 | |
| 41 if (is_main_frame) { | |
| 42 // If there is no browser-initiated pending entry for this navigation and it | |
| 43 // is not for the error URL, create a pending entry using the current | |
| 44 // SiteInstance, and ensure the address bar updates accordingly. We don't | |
| 45 // know the referrer or extra headers at this point, but the referrer will | |
| 46 // be set properly upon commit. | |
| 47 NavigationEntryImpl* pending_entry = | |
| 48 NavigationEntryImpl::FromNavigationEntry( | |
| 49 controller_->GetPendingEntry()); | |
| 50 bool has_browser_initiated_pending_entry = pending_entry && | |
| 51 !pending_entry->is_renderer_initiated(); | |
| 52 if (!has_browser_initiated_pending_entry && !is_error_page) { | |
| 53 NavigationEntryImpl* entry = NavigationEntryImpl::FromNavigationEntry( | |
| 54 controller_->CreateNavigationEntry(validated_url, | |
| 55 content::Referrer(), | |
| 56 content::PAGE_TRANSITION_LINK, | |
| 57 true /* is_renderer_initiated */, | |
| 58 std::string(), | |
| 59 controller_->GetBrowserContext())); | |
| 60 entry->set_site_instance( | |
| 61 static_cast<SiteInstanceImpl*>( | |
| 62 render_frame_host->render_view_host()->GetSiteInstance())); | |
| 63 // TODO(creis): If there's a pending entry already, find a safe way to | |
| 64 // update it instead of replacing it and copying over things like this. | |
| 65 if (pending_entry) { | |
| 66 entry->set_transferred_global_request_id( | |
| 67 pending_entry->transferred_global_request_id()); | |
| 68 entry->set_should_replace_entry(pending_entry->should_replace_entry()); | |
| 69 entry->set_redirect_chain(pending_entry->redirect_chain()); | |
| 70 } | |
| 71 controller_->SetPendingEntry(entry); | |
| 72 if (delegate_) | |
| 73 delegate_->NotifyChangedNavigationState(content::INVALIDATE_TYPE_URL); | |
| 74 } | |
| 75 } | |
| 76 | |
| 77 if (delegate_) { | |
| 78 // Notify the observer about the start of the provisional load. | |
| 79 delegate_->DidStartProvisionalLoad( | |
|
awong
2013/11/22 02:35:51
Random thought (take it or leave it)...do we want
nasko
2013/11/22 15:19:30
Those are different classes, so I'm not sure I und
| |
| 80 render_frame_host, frame_id, parent_frame_id, is_main_frame, | |
| 81 validated_url, is_error_page, is_iframe_srcdoc); | |
| 82 } | |
| 83 } | |
| 84 | |
| 18 } // namespace content | 85 } // namespace content |
| OLD | NEW |