Index: content/app/android/content_main.cc |
diff --git a/content/app/android/content_main.cc b/content/app/android/content_main.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..c517778e5c12cae062f63c03fc32b9dc54678b40 |
--- /dev/null |
+++ b/content/app/android/content_main.cc |
@@ -0,0 +1,76 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "content/app/android/content_main.h" |
+ |
+#include "base/base_switches.h" |
+#include "base/at_exit.h" |
+#include "base/command_line.h" |
+#include "base/lazy_instance.h" |
+#if !defined(ANDROID_UPSTREAM_BRINGUP) |
+#include "content/common/android/user_agent.h" |
+#endif |
+#include "content/public/app/content_main_delegate.h" |
+#include "content/public/app/content_main_runner.h" |
+#include "content/public/common/content_switches.h" |
+#include "jni/content_main_jni.h" |
+#if !defined(ANDROID_UPSTREAM_BRINGUP) |
+#include "webkit/glue/user_agent.h" |
+#endif |
+ |
+using base::LazyInstance; |
+using content::ContentMainRunner; |
+using content::ContentMainDelegate; |
+ |
+namespace { |
+LazyInstance<scoped_ptr<ContentMainRunner> > g_content_runner = |
+ LAZY_INSTANCE_INITIALIZER; |
+ |
+LazyInstance<scoped_ptr<ContentMainDelegate> > g_content_main_delegate = |
+ LAZY_INSTANCE_INITIALIZER; |
+ |
+} // namespace |
+ |
+static void InitApplicationContext(JNIEnv* env, |
+ _jclass* clazz, |
+ _jobject* context) { |
+ base::android::ScopedJavaLocalRef<jobject> scoped_context(env, context); |
+ base::android::InitApplicationContext(scoped_context); |
+} |
+ |
+static jint Start(JNIEnv* env, jclass clazz) { |
+ const CommandLine& parsed_command_line = *CommandLine::ForCurrentProcess(); |
+ |
+ // This is only for browser process. We want to start waiting as early as |
+ // possible though here is the common initialization code. |
+ if (parsed_command_line.HasSwitch(switches::kWaitForDebugger) && |
+ "" == parsed_command_line.GetSwitchValueASCII(switches::kProcessType)) { |
+ LOG(ERROR) << "Browser waiting for GDB because flag " |
+ << switches::kWaitForDebugger << " was supplied."; |
+ base::debug::WaitForDebugger(24*60*60, false); |
+ } |
+ |
+#if !defined(ANDROID_UPSTREAM_BRINGUP) |
+ webkit_glue::InitUserAgent(GetUserAgentOSInfo()); |
+#endif |
+ |
+ DCHECK(!g_content_runner.Get().get()); |
+ g_content_runner.Get().reset(ContentMainRunner::Create()); |
+ g_content_runner.Get()->Initialize(0, NULL, |
+ g_content_main_delegate.Get().get()); |
+ return g_content_runner.Get()->Run(); |
+} |
+ |
+namespace content { |
+ |
+void SetContentMainDelegate(ContentMainDelegate* delegate) { |
+ DCHECK(!g_content_main_delegate.Get().get()); |
+ g_content_main_delegate.Get().reset(delegate); |
+} |
+ |
+bool RegisterContentMain(JNIEnv* env) { |
+ return RegisterNativesImpl(env); |
+} |
+ |
+} // namespace content |