Index: components/cronet/android/cronet_loader.cc |
diff --git a/components/cronet/android/cronet_loader.cc b/components/cronet/android/cronet_loader.cc |
index 3929b6cb516af3639a92de51f03f51aabe0fdc02..ac4b42bcc1f83de508ef45748f30825258e4d7bc 100644 |
--- a/components/cronet/android/cronet_loader.cc |
+++ b/components/cronet/android/cronet_loader.cc |
@@ -6,12 +6,16 @@ |
#include "base/android/jni_android.h" |
#include "base/android/jni_registrar.h" |
#include "base/at_exit.h" |
+#include "base/message_loop/message_loop.h" |
#include "components/cronet/android/chromium_url_request.h" |
#include "components/cronet/android/chromium_url_request_context.h" |
#include "components/cronet/android/cronet_url_request.h" |
#include "components/cronet/android/cronet_url_request_context.h" |
#include "components/cronet/android/histogram_manager.h" |
+#include "jni/CronetLibraryLoader_jni.h" |
#include "net/android/net_jni_registrar.h" |
+#include "net/android/network_change_notifier_factory_android.h" |
+#include "net/base/network_change_notifier.h" |
#include "url/android/url_jni_registrar.h" |
#include "url/url_util.h" |
@@ -24,16 +28,22 @@ namespace { |
const base::android::RegistrationMethod kCronetRegisteredMethods[] = { |
{"BaseAndroid", base::android::RegisterJni}, |
- {"ChromiumUrlRequest", cronet::ChromiumUrlRequestRegisterJni}, |
- {"ChromiumUrlRequestContext", cronet::ChromiumUrlRequestContextRegisterJni}, |
- {"CronetUrlRequest", cronet::CronetUrlRequestRegisterJni}, |
- {"CronetUrlRequestContext", cronet::CronetUrlRequestContextRegisterJni}, |
- {"HistogramManager", cronet::HistogramManagerRegisterJni}, |
+ {"ChromiumUrlRequest", ChromiumUrlRequestRegisterJni}, |
+ {"ChromiumUrlRequestContext", ChromiumUrlRequestContextRegisterJni}, |
+ {"CronetLibraryLoader", RegisterNativesImpl}, |
+ {"CronetUrlRequest", CronetUrlRequestRegisterJni}, |
+ {"CronetUrlRequestContext", CronetUrlRequestContextRegisterJni}, |
+ {"HistogramManager", HistogramManagerRegisterJni}, |
{"NetAndroid", net::android::RegisterJni}, |
{"UrlAndroid", url::android::RegisterJni}, |
}; |
base::AtExitManager* g_at_exit_manager = NULL; |
+// MessageLoop on the main thread, which is where objects that receive Java |
+// notifications generally live. |
+base::MessageLoop* g_main_message_loop = nullptr; |
+ |
+net::NetworkChangeNotifier* g_network_change_notifier = nullptr; |
} // namespace |
@@ -53,10 +63,6 @@ jint CronetOnLoad(JavaVM* vm, void* reserved) { |
g_at_exit_manager = new base::AtExitManager(); |
-#if !defined(USE_ICU_ALTERNATIVES_ON_ANDROID) |
- base::i18n::InitializeICU(); |
-#endif |
- |
url::Initialize(); |
return JNI_VERSION_1_6; |
@@ -69,4 +75,25 @@ void CronetOnUnLoad(JavaVM* jvm, void* reserved) { |
} |
} |
+jlong CronetInitOnMainThread(JNIEnv* env, jclass jcaller, jobject jcontext) { |
+ // Set application context. |
+ base::android::ScopedJavaLocalRef<jobject> scoped_context(env, jcontext); |
+ base::android::InitApplicationContext(env, scoped_context); |
+ |
+#if !defined(USE_ICU_ALTERNATIVES_ON_ANDROID) |
+ base::i18n::InitializeICU(); |
+#endif |
+ |
+ DCHECK(!base::MessageLoop::current()); |
+ DCHECK(!g_main_message_loop); |
mmenke
2015/02/02 19:30:26
include base/logging.h
While we're here, should p
mef
2015/02/03 01:28:57
Done.
|
+ g_main_message_loop = new base::MessageLoopForUI(); |
+ base::MessageLoopForUI::current()->Start(); |
+ DCHECK(!g_network_change_notifier); |
+ net::NetworkChangeNotifier::SetFactory( |
+ new net::NetworkChangeNotifierFactoryAndroid()); |
+ g_network_change_notifier = net::NetworkChangeNotifier::Create(); |
+ |
+ return 0; |
+} |
+ |
} // namespace cronet |