summaryrefslogtreecommitdiffstats
path: root/luni-kernel/src/main
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2010-04-16 17:44:12 -0700
committerElliott Hughes <enh@google.com>2010-04-16 17:44:12 -0700
commitc08f9fb2a3be82bb1a3f477ca1524ddcf7a1d4b8 (patch)
treecc325048a7dc4cb15eb2f39244c3b881b284644d /luni-kernel/src/main
parent757a7942eed2b0aa457f8517a0259d2ac82c5b18 (diff)
downloadlibcore-c08f9fb2a3be82bb1a3f477ca1524ddcf7a1d4b8.zip
libcore-c08f9fb2a3be82bb1a3f477ca1524ddcf7a1d4b8.tar.gz
libcore-c08f9fb2a3be82bb1a3f477ca1524ddcf7a1d4b8.tar.bz2
Move the libcore registration out of libnativehelpers and into libcore.
Bug: 754114 Change-Id: Iaa03def509c10cbaa12fd2128584b93d4be4a6b7
Diffstat (limited to 'luni-kernel/src/main')
-rw-r--r--luni-kernel/src/main/native/Register.cpp107
-rw-r--r--luni-kernel/src/main/native/java_lang_ProcessManager.cpp5
-rw-r--r--luni-kernel/src/main/native/java_lang_System.cpp9
-rw-r--r--luni-kernel/src/main/native/sub.mk3
4 files changed, 111 insertions, 13 deletions
diff --git a/luni-kernel/src/main/native/Register.cpp b/luni-kernel/src/main/native/Register.cpp
new file mode 100644
index 0000000..8980cc5
--- /dev/null
+++ b/luni-kernel/src/main/native/Register.cpp
@@ -0,0 +1,107 @@
+/*
+ * Copyright (C) 2010 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "ScopedLocalFrame.h"
+
+namespace android {
+ extern int register_dalvik_system_TouchDex(JNIEnv* env);
+}
+
+extern int register_com_ibm_icu4jni_converters_NativeConverter(JNIEnv* env);
+extern int register_com_ibm_icu4jni_lang_UCharacter(JNIEnv* env);
+extern int register_com_ibm_icu4jni_regex_NativeRegEx(JNIEnv* env);
+extern int register_com_ibm_icu4jni_text_NativeBreakIterator(JNIEnv* env);
+extern int register_com_ibm_icu4jni_text_NativeCollator(JNIEnv* env);
+extern int register_com_ibm_icu4jni_text_NativeDecimalFormat(JNIEnv* env);
+extern int register_com_ibm_icu4jni_text_NativeIDN(JNIEnv* env);
+extern int register_com_ibm_icu4jni_text_NativeNormalizer(JNIEnv* env);
+extern int register_com_ibm_icu4jni_util_Resources(JNIEnv* env);
+extern int register_java_io_Console(JNIEnv* env);
+extern int register_java_io_File(JNIEnv* env);
+extern "C" int register_java_io_FileDescriptor(JNIEnv* env);
+extern "C" int register_java_io_ObjectInputStream(JNIEnv* env);
+extern "C" int register_java_io_ObjectOutputStream(JNIEnv* env);
+extern "C" int register_java_io_ObjectStreamClass(JNIEnv* env);
+extern "C" int register_java_lang_Double(JNIEnv* env);
+extern "C" int register_java_lang_Float(JNIEnv* env);
+extern "C" int register_java_lang_Math(JNIEnv* env);
+extern int register_java_lang_ProcessManager(JNIEnv* env);
+extern "C" int register_java_lang_StrictMath(JNIEnv* env);
+extern int register_java_lang_System(JNIEnv* env);
+extern int register_java_net_InetAddress(JNIEnv* env);
+extern int register_java_net_NetworkInterface(JNIEnv* env);
+extern "C" int register_java_util_zip_Adler32(JNIEnv* env);
+extern "C" int register_java_util_zip_CRC32(JNIEnv* env);
+extern "C" int register_java_util_zip_Deflater(JNIEnv* env);
+extern "C" int register_java_util_zip_Inflater(JNIEnv* env);
+extern "C" int register_org_apache_harmony_dalvik_NativeTestTarget(JNIEnv* env);
+extern int register_org_apache_harmony_luni_platform_OSFileSystem(JNIEnv* env);
+extern int register_org_apache_harmony_luni_platform_OSMemory(JNIEnv* env);
+extern int register_org_apache_harmony_luni_platform_OSNetworkSystem(JNIEnv* env);
+extern "C" int register_org_apache_harmony_luni_util_NumberConvert(JNIEnv* env);
+extern "C" int register_org_apache_harmony_luni_util_fltparse(JNIEnv* env);
+extern int register_org_apache_harmony_text_BidiWrapper(JNIEnv* env);
+extern int register_org_apache_harmony_xml_ExpatParser(JNIEnv* env);
+extern int register_org_apache_harmony_xnet_provider_jsse_NativeCrypto(JNIEnv* env);
+extern "C" int register_org_openssl_NativeBN(JNIEnv* env);
+
+// DalvikVM calls this on startup, so we can statically register all our native methods.
+extern "C" int registerCoreLibrariesJni(JNIEnv* env) {
+ ScopedLocalFrame localFrame(env);
+
+ bool result =
+ register_com_ibm_icu4jni_converters_NativeConverter(env) != -1 &&
+ register_com_ibm_icu4jni_lang_UCharacter(env) != -1 &&
+ register_com_ibm_icu4jni_regex_NativeRegEx(env) != -1 &&
+ register_com_ibm_icu4jni_text_NativeBreakIterator(env) != -1 &&
+ register_com_ibm_icu4jni_text_NativeCollator(env) != -1 &&
+ register_com_ibm_icu4jni_text_NativeDecimalFormat(env) != -1 &&
+ register_com_ibm_icu4jni_text_NativeIDN(env) != -1 &&
+ register_com_ibm_icu4jni_text_NativeNormalizer(env) != -1 &&
+ register_com_ibm_icu4jni_util_Resources(env) != -1 &&
+ register_java_io_Console(env) != -1 &&
+ register_java_io_File(env) != -1 &&
+ register_java_io_FileDescriptor(env) != -1 &&
+ register_java_io_ObjectInputStream(env) != -1 &&
+ register_java_io_ObjectOutputStream(env) != -1 &&
+ register_java_io_ObjectStreamClass(env) != -1 &&
+ register_java_lang_Double(env) != -1 &&
+ register_java_lang_Float(env) != -1 &&
+ register_java_lang_Math(env) != -1 &&
+ register_java_lang_ProcessManager(env) != -1 &&
+ register_java_lang_StrictMath(env) != -1 &&
+ register_java_lang_System(env) != -1 &&
+ register_java_net_InetAddress(env) != -1 &&
+ register_java_net_NetworkInterface(env) != -1 &&
+ register_java_util_zip_Adler32(env) != -1 &&
+ register_java_util_zip_CRC32(env) != -1 &&
+ register_java_util_zip_Deflater(env) != -1 &&
+ register_java_util_zip_Inflater(env) != -1 &&
+ register_org_apache_harmony_luni_platform_OSFileSystem(env) != -1 &&
+ register_org_apache_harmony_luni_platform_OSMemory(env) != -1 &&
+ register_org_apache_harmony_luni_platform_OSNetworkSystem(env) != -1 &&
+ register_org_apache_harmony_luni_util_NumberConvert(env) != -1 &&
+ register_org_apache_harmony_luni_util_fltparse(env) != -1 &&
+ register_org_apache_harmony_text_BidiWrapper(env) != -1 &&
+ register_org_apache_harmony_xnet_provider_jsse_NativeCrypto(env) != -1 &&
+ register_org_openssl_NativeBN(env) != -1 &&
+ // Initialize the Android classes last, as they have dependencies on the "corer" core classes.
+ android::register_dalvik_system_TouchDex(env) != -1 &&
+ register_org_apache_harmony_dalvik_NativeTestTarget(env) != -1 &&
+ register_org_apache_harmony_xml_ExpatParser(env) != -1;
+
+ return result ? 0 : -1;
+}
diff --git a/luni-kernel/src/main/native/java_lang_ProcessManager.cpp b/luni-kernel/src/main/native/java_lang_ProcessManager.cpp
index 045d980..666a8c7 100644
--- a/luni-kernel/src/main/native/java_lang_ProcessManager.cpp
+++ b/luni-kernel/src/main/native/java_lang_ProcessManager.cpp
@@ -29,7 +29,6 @@
#include "jni.h"
#include "JNIHelp.h"
#include "utils/Log.h"
-#include "AndroidSystemNatives.h"
/** Environment variables. */
extern char **environ;
@@ -415,8 +414,6 @@ static JNINativeMethod methods[] = {
{ "exec", "([Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;Ljava/io/FileDescriptor;Ljava/io/FileDescriptor;Ljava/io/FileDescriptor;Z)I",
(void*) java_lang_ProcessManager_exec },
};
-
int register_java_lang_ProcessManager(JNIEnv* env) {
- return jniRegisterNativeMethods(
- env, "java/lang/ProcessManager", methods, NELEM(methods));
+ return jniRegisterNativeMethods(env, "java/lang/ProcessManager", methods, NELEM(methods));
}
diff --git a/luni-kernel/src/main/native/java_lang_System.cpp b/luni-kernel/src/main/native/java_lang_System.cpp
index 52150d3..b114dab 100644
--- a/luni-kernel/src/main/native/java_lang_System.cpp
+++ b/luni-kernel/src/main/native/java_lang_System.cpp
@@ -14,7 +14,6 @@
* limitations under the License.
*/
-#include "AndroidSystemNatives.h"
#include "JNIHelp.h"
#include <stdlib.h>
@@ -84,17 +83,11 @@ static void java_setFieldImpl(JNIEnv* env, jclass clazz,
env->ReleaseStringUTFChars(sig, fieldSig);
}
-/*
- * JNI registration
- */
static JNINativeMethod gMethods[] = {
- /* name, signature, funcPtr */
{ "getEnvByName", "(Ljava/lang/String;)Ljava/lang/String;", (void*) java_getEnvByName },
{ "getEnvByIndex", "(I)Ljava/lang/String;", (void*) java_getEnvByIndex },
{ "setFieldImpl", "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;)V", (void*) java_setFieldImpl },
};
-
int register_java_lang_System(JNIEnv* env) {
- return jniRegisterNativeMethods(env, "java/lang/System",
- gMethods, NELEM(gMethods));
+ return jniRegisterNativeMethods(env, "java/lang/System", gMethods, NELEM(gMethods));
}
diff --git a/luni-kernel/src/main/native/sub.mk b/luni-kernel/src/main/native/sub.mk
index fcb7d0d..7f6417b 100644
--- a/luni-kernel/src/main/native/sub.mk
+++ b/luni-kernel/src/main/native/sub.mk
@@ -4,7 +4,8 @@
LOCAL_SRC_FILES := \
java_lang_ProcessManager.cpp \
- java_lang_System.cpp
+ java_lang_System.cpp \
+ Register.cpp
LOCAL_C_INCLUDES +=