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 #include "content/browser/android/content_view_core_impl.h" | 5 #include "content/browser/android/content_view_core_impl.h" |
6 | 6 |
7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
8 #include "base/android/jni_array.h" | 8 #include "base/android/jni_array.h" |
9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
(...skipping 230 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
241 // Currently, the only use case we have for overriding a user agent involves | 241 // Currently, the only use case we have for overriding a user agent involves |
242 // spoofing a desktop Linux user agent for "Request desktop site". | 242 // spoofing a desktop Linux user agent for "Request desktop site". |
243 // Automatically set it for all WebContents so that it is available when a | 243 // Automatically set it for all WebContents so that it is available when a |
244 // NavigationEntry requires the user agent to be overridden. | 244 // NavigationEntry requires the user agent to be overridden. |
245 const char kLinuxInfoStr[] = "X11; Linux x86_64"; | 245 const char kLinuxInfoStr[] = "X11; Linux x86_64"; |
246 std::string product = content::GetContentClient()->GetProduct(); | 246 std::string product = content::GetContentClient()->GetProduct(); |
247 std::string spoofed_ua = | 247 std::string spoofed_ua = |
248 BuildUserAgentFromOSAndProduct(kLinuxInfoStr, product); | 248 BuildUserAgentFromOSAndProduct(kLinuxInfoStr, product); |
249 web_contents->SetUserAgentOverride(spoofed_ua); | 249 web_contents->SetUserAgentOverride(spoofed_ua); |
250 | 250 |
251 java_bridge_dispatcher_host_.reset( | 251 java_bridge_dispatcher_host_ = |
252 new GinJavaBridgeDispatcherHost(web_contents, | 252 new GinJavaBridgeDispatcherHost(web_contents, |
253 java_bridge_retained_object_set)); | 253 java_bridge_retained_object_set); |
254 | 254 |
255 InitWebContents(); | 255 InitWebContents(); |
256 } | 256 } |
257 | 257 |
258 ContentViewCoreImpl::~ContentViewCoreImpl() { | 258 ContentViewCoreImpl::~ContentViewCoreImpl() { |
259 JNIEnv* env = base::android::AttachCurrentThread(); | 259 JNIEnv* env = base::android::AttachCurrentThread(); |
260 ScopedJavaLocalRef<jobject> j_obj = java_ref_.get(env); | 260 ScopedJavaLocalRef<jobject> j_obj = java_ref_.get(env); |
261 java_ref_.reset(); | 261 java_ref_.reset(); |
262 if (!j_obj.is_null()) { | 262 if (!j_obj.is_null()) { |
263 Java_ContentViewCore_onNativeContentViewCoreDestroyed( | 263 Java_ContentViewCore_onNativeContentViewCoreDestroyed( |
(...skipping 1083 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1347 reinterpret_cast<ui::WindowAndroid*>(window_android), | 1347 reinterpret_cast<ui::WindowAndroid*>(window_android), |
1348 retained_objects_set); | 1348 retained_objects_set); |
1349 return reinterpret_cast<intptr_t>(view); | 1349 return reinterpret_cast<intptr_t>(view); |
1350 } | 1350 } |
1351 | 1351 |
1352 bool RegisterContentViewCore(JNIEnv* env) { | 1352 bool RegisterContentViewCore(JNIEnv* env) { |
1353 return RegisterNativesImpl(env); | 1353 return RegisterNativesImpl(env); |
1354 } | 1354 } |
1355 | 1355 |
1356 } // namespace content | 1356 } // namespace content |
OLD | NEW |