Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "chrome/browser/search_engines/template_url_service_android.h" | 5 #include "chrome/browser/search_engines/template_url_service_android.h" |
| 6 | 6 |
| 7 #include "base/android/jni_string.h" | 7 #include "base/android/jni_string.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/format_macros.h" | 9 #include "base/format_macros.h" |
| 10 #include "base/strings/stringprintf.h" | 10 #include "base/strings/stringprintf.h" |
| 11 #include "base/strings/utf_string_conversions.h" | 11 #include "base/strings/utf_string_conversions.h" |
| 12 #include "chrome/browser/profiles/profile_manager.h" | 12 #include "chrome/browser/profiles/profile_manager.h" |
| 13 #include "chrome/browser/search_engines/template_url_service_factory.h" | 13 #include "chrome/browser/search_engines/template_url_service_factory.h" |
| 14 #include "components/google/core/browser/google_util.h" | 14 #include "components/google/core/browser/google_util.h" |
| 15 #include "components/search_engines/template_url.h" | 15 #include "components/search_engines/template_url.h" |
| 16 #include "components/search_engines/template_url_prepopulate_data.h" | 16 #include "components/search_engines/template_url_prepopulate_data.h" |
| 17 #include "components/search_engines/template_url_service.h" | 17 #include "components/search_engines/template_url_service.h" |
| 18 #include "components/search_engines/util.h" | 18 #include "components/search_engines/util.h" |
| 19 #include "jni/TemplateUrlService_jni.h" | 19 #include "jni/TemplateUrlService_jni.h" |
| 20 #include "net/base/url_util.h" | 20 #include "net/base/url_util.h" |
| 21 | 21 |
| 22 using base::android::ConvertJavaStringToUTF16; | 22 using base::android::ConvertJavaStringToUTF16; |
| 23 using base::android::ConvertJavaStringToUTF8; | |
| 23 using base::android::ConvertUTF16ToJavaString; | 24 using base::android::ConvertUTF16ToJavaString; |
| 24 using base::android::ConvertUTF8ToJavaString; | 25 using base::android::ConvertUTF8ToJavaString; |
|
Peter Kasting
2014/08/13 02:04:16
Nit: Avoid using statements unless they significan
jeremycho
2014/08/13 20:29:27
Done.
| |
| 25 | 26 |
| 26 namespace { | 27 namespace { |
| 27 | 28 |
| 28 Profile* GetOriginalProfile() { | 29 Profile* GetOriginalProfile() { |
| 29 return ProfileManager::GetActiveUserProfile()->GetOriginalProfile(); | 30 return ProfileManager::GetActiveUserProfile()->GetOriginalProfile(); |
| 30 } | 31 } |
| 31 | 32 |
| 32 } // namespace | 33 } // namespace |
| 33 | 34 |
| 34 TemplateUrlServiceAndroid::TemplateUrlServiceAndroid(JNIEnv* env, | 35 TemplateUrlServiceAndroid::TemplateUrlServiceAndroid(JNIEnv* env, |
| (...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 197 if (refined_query) | 198 if (refined_query) |
| 198 return ConvertUTF8ToJavaString(env, destination_url.spec()); | 199 return ConvertUTF8ToJavaString(env, destination_url.spec()); |
| 199 } | 200 } |
| 200 return base::android::ScopedJavaLocalRef<jstring>(env, NULL); | 201 return base::android::ScopedJavaLocalRef<jstring>(env, NULL); |
| 201 } | 202 } |
| 202 | 203 |
| 203 base::android::ScopedJavaLocalRef<jstring> | 204 base::android::ScopedJavaLocalRef<jstring> |
| 204 TemplateUrlServiceAndroid::GetUrlForContextualSearchQuery(JNIEnv* env, | 205 TemplateUrlServiceAndroid::GetUrlForContextualSearchQuery(JNIEnv* env, |
| 205 jobject obj, | 206 jobject obj, |
| 206 jstring jquery) { | 207 jstring jquery) { |
| 208 return GetUrlForContextualSearchQuery(env, obj, jquery, NULL); | |
| 209 } | |
| 210 | |
| 211 base::android::ScopedJavaLocalRef<jstring> | |
| 212 TemplateUrlServiceAndroid::GetUrlForContextualSearchQuery( | |
| 213 JNIEnv* env, jobject obj, jstring jquery, jstring jalternate_term) { | |
|
Peter Kasting
2014/08/13 02:04:16
Nit: One arg per line
jeremycho
2014/08/13 20:29:27
Done.
| |
| 207 base::string16 query(ConvertJavaStringToUTF16(env, jquery)); | 214 base::string16 query(ConvertJavaStringToUTF16(env, jquery)); |
| 208 std::string url; | 215 std::string url; |
| 209 | 216 |
| 210 if (!query.empty()) { | 217 if (!query.empty()) { |
| 211 GURL gurl(GetDefaultSearchURLForSearchTerms(template_url_service_, query)); | 218 GURL gurl(GetDefaultSearchURLForSearchTerms(template_url_service_, query)); |
| 212 if (google_util::IsGoogleSearchUrl(gurl)) { | 219 if (google_util::IsGoogleSearchUrl(gurl)) { |
| 213 gurl = net::AppendQueryParameter(gurl, "ctxs", "1"); | 220 gurl = net::AppendQueryParameter(gurl, "ctxs", "2"); |
| 214 // Indicate that the search page is being prefetched. | 221 // Indicate that the search page is being prefetched. |
| 215 gurl = net::AppendQueryParameter(gurl, "pf", "c"); | 222 gurl = net::AppendQueryParameter(gurl, "pf", "c"); |
| 223 | |
| 224 if (jalternate_term) { | |
| 225 std::string alternate_term( | |
| 226 ConvertJavaStringToUTF8(env, jalternate_term)); | |
|
Peter Kasting
2014/08/13 02:04:15
Nit: Is it safe to run this if !jalternate_term?
jeremycho
2014/08/13 20:29:27
A null is being passed from Java, so I think havin
| |
| 227 if (!alternate_term.empty()) { | |
| 228 gurl = net::AppendQueryParameter( | |
| 229 gurl, "ctxsl_alternate_term", alternate_term); | |
| 230 } | |
| 231 } | |
| 216 } | 232 } |
| 217 url = gurl.spec(); | 233 url = gurl.spec(); |
| 218 } | 234 } |
| 219 | 235 |
| 220 return ConvertUTF8ToJavaString(env, url); | 236 return ConvertUTF8ToJavaString(env, url); |
| 221 } | 237 } |
| 222 | 238 |
| 223 static jlong Init(JNIEnv* env, jobject obj) { | 239 static jlong Init(JNIEnv* env, jobject obj) { |
| 224 TemplateUrlServiceAndroid* template_url_service_android = | 240 TemplateUrlServiceAndroid* template_url_service_android = |
| 225 new TemplateUrlServiceAndroid(env, obj); | 241 new TemplateUrlServiceAndroid(env, obj); |
| 226 return reinterpret_cast<intptr_t>(template_url_service_android); | 242 return reinterpret_cast<intptr_t>(template_url_service_android); |
| 227 } | 243 } |
| 228 | 244 |
| 229 // static | 245 // static |
| 230 bool TemplateUrlServiceAndroid::Register(JNIEnv* env) { | 246 bool TemplateUrlServiceAndroid::Register(JNIEnv* env) { |
| 231 return RegisterNativesImpl(env); | 247 return RegisterNativesImpl(env); |
| 232 } | 248 } |
| OLD | NEW |