| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "android_webview/lib/main/webview_jni_onload.h" | 5 #include "android_webview/lib/main/webview_jni_onload.h" |
| 6 #include "base/android/jni_android.h" | 6 #include "base/android/jni_android.h" |
| 7 #include "base/bind.h" | 7 #include "base/android/library_loader/library_loader_hooks.h" |
| 8 #include "content/public/app/content_jni_onload.h" | |
| 9 | 8 |
| 10 // This is called by the VM when the shared library is first loaded. | 9 // This is called by the VM when the shared library is first loaded. |
| 11 // Most of the initialization is done in LibraryLoadedOnMainThread(), not here. | 10 // Most of the initialization is done in LibraryLoadedOnMainThread(), not here. |
| 12 JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) { | 11 JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) { |
| 13 // WebView uses native JNI exports; disable manual JNI registration to | 12 // WebView uses native JNI exports; disable manual JNI registration because |
| 14 // improve startup peformance. | 13 // we don't have a good way to detect the JNI registrations which is called, |
| 14 // outside of OnJNIOnLoadRegisterJNI code path. |
| 15 base::android::DisableManualJniRegistration(); | 15 base::android::DisableManualJniRegistration(); |
| 16 | 16 |
| 17 std::vector<base::android::RegisterCallback> register_callbacks; | 17 if (base::android::IsManualJniRegistrationDisabled()) { |
| 18 register_callbacks.push_back(base::Bind(&android_webview::RegisterJNI)); | 18 base::android::InitVM(vm); |
| 19 std::vector<base::android::InitCallback> init_callbacks; | 19 base::android::InitAtExitManager(); |
| 20 init_callbacks.push_back(base::Bind(&android_webview::Init)); | 20 } else { |
| 21 if (!content::android::OnJNIOnLoadRegisterJNI(vm, register_callbacks) || | 21 if (android_webview::OnJNIOnLoadRegisterJNI(vm)) |
| 22 !content::android::OnJNIOnLoadInit(init_callbacks)) { | 22 return -1; |
| 23 } |
| 24 |
| 25 if (!android_webview::OnJNIOnLoadInit()) { |
| 23 return -1; | 26 return -1; |
| 24 } | 27 } |
| 25 return JNI_VERSION_1_4; | 28 return JNI_VERSION_1_4; |
| 26 } | 29 } |
| OLD | NEW |