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 |