| OLD | NEW | 
|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 #import "ios/web/web_state/ui/crw_web_controller.h" | 5 #import "ios/web/web_state/ui/crw_web_controller.h" | 
| 6 | 6 | 
| 7 #import <WebKit/WebKit.h> | 7 #import <WebKit/WebKit.h> | 
| 8 | 8 | 
| 9 #import <objc/runtime.h> | 9 #import <objc/runtime.h> | 
| 10 #include <stddef.h> | 10 #include <stddef.h> | 
| (...skipping 4520 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 4531   // the pending load. | 4531   // the pending load. | 
| 4532   _pendingNavigationInfo.reset(); | 4532   _pendingNavigationInfo.reset(); | 
| 4533   _certVerificationErrors->Clear(); | 4533   _certVerificationErrors->Clear(); | 
| 4534   [_navigationStates removeNavigation:navigation]; | 4534   [_navigationStates removeNavigation:navigation]; | 
| 4535 } | 4535 } | 
| 4536 | 4536 | 
| 4537 - (void)webView:(WKWebView*)webView | 4537 - (void)webView:(WKWebView*)webView | 
| 4538     didCommitNavigation:(WKNavigation*)navigation { | 4538     didCommitNavigation:(WKNavigation*)navigation { | 
| 4539   [self displayWebView]; | 4539   [self displayWebView]; | 
| 4540 | 4540 | 
|  | 4541   bool navigationFinished = [_navigationStates stateForNavigation:navigation] == | 
|  | 4542                             web::WKNavigationState::FINISHED; | 
|  | 4543 | 
| 4541   // Record the navigation state. | 4544   // Record the navigation state. | 
| 4542   [_navigationStates setState:web::WKNavigationState::COMMITTED | 4545   [_navigationStates setState:web::WKNavigationState::COMMITTED | 
| 4543                 forNavigation:navigation]; | 4546                 forNavigation:navigation]; | 
| 4544 | 4547 | 
| 4545   DCHECK_EQ(_webView, webView); | 4548   DCHECK_EQ(_webView, webView); | 
| 4546   _certVerificationErrors->Clear(); | 4549   _certVerificationErrors->Clear(); | 
| 4547 | 4550 | 
| 4548   // This is the point where the document's URL has actually changed, and | 4551   // This is the point where the document's URL has actually changed, and | 
| 4549   // pending navigation information should be applied to state information. | 4552   // pending navigation information should be applied to state information. | 
| 4550   [self setDocumentURL:net::GURLWithNSURL([_webView URL])]; | 4553   [self setDocumentURL:net::GURLWithNSURL([_webView URL])]; | 
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 4622   // item title should be updated. | 4625   // item title should be updated. | 
| 4623   [self setNavigationItemTitle:[_webView title]]; | 4626   [self setNavigationItemTitle:[_webView title]]; | 
| 4624 | 4627 | 
| 4625   // Report cases where SSL cert is missing for a secure connection. | 4628   // Report cases where SSL cert is missing for a secure connection. | 
| 4626   if (_documentURL.SchemeIsCryptographic()) { | 4629   if (_documentURL.SchemeIsCryptographic()) { | 
| 4627     scoped_refptr<net::X509Certificate> cert = | 4630     scoped_refptr<net::X509Certificate> cert = | 
| 4628         web::CreateCertFromChain([_webView certificateChain]); | 4631         web::CreateCertFromChain([_webView certificateChain]); | 
| 4629     UMA_HISTOGRAM_BOOLEAN("WebController.WKWebViewHasCertForSecureConnection", | 4632     UMA_HISTOGRAM_BOOLEAN("WebController.WKWebViewHasCertForSecureConnection", | 
| 4630                           static_cast<bool>(cert)); | 4633                           static_cast<bool>(cert)); | 
| 4631   } | 4634   } | 
|  | 4635 | 
|  | 4636   if (navigationFinished) { | 
|  | 4637     // webView:didFinishNavigation: was called before | 
|  | 4638     // webView:didCommitNavigation:, so remove the navigation now and signal | 
|  | 4639     // that navigation was finished. | 
|  | 4640     [_navigationStates removeNavigation:navigation]; | 
|  | 4641     [self didFinishNavigation:navigation]; | 
|  | 4642   } | 
| 4632 } | 4643 } | 
| 4633 | 4644 | 
| 4634 - (void)webView:(WKWebView*)webView | 4645 - (void)webView:(WKWebView*)webView | 
| 4635     didFinishNavigation:(WKNavigation*)navigation { | 4646     didFinishNavigation:(WKNavigation*)navigation { | 
|  | 4647   bool navigationCommitted = | 
|  | 4648       [_navigationStates stateForNavigation:navigation] == | 
|  | 4649       web::WKNavigationState::COMMITTED; | 
| 4636   [_navigationStates setState:web::WKNavigationState::FINISHED | 4650   [_navigationStates setState:web::WKNavigationState::FINISHED | 
| 4637                 forNavigation:navigation]; | 4651                 forNavigation:navigation]; | 
| 4638 | 4652 | 
| 4639   DCHECK(!_isHalted); | 4653   DCHECK(!_isHalted); | 
| 4640   // Trigger JavaScript driven post-document-load-completion tasks. | 4654   // Trigger JavaScript driven post-document-load-completion tasks. | 
| 4641   // TODO(crbug.com/546350): Investigate using | 4655   // TODO(crbug.com/546350): Investigate using | 
| 4642   // WKUserScriptInjectionTimeAtDocumentEnd to inject this material at the | 4656   // WKUserScriptInjectionTimeAtDocumentEnd to inject this material at the | 
| 4643   // appropriate time rather than invoking here. | 4657   // appropriate time rather than invoking here. | 
| 4644   web::ExecuteJavaScript(webView, @"__gCrWeb.didFinishNavigation()", nil); | 4658   web::ExecuteJavaScript(webView, @"__gCrWeb.didFinishNavigation()", nil); | 
| 4645   [self didFinishNavigation:navigation]; | 4659   [self didFinishNavigation:navigation]; | 
| 4646   [_navigationStates removeNavigation:navigation]; | 4660 | 
|  | 4661   // Remove navigation only if it has been committed. Otherwise it will be | 
|  | 4662   // removed in webView:didCommitNavigation: callback. | 
|  | 4663   if (navigationCommitted) { | 
|  | 4664     [_navigationStates removeNavigation:navigation]; | 
|  | 4665   } | 
| 4647 } | 4666 } | 
| 4648 | 4667 | 
| 4649 - (void)webView:(WKWebView*)webView | 4668 - (void)webView:(WKWebView*)webView | 
| 4650     didFailNavigation:(WKNavigation*)navigation | 4669     didFailNavigation:(WKNavigation*)navigation | 
| 4651             withError:(NSError*)error { | 4670             withError:(NSError*)error { | 
| 4652   [_navigationStates setState:web::WKNavigationState::FAILED | 4671   [_navigationStates setState:web::WKNavigationState::FAILED | 
| 4653                 forNavigation:navigation]; | 4672                 forNavigation:navigation]; | 
| 4654 | 4673 | 
| 4655   [self handleLoadError:WKWebViewErrorWithSource(error, NAVIGATION) | 4674   [self handleLoadError:WKWebViewErrorWithSource(error, NAVIGATION) | 
| 4656             inMainFrame:YES | 4675             inMainFrame:YES | 
| (...skipping 562 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 5219 - (NSUInteger)observerCount { | 5238 - (NSUInteger)observerCount { | 
| 5220   DCHECK_EQ(_observerBridges.size(), [_observers count]); | 5239   DCHECK_EQ(_observerBridges.size(), [_observers count]); | 
| 5221   return [_observers count]; | 5240   return [_observers count]; | 
| 5222 } | 5241 } | 
| 5223 | 5242 | 
| 5224 - (NSString*)referrerFromNavigationAction:(WKNavigationAction*)action { | 5243 - (NSString*)referrerFromNavigationAction:(WKNavigationAction*)action { | 
| 5225   return [action.request valueForHTTPHeaderField:kReferrerHeaderName]; | 5244   return [action.request valueForHTTPHeaderField:kReferrerHeaderName]; | 
| 5226 } | 5245 } | 
| 5227 | 5246 | 
| 5228 @end | 5247 @end | 
| OLD | NEW | 
|---|