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 <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
222 } | 222 } |
223 return base::android::ScopedJavaLocalRef<jstring>(env, NULL); | 223 return base::android::ScopedJavaLocalRef<jstring>(env, NULL); |
224 } | 224 } |
225 | 225 |
226 base::android::ScopedJavaLocalRef<jstring> | 226 base::android::ScopedJavaLocalRef<jstring> |
227 TemplateUrlServiceAndroid::GetUrlForContextualSearchQuery( | 227 TemplateUrlServiceAndroid::GetUrlForContextualSearchQuery( |
228 JNIEnv* env, | 228 JNIEnv* env, |
229 const JavaParamRef<jobject>& obj, | 229 const JavaParamRef<jobject>& obj, |
230 const JavaParamRef<jstring>& jquery, | 230 const JavaParamRef<jstring>& jquery, |
231 const JavaParamRef<jstring>& jalternate_term, | 231 const JavaParamRef<jstring>& jalternate_term, |
232 jboolean jshould_prefetch) { | 232 jboolean jshould_prefetch, |
| 233 const JavaParamRef<jstring>& jprotocol_version) { |
233 base::string16 query(base::android::ConvertJavaStringToUTF16(env, jquery)); | 234 base::string16 query(base::android::ConvertJavaStringToUTF16(env, jquery)); |
234 std::string url; | 235 std::string url; |
235 | 236 |
236 if (!query.empty()) { | 237 if (!query.empty()) { |
237 GURL gurl(GetDefaultSearchURLForSearchTerms(template_url_service_, query)); | 238 GURL gurl(GetDefaultSearchURLForSearchTerms(template_url_service_, query)); |
238 if (google_util::IsGoogleSearchUrl(gurl)) { | 239 if (google_util::IsGoogleSearchUrl(gurl)) { |
239 gurl = net::AppendQueryParameter(gurl, "ctxs", "2"); | 240 std::string protocol_version( |
| 241 base::android::ConvertJavaStringToUTF8(env, jprotocol_version)); |
| 242 gurl = net::AppendQueryParameter(gurl, "ctxs", protocol_version); |
240 if (jshould_prefetch) { | 243 if (jshould_prefetch) { |
241 // Indicate that the search page is being prefetched. | 244 // Indicate that the search page is being prefetched. |
242 gurl = net::AppendQueryParameter(gurl, "pf", "c"); | 245 gurl = net::AppendQueryParameter(gurl, "pf", "c"); |
243 } | 246 } |
244 | 247 |
245 if (jalternate_term) { | 248 if (jalternate_term) { |
246 std::string alternate_term( | 249 std::string alternate_term( |
247 base::android::ConvertJavaStringToUTF8(env, jalternate_term)); | 250 base::android::ConvertJavaStringToUTF8(env, jalternate_term)); |
248 if (!alternate_term.empty()) { | 251 if (!alternate_term.empty()) { |
249 gurl = net::AppendQueryParameter( | 252 gurl = net::AppendQueryParameter( |
(...skipping 22 matching lines...) Expand all Loading... |
272 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 275 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
273 TemplateUrlServiceAndroid* template_url_service_android = | 276 TemplateUrlServiceAndroid* template_url_service_android = |
274 new TemplateUrlServiceAndroid(env, obj); | 277 new TemplateUrlServiceAndroid(env, obj); |
275 return reinterpret_cast<intptr_t>(template_url_service_android); | 278 return reinterpret_cast<intptr_t>(template_url_service_android); |
276 } | 279 } |
277 | 280 |
278 // static | 281 // static |
279 bool TemplateUrlServiceAndroid::Register(JNIEnv* env) { | 282 bool TemplateUrlServiceAndroid::Register(JNIEnv* env) { |
280 return RegisterNativesImpl(env); | 283 return RegisterNativesImpl(env); |
281 } | 284 } |
OLD | NEW |