OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 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_frame/bho.h" | 5 #include "chrome_frame/bho.h" |
6 | 6 |
7 #include <shlguid.h> | 7 #include <shlguid.h> |
8 #include <shobjidl.h> | 8 #include <shobjidl.h> |
9 | 9 |
10 #include "base/file_path.h" | 10 #include "base/file_path.h" |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
87 bho_current_thread_instance_.Pointer()->Set(NULL); | 87 bho_current_thread_instance_.Pointer()->Set(NULL); |
88 Release(); | 88 Release(); |
89 } | 89 } |
90 | 90 |
91 return IObjectWithSiteImpl<Bho>::SetSite(site); | 91 return IObjectWithSiteImpl<Bho>::SetSite(site); |
92 } | 92 } |
93 | 93 |
94 STDMETHODIMP Bho::BeforeNavigate2(IDispatch* dispatch, VARIANT* url, | 94 STDMETHODIMP Bho::BeforeNavigate2(IDispatch* dispatch, VARIANT* url, |
95 VARIANT* flags, VARIANT* target_frame_name, VARIANT* post_data, | 95 VARIANT* flags, VARIANT* target_frame_name, VARIANT* post_data, |
96 VARIANT* headers, VARIANT_BOOL* cancel) { | 96 VARIANT* headers, VARIANT_BOOL* cancel) { |
| 97 if (!url || url->vt != VT_BSTR || url->bstrVal == NULL) { |
| 98 DLOG(WARNING) << "Invalid URL passed in"; |
| 99 return S_OK; |
| 100 } |
| 101 |
97 ScopedComPtr<IWebBrowser2> web_browser2; | 102 ScopedComPtr<IWebBrowser2> web_browser2; |
98 if (dispatch) | 103 if (dispatch) |
99 web_browser2.QueryFrom(dispatch); | 104 web_browser2.QueryFrom(dispatch); |
100 | 105 |
101 if (!web_browser2 || url->vt != VT_BSTR) { | 106 if (!web_browser2) { |
102 NOTREACHED() << "Can't find WebBrowser2 with given dispatch"; | 107 NOTREACHED() << "Can't find WebBrowser2 with given dispatch"; |
103 } else { | 108 return S_OK; |
104 DLOG(INFO) << "BeforeNavigate2: " << url->bstrVal; | |
105 ScopedComPtr<IBrowserService> browser_service; | |
106 DoQueryService(SID_SShellBrowser, web_browser2, browser_service.Receive()); | |
107 if (!browser_service || !CheckForCFNavigation(browser_service, false)) { | |
108 referrer_.clear(); | |
109 } | |
110 url_ = url->bstrVal; | |
111 ProcessOptInUrls(web_browser2, url->bstrVal); | |
112 } | 109 } |
113 | 110 |
| 111 DLOG(INFO) << "BeforeNavigate2: " << url->bstrVal; |
| 112 ScopedComPtr<IBrowserService> browser_service; |
| 113 DoQueryService(SID_SShellBrowser, web_browser2, browser_service.Receive()); |
| 114 if (!browser_service || !CheckForCFNavigation(browser_service, false)) { |
| 115 referrer_.clear(); |
| 116 } |
| 117 url_ = url->bstrVal; |
| 118 ProcessOptInUrls(web_browser2, url->bstrVal); |
114 return S_OK; | 119 return S_OK; |
115 } | 120 } |
116 | 121 |
117 HRESULT Bho::NavigateToCurrentUrlInCF(IBrowserService* browser) { | 122 HRESULT Bho::NavigateToCurrentUrlInCF(IBrowserService* browser) { |
118 DCHECK(browser); | 123 DCHECK(browser); |
119 MarkBrowserOnThreadForCFNavigation(browser); | 124 MarkBrowserOnThreadForCFNavigation(browser); |
120 ScopedComPtr<IBindCtx> bind_context; | 125 ScopedComPtr<IBindCtx> bind_context; |
121 ScopedComPtr<IMoniker> moniker; | 126 ScopedComPtr<IMoniker> moniker; |
122 HRESULT hr = ::CreateBindCtx(0, bind_context.Receive()); | 127 HRESULT hr = ::CreateBindCtx(0, bind_context.Receive()); |
123 DCHECK(bind_context); | 128 DCHECK(bind_context); |
(...skipping 261 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
385 ProtocolSinkWrap::UnpatchProtocolHandlers(); | 390 ProtocolSinkWrap::UnpatchProtocolHandlers(); |
386 } else if (state_ == PATCH_IBROWSER) { | 391 } else if (state_ == PATCH_IBROWSER) { |
387 vtable_patch::UnpatchInterfaceMethods(IBrowserService_PatchInfo); | 392 vtable_patch::UnpatchInterfaceMethods(IBrowserService_PatchInfo); |
388 } | 393 } |
389 | 394 |
390 HttpNegotiatePatch::Uninitialize(); | 395 HttpNegotiatePatch::Uninitialize(); |
391 | 396 |
392 state_ = UNKNOWN; | 397 state_ = UNKNOWN; |
393 } | 398 } |
394 | 399 |
OLD | NEW |