summaryrefslogtreecommitdiffstats
path: root/mojo/runner
diff options
context:
space:
mode:
Diffstat (limited to 'mojo/runner')
-rw-r--r--mojo/runner/android/main.cc3
-rw-r--r--mojo/runner/context.cc15
-rw-r--r--mojo/runner/context.h3
-rw-r--r--mojo/runner/desktop/launcher_process.cc21
4 files changed, 22 insertions, 20 deletions
diff --git a/mojo/runner/android/main.cc b/mojo/runner/android/main.cc
index dbe65e1..7236763 100644
--- a/mojo/runner/android/main.cc
+++ b/mojo/runner/android/main.cc
@@ -99,8 +99,7 @@ void MojoShellRunner::Run() {
Context* context = g_context.Pointer()->get();
ConfigureAndroidServices(context);
context->Init();
-
- context->Run(GURL("mojo:window_manager"));
+ context->RunCommandLineApplication();
loop.Run();
g_java_message_loop.Pointer()->get()->PostTask(FROM_HERE,
diff --git a/mojo/runner/context.cc b/mojo/runner/context.cc
index adccbfa..d9aee2e 100644
--- a/mojo/runner/context.cc
+++ b/mojo/runner/context.cc
@@ -318,6 +318,21 @@ void Context::Run(const GURL& url) {
base::Bind(&Context::OnApplicationEnd, base::Unretained(this), url));
}
+void Context::RunCommandLineApplication() {
+ // If an app isn't specified (i.e. for an apptest), run the window manager.
+ GURL app_url("mojo:window_manager");
+ base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();
+ base::CommandLine::StringVector args = command_line->GetArgs();
+ for (size_t i = 0; i < args.size(); ++i) {
+ GURL possible_app(args[i]);
+ if (possible_app.SchemeIs("mojo")) {
+ app_url = possible_app;
+ break;
+ }
+ }
+ Run(app_url);
+}
+
void Context::OnApplicationEnd(const GURL& url) {
if (app_urls_.find(url) != app_urls_.end()) {
app_urls_.erase(url);
diff --git a/mojo/runner/context.h b/mojo/runner/context.h
index 1dd54cb..78cd163 100644
--- a/mojo/runner/context.h
+++ b/mojo/runner/context.h
@@ -55,6 +55,9 @@ class Context : public shell::ApplicationManager::Delegate,
void Run(const GURL& url);
+ // Run the application specified on the commandline.
+ void RunCommandLineApplication();
+
TaskRunners* task_runners() { return task_runners_.get(); }
shell::ApplicationManager* application_manager() {
return &application_manager_;
diff --git a/mojo/runner/desktop/launcher_process.cc b/mojo/runner/desktop/launcher_process.cc
index d8d9f9a..204b3f7 100644
--- a/mojo/runner/desktop/launcher_process.cc
+++ b/mojo/runner/desktop/launcher_process.cc
@@ -75,23 +75,6 @@ void StopTracingAndFlushToDisk() {
flush_complete_event.Wait();
}
-void StartApp(mojo::runner::Context* context) {
- // If a mojo app isn't specified (i.e. for an apptest), run the mojo shell's
- // window manager.
- GURL app_url(GURL("mojo:window_manager"));
- base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();
- base::CommandLine::StringVector args = command_line->GetArgs();
- for (size_t i = 0; i < args.size(); ++i) {
- GURL possible_app(args[i]);
- if (possible_app.SchemeIs("mojo")) {
- app_url = possible_app;
- break;
- }
- }
-
- context->Run(app_url);
-}
-
} // namespace
int LauncherProcessMain(int argc, char** argv) {
@@ -120,7 +103,9 @@ int LauncherProcessMain(int argc, char** argv) {
base::TimeDelta::FromSeconds(5));
}
- message_loop.PostTask(FROM_HERE, base::Bind(&StartApp, &shell_context));
+ message_loop.PostTask(FROM_HERE,
+ base::Bind(&Context::RunCommandLineApplication,
+ base::Unretained(&shell_context)));
message_loop.Run();
// Must be called before |message_loop| is destroyed.