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

Unified Diff: ios/chrome/browser/native_app_launcher/native_app_navigation_utils.mm

Issue 2650563002: Pass WebState to NativeAppNavigationController (Closed)
Patch Set: IsLinkNavigation() is now a util function w/ unit tests Created 3 years, 11 months 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 side-by-side diff with in-line comments
Download patch
Index: ios/chrome/browser/native_app_launcher/native_app_navigation_utils.mm
diff --git a/ios/chrome/browser/native_app_launcher/native_app_navigation_utils.mm b/ios/chrome/browser/native_app_launcher/native_app_navigation_utils.mm
new file mode 100644
index 0000000000000000000000000000000000000000..80af7ed6ac1b69a0811b3857dd4d41e06ff496cb
--- /dev/null
+++ b/ios/chrome/browser/native_app_launcher/native_app_navigation_utils.mm
@@ -0,0 +1,38 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ios/chrome/browser/native_app_launcher/native_app_navigation_utils.h"
+
+#include "base/logging.h"
+#import "ios/web/navigation/navigation_manager_impl.h"
Eugene But (OOO till 7-30) 2017/01/26 01:04:38 do we need this include?
pkl (ping after 24h if needed) 2017/01/26 02:26:28 Not this one, but we do need ios/web/public/naviga
+#include "ios/web/public/navigation_item.h"
+#include "ios/web/public/web_state/web_state.h"
Eugene But (OOO till 7-30) 2017/01/26 01:04:38 s/include/import
pkl (ping after 24h if needed) 2017/01/26 02:26:28 web_state.h is all C++ code, so should be #include
Eugene But (OOO till 7-30) 2017/01/26 03:10:02 Line 26 is Objective-C code.
pkl (ping after 24h if needed) 2017/01/26 19:44:24 Done.
+
+namespace native_app_launcher {
+
+bool IsLinkNavigation(web::WebState* webState) {
Eugene But (OOO till 7-30) 2017/01/26 01:04:39 Please use C++ Style for variables
pkl (ping after 24h if needed) 2017/01/26 02:26:28 Done.
+ web::NavigationManager* navigationManager = webState->GetNavigationManager();
+ if (!navigationManager)
+ return false;
Eugene But (OOO till 7-30) 2017/01/26 01:04:38 Can this ever happen? I think NavigationManager li
pkl (ping after 24h if needed) 2017/01/26 02:26:28 web_state.h says "Can never return null". Cool! Tu
+ int index = navigationManager->GetCurrentItemIndex();
+ // Walks backward on the navigation items for the first item that is not a
Eugene But (OOO till 7-30) 2017/01/26 01:04:38 nit: s/Walks/Walk
pkl (ping after 24h if needed) 2017/01/26 02:26:28 I recall that comments should be third-person sing
Eugene But (OOO till 7-30) 2017/01/26 03:10:02 I guess you referring to Style Guide: "Use descrip
pkl (ping after 24h if needed) 2017/01/26 19:44:24 Acknowledged.
+ // redirect.
+ while (index >= 0) {
+ web::NavigationItem* item = navigationManager->GetItemAtIndex(index);
+ DCHECK(item);
+ ui::PageTransition currentTransition = item->GetTransitionType();
+ // Checks non-redirect entries for transitions that are either links or
+ // bookmarks.
+ if ((currentTransition & ui::PAGE_TRANSITION_IS_REDIRECT_MASK) == 0) {
+ return PageTransitionCoreTypeIs(currentTransition,
+ ui::PAGE_TRANSITION_LINK) ||
+ PageTransitionCoreTypeIs(currentTransition,
+ ui::PAGE_TRANSITION_AUTO_BOOKMARK);
+ }
+ --index;
+ }
+ return false;
+}
+
+} // namespace native_app_launcher

Powered by Google App Engine
This is Rietveld 408576698