| Index: content/shell/android/shell_library_loader.cc
|
| diff --git a/content/shell/android/shell_library_loader.cc b/content/shell/android/shell_library_loader.cc
|
| index 142d9efcd45c4d574fd1d96d8edba0c94ed9937f..6d80fc3a85cb97b2c09843d0b28f48cdb091ecf9 100644
|
| --- a/content/shell/android/shell_library_loader.cc
|
| +++ b/content/shell/android/shell_library_loader.cc
|
| @@ -3,34 +3,39 @@
|
| // found in the LICENSE file.
|
|
|
| #include "base/android/jni_android.h"
|
| -#include "base/android/jni_registrar.h"
|
| -#include "base/android/library_loader/library_loader_hooks.h"
|
| -#include "base/basictypes.h"
|
| -#include "base/debug/debugger.h"
|
| -#include "base/logging.h"
|
| -#include "content/public/app/android_library_loader_hooks.h"
|
| +#include "base/android/jni_onload_delegate.h"
|
| +#include "content/public/app/content_jni_onload.h"
|
| #include "content/public/app/content_main.h"
|
| #include "content/public/browser/android/compositor.h"
|
| #include "content/shell/android/shell_jni_registrar.h"
|
| #include "content/shell/app/shell_main_delegate.h"
|
|
|
| -// This is called by the VM when the shared library is first loaded.
|
| -JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) {
|
| +namespace {
|
|
|
| - base::android::SetLibraryLoadedHook(&content::LibraryLoaded);
|
| +class ShellJNIOnLoadDelegate : public base::android::JNIOnLoadDelegate {
|
| + public:
|
| + bool RegisterJNI(JNIEnv* env) override;
|
| + bool Init() override;
|
| +};
|
|
|
| - base::android::InitVM(vm);
|
| - JNIEnv* env = base::android::AttachCurrentThread();
|
| +bool ShellJNIOnLoadDelegate::RegisterJNI(JNIEnv* env) {
|
| + return content::android::RegisterShellJni(env);
|
| +}
|
|
|
| - if (!base::android::RegisterLibraryLoaderEntryHook(env))
|
| - return -1;
|
| +bool ShellJNIOnLoadDelegate::Init() {
|
| + content::Compositor::Initialize();
|
| + content::SetContentMainDelegate(new content::ShellMainDelegate());
|
| + return true;
|
| +}
|
|
|
| - // To be called only from the UI thread. If loading the library is done on
|
| - // a separate thread, this should be moved elsewhere.
|
| - if (!content::android::RegisterShellJni(env))
|
| +} // namespace
|
| +
|
| +
|
| +// This is called by the VM when the shared library is first loaded.
|
| +JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) {
|
| + ShellJNIOnLoadDelegate delegate;
|
| + if (!content::android::OnJNIOnLoad(vm, &delegate))
|
| return -1;
|
|
|
| - content::Compositor::Initialize();
|
| - content::SetContentMainDelegate(new content::ShellMainDelegate());
|
| return JNI_VERSION_1_4;
|
| }
|
|
|