Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: content/shell/android/shell_library_loader.cc

Issue 10444121: Added android_browser_process. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Init Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 "base/basictypes.h" 5 #include "base/basictypes.h"
6 #include "base/debug/debugger.h" 6 #include "base/debug/debugger.h"
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/android/jni_android.h" 8 #include "base/android/jni_android.h"
9 #include "base/android/jni_registrar.h" 9 #include "base/android/jni_registrar.h"
10 #include "content/common/android/process_main.h"
Yaron 2012/06/01 20:20:37 Does this have to in public because you're referen
jam 2012/06/01 22:04:55 exactly, you'll get a checkdeps failure in the try
michaelbai 2012/06/01 23:27:20 Done.
10 #include "content/public/app/android_library_loader_hooks.h" 11 #include "content/public/app/android_library_loader_hooks.h"
11 #include "content/public/app/content_main_runner.h"
12 #include "content/shell/shell_main_delegate.h"
13 #include "content/shell/android/shell_manager.h" 12 #include "content/shell/android/shell_manager.h"
14 #include "content/shell/android/shell_view.h" 13 #include "content/shell/android/shell_view.h"
14 #include "content/shell/shell_main_delegate.h"
15 15
16 static base::android::RegistrationMethod kRegistrationMethods[] = { 16 static base::android::RegistrationMethod kRegistrationMethods[] = {
17 { "ShellManager", content::RegisterShellManager }, 17 { "ShellManager", content::RegisterShellManager },
18 { "ShellView", content::ShellView::Register }, 18 { "ShellView", content::ShellView::Register },
19 }; 19 };
20 20
21 namespace {
22 content::ContentMainRunner* g_content_main_runner = NULL;
23 }
24
25 // This is called by the VM when the shared library is first loaded. 21 // This is called by the VM when the shared library is first loaded.
26 JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) { 22 JNI_EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) {
27
28 // Don't call anything in base without initializing it.
29 // ContentMainRunner will do what we need.
30 g_content_main_runner = content::ContentMainRunner::Create();
31
32 // TODO(tedchoc): Set this to the main delegate once the Android specific
33 // browser process initialization gets checked in.
34 ShellMainDelegate* delegate = new ShellMainDelegate();
35
36 // TODO(jrg): find command line info from java; pass down in here.
37 g_content_main_runner->Initialize(0, NULL, delegate);
38
39 base::android::InitVM(vm); 23 base::android::InitVM(vm);
40 JNIEnv* env = base::android::AttachCurrentThread(); 24 JNIEnv* env = base::android::AttachCurrentThread();
41 if (!content::RegisterLibraryLoaderEntryHook(env)) { 25 if (!content::RegisterLibraryLoaderEntryHook(env)) {
42 return -1; 26 return -1;
43 } 27 }
44 28
45 // To be called only from the UI thread. If loading the library is done on 29 // To be called only from the UI thread. If loading the library is done on
46 // a separate thread, this should be moved elsewhere. 30 // a separate thread, this should be moved elsewhere.
47 if (!base::android::RegisterNativeMethods(env, kRegistrationMethods, 31 if (!base::android::RegisterNativeMethods(env, kRegistrationMethods,
48 arraysize(kRegistrationMethods))) 32 arraysize(kRegistrationMethods)))
49 return -1; 33 return -1;
50 34
35 content::g_content_main_delegate = new ShellMainDelegate();
36
51 return JNI_VERSION_1_4; 37 return JNI_VERSION_1_4;
52 } 38 }
53 39
54 40
55 JNI_EXPORT void JNI_OnUnload(JavaVM* vm, void* reserved) { 41 JNI_EXPORT void JNI_OnUnload(JavaVM* vm, void* reserved) {
56 delete g_content_main_runner; 42 if (content::g_content_main_delegate)
57 g_content_main_runner = NULL; 43 delete content::g_content_main_delegate;
44 content::g_content_main_delegate = NULL;
58 } 45 }
59
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698