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

Side by Side Diff: shell/android/mojo_main.cc

Issue 816473002: Update mojo shell so that --args-for can be used on android (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Remove spurious print Created 6 years 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "shell/android/mojo_main.h" 5 #include "shell/android/mojo_main.h"
6 6
7 #include "base/android/command_line_android.h"
8 #include "base/android/java_handler_thread.h" 7 #include "base/android/java_handler_thread.h"
9 #include "base/android/jni_android.h" 8 #include "base/android/jni_android.h"
9 #include "base/android/jni_array.h"
10 #include "base/android/jni_string.h" 10 #include "base/android/jni_string.h"
11 #include "base/at_exit.h" 11 #include "base/at_exit.h"
12 #include "base/bind.h" 12 #include "base/bind.h"
13 #include "base/command_line.h" 13 #include "base/command_line.h"
14 #include "base/files/file_path.h" 14 #include "base/files/file_path.h"
15 #include "base/lazy_instance.h" 15 #include "base/lazy_instance.h"
16 #include "base/logging.h" 16 #include "base/logging.h"
17 #include "base/macros.h" 17 #include "base/macros.h"
18 #include "base/message_loop/message_loop.h" 18 #include "base/message_loop/message_loop.h"
19 #include "jni/MojoMain_jni.h" 19 #include "jni/MojoMain_jni.h"
20 #include "mojo/application_manager/application_loader.h" 20 #include "mojo/application_manager/application_loader.h"
21 #include "mojo/application_manager/application_manager.h" 21 #include "mojo/application_manager/application_manager.h"
22 #include "mojo/application_manager/background_shell_application_loader.h" 22 #include "mojo/application_manager/background_shell_application_loader.h"
23 #include "services/gles2/gpu_impl.h" 23 #include "services/gles2/gpu_impl.h"
24 #include "services/native_viewport/native_viewport_impl.h" 24 #include "services/native_viewport/native_viewport_impl.h"
25 #include "shell/android/android_handler_loader.h" 25 #include "shell/android/android_handler_loader.h"
26 #include "shell/android/ui_application_loader_android.h" 26 #include "shell/android/ui_application_loader_android.h"
27 #include "shell/command_line_util.h"
27 #include "shell/context.h" 28 #include "shell/context.h"
28 #include "shell/init.h" 29 #include "shell/init.h"
29 #include "ui/gl/gl_surface_egl.h" 30 #include "ui/gl/gl_surface_egl.h"
30 31
31 using base::LazyInstance; 32 using base::LazyInstance;
32 33
33 namespace mojo { 34 namespace mojo {
34 namespace shell { 35 namespace shell {
35 36
36 namespace { 37 namespace {
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
100 // Android handler is bundled with the Mojo shell, because it uses the 101 // Android handler is bundled with the Mojo shell, because it uses the
101 // MojoShell application as the JNI bridge to bootstrap execution of other 102 // MojoShell application as the JNI bridge to bootstrap execution of other
102 // Android Mojo apps that need JNI. 103 // Android Mojo apps that need JNI.
103 context->application_manager()->SetLoaderForURL( 104 context->application_manager()->SetLoaderForURL(
104 make_scoped_ptr(new BackgroundShellApplicationLoader( 105 make_scoped_ptr(new BackgroundShellApplicationLoader(
105 make_scoped_ptr(new AndroidHandlerLoader()), "android_handler", 106 make_scoped_ptr(new AndroidHandlerLoader()), "android_handler",
106 base::MessageLoop::TYPE_DEFAULT)), 107 base::MessageLoop::TYPE_DEFAULT)),
107 GURL("mojo:android_handler")); 108 GURL("mojo:android_handler"));
108 } 109 }
109 110
110 void RunShell(std::vector<GURL> app_urls) { 111 void StartShellOnShellThread() {
111 Context* context = g_context.Pointer()->get(); 112 Context* context = g_context.Pointer()->get();
112 ConfigureAndroidServices(context); 113 ConfigureAndroidServices(context);
113 context->Init(); 114 context->Init();
114 for (std::vector<GURL>::const_iterator it = app_urls.begin(); 115 RunCommandLineApps(context);
115 it != app_urls.end(); ++it) {
116 context->Run(*it);
117 }
118 } 116 }
119 117
120 } // namespace 118 } // namespace
121 119
122 static void Init(JNIEnv* env, 120 static void Init(JNIEnv* env,
123 jclass clazz, 121 jclass clazz,
124 jobject context, 122 jobject context,
125 jstring mojo_shell_path, 123 jstring mojo_shell_path,
126 jobjectArray jparameters, 124 jobjectArray jparameters,
127 jstring j_local_apps_directory) { 125 jstring j_local_apps_directory) {
128 base::android::ScopedJavaLocalRef<jobject> scoped_context(env, context); 126 base::android::ScopedJavaLocalRef<jobject> scoped_context(env, context);
129 base::android::InitApplicationContext(env, scoped_context); 127 base::android::InitApplicationContext(env, scoped_context);
130 128
131 base::android::InitNativeCommandLineFromJavaArray(env, jparameters); 129 std::vector<std::string> parameters;
132 base::FilePath mojo_shell_file_path( 130 parameters.push_back(
133 base::android::ConvertJavaStringToUTF8(env, mojo_shell_path)); 131 base::android::ConvertJavaStringToUTF8(env, mojo_shell_path));
134 base::CommandLine::ForCurrentProcess()->SetProgram(mojo_shell_file_path); 132 base::android::AppendJavaStringArrayToStringVector(env, jparameters,
133 &parameters);
134 CommandLine::Init(0, nullptr);
135 base::CommandLine::ForCurrentProcess()->InitFromArgv(parameters);
136
135 InitializeLogging(); 137 InitializeLogging();
136 138
137 // We want ~MessageLoop to happen prior to ~Context. Initializing 139 // We want ~MessageLoop to happen prior to ~Context. Initializing
138 // LazyInstances is akin to stack-allocating objects; their destructors 140 // LazyInstances is akin to stack-allocating objects; their destructors
139 // will be invoked first-in-last-out. 141 // will be invoked first-in-last-out.
140 Context* shell_context = new Context(); 142 Context* shell_context = new Context();
141 shell_context->mojo_url_resolver()->SetLocalAppsPath(base::FilePath( 143 shell_context->mojo_url_resolver()->SetLocalAppsPath(base::FilePath(
142 base::android::ConvertJavaStringToUTF8(env, j_local_apps_directory))); 144 base::android::ConvertJavaStringToUTF8(env, j_local_apps_directory)));
145 for (auto& args : parameters) {
146 ApplyApplicationArgs(shell_context, args);
147 }
148
143 g_context.Get().reset(shell_context); 149 g_context.Get().reset(shell_context);
144 150
145 g_java_message_loop.Get().reset(new base::MessageLoopForUI); 151 g_java_message_loop.Get().reset(new base::MessageLoopForUI);
146 base::MessageLoopForUI::current()->Start(); 152 base::MessageLoopForUI::current()->Start();
147 153
148 // TODO(abarth): At which point should we switch to cross-platform 154 // TODO(abarth): At which point should we switch to cross-platform
149 // initialization? 155 // initialization?
150 156
151 gfx::GLSurface::InitializeOneOff(); 157 gfx::GLSurface::InitializeOneOff();
152 } 158 }
153 159
154 static void Start(JNIEnv* env, jclass clazz, jstring jurl) { 160 static jboolean Start(JNIEnv* env, jclass clazz) {
155 std::vector<GURL> app_urls; 161 if (!base::CommandLine::ForCurrentProcess()->GetArgs().size()) {
sky 2014/12/17 16:44:04 nit: no {}
qsr 2014/12/18 14:21:35 Done.
162 return false;
163 }
164
156 #if defined(MOJO_SHELL_DEBUG_URL) 165 #if defined(MOJO_SHELL_DEBUG_URL)
157 app_urls.push_back(GURL(MOJO_SHELL_DEBUG_URL)); 166 base::CommandLine::ForCurrentProcess()->AppendArg(MOJO_SHELL_DEBUG_URL);
158 // Sleep for 5 seconds to give the debugger a chance to attach. 167 // Sleep for 5 seconds to give the debugger a chance to attach.
159 sleep(5); 168 sleep(5);
160 #else
161 if (jurl)
162 app_urls.push_back(GURL(base::android::ConvertJavaStringToUTF8(env, jurl)));
163 #endif 169 #endif
164 170
165 g_shell_thread.Get().reset( 171 g_shell_thread.Get().reset(
166 new base::android::JavaHandlerThread("shell_thread")); 172 new base::android::JavaHandlerThread("shell_thread"));
167 g_shell_thread.Get()->Start(); 173 g_shell_thread.Get()->Start();
168 g_shell_thread.Get()->message_loop()->PostTask( 174 g_shell_thread.Get()->message_loop()->PostTask(
169 FROM_HERE, base::Bind(&RunShell, app_urls)); 175 FROM_HERE, base::Bind(&StartShellOnShellThread));
176 return true;
177 }
178
179 static void AddApplicationURL(JNIEnv* env, jclass clazz, jstring jurl) {
180 base::CommandLine::ForCurrentProcess()->AppendArg(
181 base::android::ConvertJavaStringToUTF8(env, jurl));
170 } 182 }
171 183
172 bool RegisterMojoMain(JNIEnv* env) { 184 bool RegisterMojoMain(JNIEnv* env) {
173 return RegisterNativesImpl(env); 185 return RegisterNativesImpl(env);
174 } 186 }
175 187
176 } // namespace shell 188 } // namespace shell
177 } // namespace mojo 189 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698