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

Unified Diff: ios/chrome/browser/chrome_url_util.mm

Issue 1139383002: [iOS] Upstream URL utilities (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 7 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/chrome_url_util.mm
diff --git a/ios/chrome/browser/chrome_url_util.mm b/ios/chrome/browser/chrome_url_util.mm
new file mode 100644
index 0000000000000000000000000000000000000000..0c1a92b761c14fc9b96a3e8fb95bdad45d644b38
--- /dev/null
+++ b/ios/chrome/browser/chrome_url_util.mm
@@ -0,0 +1,99 @@
+// Copyright 2012 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.
+
+#import "ios/chrome/browser/chrome_url_util.h"
+
+#import <UIKit/UIKit.h>
+
+#include "base/logging.h"
+#include "base/mac/scoped_nsobject.h"
+#include "base/strings/string_util.h"
+#include "base/strings/sys_string_conversions.h"
+#include "ios/chrome/browser/chrome_url_constants.h"
+#import "ios/net/url_scheme_util.h"
+#include "ios/public/provider/chrome/browser/chrome_browser_provider.h"
+#include "url/gurl.h"
+
+bool UrlIsExternalFileReference(const GURL& url) {
+ return url.SchemeIs(ios::GetChromeBrowserProvider()->GetChromeUIScheme()) &&
+ LowerCaseEqualsASCII(url.host(), kChromeUIExternalFileHost);
+}
+
+NSURL* UrlToLaunchChrome() {
+ // Determines the target URL scheme that will launch Chrome.
+ NSString* scheme = [[ChromeAppConstants sharedInstance] getBundleURLScheme];
+ return [NSURL URLWithString:[NSString stringWithFormat:@"%@://", scheme]];
+}
+
+NSURL* UrlOfChromeAppIcon(int width, int height) {
+ NSString* url =
+ [[ChromeAppConstants sharedInstance] getChromeAppIconURLOfWidth:width
+ height:height];
+ return [NSURL URLWithString:url];
+}
+
+bool UrlHasChromeScheme(const GURL& url) {
+ return url.SchemeIs(ios::GetChromeBrowserProvider()->GetChromeUIScheme());
+}
+
+bool UrlHasChromeScheme(NSURL* url) {
+ return net::UrlSchemeIs(
+ url, base::SysUTF8ToNSString(
+ ios::GetChromeBrowserProvider()->GetChromeUIScheme()));
+}
+
+@implementation ChromeAppConstants {
+ base::scoped_nsobject<NSString> callbackScheme_;
+ base::scoped_nsprotocol<AppIconURLProvider> appIconURLProvider_;
rohitrao (ping after 24h) 2015/05/18 13:34:56 Want to switch to leading underscores for these va
sdefresne 2015/05/18 14:19:54 Done and changed the block to use base::mac::Scope
+}
+
++ (ChromeAppConstants*)sharedInstance {
+ static ChromeAppConstants* g_instance = [[ChromeAppConstants alloc] init];
+ return g_instance;
+}
+
+- (NSString*)getBundleURLScheme {
+ if (!callbackScheme_) {
+ NSSet* allowableSchemes =
+ [NSSet setWithObjects:@"googlechrome", @"chromium", nil];
+ NSDictionary* info = [[NSBundle mainBundle] infoDictionary];
+ NSArray* urlTypes = [info objectForKey:@"CFBundleURLTypes"];
+ for (NSDictionary* urlType in urlTypes) {
+ DCHECK([urlType isKindOfClass:[NSDictionary class]]);
+ NSArray* schemes = [urlType objectForKey:@"CFBundleURLSchemes"];
+ if (!schemes)
+ continue;
+ DCHECK([schemes isKindOfClass:[NSArray class]]);
+ for (NSString* scheme in schemes) {
+ if ([allowableSchemes containsObject:scheme])
+ callbackScheme_.reset([scheme copy]);
+ }
+ }
+ }
+ DCHECK([callbackScheme_ length]);
+ return callbackScheme_;
+}
+
+- (NSString*)getChromeAppIconURLOfWidth:(int)width height:(int)height {
+ if (!appIconURLProvider_) {
+ appIconURLProvider_.reset([^(int width, int height) {
+ return [NSString
+ stringWithFormat:@"https://%@/Icon-%dx%d-%dx.png",
+ @"ssl.gstatic.com/ios-apps/com.google.chrome.ios",
rohitrao (ping after 24h) 2015/05/18 13:34:56 We should consider debranding this.
sdefresne 2015/05/18 14:19:54 Added a TODO.
+ width, height,
+ [[UIScreen mainScreen] scale] == 1.0 ? 1 : 2];
+ } copy]);
+ }
+ return appIconURLProvider_.get()(width, height);
+}
+
+- (void)setCallbackSchemeForTesting:(NSString*)scheme {
+ callbackScheme_.reset([scheme copy]);
+}
+
+- (void)setAppIconURLProviderForTesting:(AppIconURLProvider)block {
+ appIconURLProvider_.reset([block copy]);
+}
+
+@end

Powered by Google App Engine
This is Rietveld 408576698