summaryrefslogtreecommitdiffstats
path: root/luni/src/main/native/java_io_ObjectOutputStream.cpp
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2010-05-26 17:45:07 -0700
committerElliott Hughes <enh@google.com>2010-05-26 23:52:54 -0700
commit05960876dff6a5b686821eed8f7ae7cef5af4f50 (patch)
tree56403ecb87974f4f17b02d996ed828cb74054118 /luni/src/main/native/java_io_ObjectOutputStream.cpp
parent2be0ae9c8abc05d1c94c8bb170503ee2feae1866 (diff)
downloadlibcore-05960876dff6a5b686821eed8f7ae7cef5af4f50.zip
libcore-05960876dff6a5b686821eed8f7ae7cef5af4f50.tar.gz
libcore-05960876dff6a5b686821eed8f7ae7cef5af4f50.tar.bz2
Enhance ScopedUtfChars to include the null check most callers were missing.
Also switch most non-users over to ScopedUtfChars. Also ensure all users check that ScopedUtfChars was successful in getting the chars. Also rewrite ObjectInputStream and ObjectOutputStream without duplication. Change-Id: I929d00fe3ff50b303cba4a2cf2269355e9fef5f9
Diffstat (limited to 'luni/src/main/native/java_io_ObjectOutputStream.cpp')
-rw-r--r--luni/src/main/native/java_io_ObjectOutputStream.cpp256
1 files changed, 47 insertions, 209 deletions
diff --git a/luni/src/main/native/java_io_ObjectOutputStream.cpp b/luni/src/main/native/java_io_ObjectOutputStream.cpp
index 791e041..c499bac 100644
--- a/luni/src/main/native/java_io_ObjectOutputStream.cpp
+++ b/luni/src/main/native/java_io_ObjectOutputStream.cpp
@@ -16,223 +16,61 @@
*/
#include "JNIHelp.h"
-
-static jlong java_getFieldLong(JNIEnv * env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "J");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jlong) 0L;
- } else {
- return env->GetLongField(targetObject, fid);
+#include "ScopedUtfChars.h"
+
+#define GETTER(FUNCTION_NAME, JNI_C_TYPE, JNI_TYPE_STRING, JNI_GETTER_FUNCTION) \
+ static JNI_C_TYPE FUNCTION_NAME(JNIEnv* env, jclass, jobject instance, jclass declaringClass, \
+ jstring javaFieldName) { \
+ if (instance == NULL) { \
+ return JNI_C_TYPE(); \
+ } \
+ ScopedUtfChars fieldName(env, javaFieldName); \
+ if (fieldName.c_str() == NULL) { \
+ return JNI_C_TYPE(); \
+ } \
+ jfieldID fid = env->GetFieldID(declaringClass, fieldName.c_str(), JNI_TYPE_STRING); \
+ if (fid == 0) { \
+ return JNI_C_TYPE(); \
+ } \
+ return env->JNI_GETTER_FUNCTION(instance, fid); \
}
-}
-static jshort java_getFieldShort(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "S");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jshort) 0;
- } else {
- return env->GetShortField(targetObject, fid);
+GETTER(ObjectOutputStream_getFieldBool, jboolean, "Z", GetBooleanField)
+GETTER(ObjectOutputStream_getFieldByte, jbyte, "B", GetByteField)
+GETTER(ObjectOutputStream_getFieldChar, jchar, "C", GetCharField)
+GETTER(ObjectOutputStream_getFieldDouble, jdouble, "D", GetDoubleField)
+GETTER(ObjectOutputStream_getFieldFloat, jfloat, "F", GetFloatField)
+GETTER(ObjectOutputStream_getFieldInt, jint, "I", GetIntField)
+GETTER(ObjectOutputStream_getFieldLong, jlong, "J", GetLongField)
+GETTER(ObjectOutputStream_getFieldShort, jshort, "S", GetShortField)
+
+static jobject ObjectOutputStream_getFieldObj(JNIEnv* env, jclass, jobject instance,
+ jclass declaringClass, jstring javaFieldName, jstring javaFieldTypeName) {
+ ScopedUtfChars fieldName(env, javaFieldName);
+ if (fieldName.c_str() == NULL) {
+ return NULL;
}
-}
-
-static jdouble java_getFieldDouble(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "D");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jdouble) 0.0;
- } else {
- return env->GetDoubleField(targetObject, fid);
+ ScopedUtfChars fieldTypeName(env, javaFieldTypeName);
+ if (fieldTypeName.c_str() == NULL) {
+ return NULL;
}
-}
-
-static jboolean java_getFieldBool(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "Z");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jboolean) 0;
- } else {
- return env->GetBooleanField(targetObject, fid);
- }
-}
-
-static jbyte java_getFieldByte(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "B");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jbyte) 0;
- } else {
- return env->GetByteField(targetObject, fid);
- }
-}
-
-static jfloat java_getFieldFloat(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "F");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jfloat) 0.0f;
- }
- else {
- return env->GetFloatField(targetObject, fid);
- }
-
-}
-
-static jchar java_getFieldChar(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "C");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jchar) 0;
- } else {
- return env->GetCharField(targetObject, fid);
- }
-}
-
-static jobject java_getFieldObj(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName,
- jstring fieldTypeName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- const char *fieldTypeNameInC =
- env->GetStringUTFChars(fieldTypeName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass,
- fieldNameInC, fieldTypeNameInC);
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
- env->ReleaseStringUTFChars(fieldTypeName, fieldTypeNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused an exception,
- * or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jobject) 0;
- } else {
- return env->GetObjectField(targetObject, fid);
- }
-}
-
-static jint java_getFieldInt(JNIEnv* env, jclass,
- jobject targetObject,
- jclass declaringClass,
- jstring fieldName) {
- const char *fieldNameInC = env->GetStringUTFChars(fieldName, NULL);
- jfieldID fid = env->GetFieldID(declaringClass, fieldNameInC, "I");
- env->ReleaseStringUTFChars(fieldName, fieldNameInC);
-
- /*
- * Two options now. Maybe getFieldID caused
- * an exception, or maybe it returned the real value
- */
- if(fid == 0) {
- // Field not found. I believe we must throw an exception here
- return (jint) 0;
- } else {
- return env->GetIntField(targetObject, fid);
+ jfieldID fid = env->GetFieldID(declaringClass, fieldName.c_str(), fieldTypeName.c_str());
+ if (fid == 0) {
+ return NULL;
}
+ return env->GetObjectField(instance, fid);
}
static JNINativeMethod gMethods[] = {
- { "getFieldLong",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)J",
- (void*) java_getFieldLong },
- { "getFieldShort",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)S",
- (void*) java_getFieldShort },
- { "getFieldDouble",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)D",
- (void*) java_getFieldDouble },
- { "getFieldBool",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)Z",
- (void*) java_getFieldBool },
- { "getFieldByte",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)B",
- (void*) java_getFieldByte },
- { "getFieldFloat",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)F",
- (void*) java_getFieldFloat },
- { "getFieldChar",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)C",
- (void*) java_getFieldChar },
- { "getFieldObj",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;",
- (void*) java_getFieldObj },
- { "getFieldInt",
- "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)I",
- (void*) java_getFieldInt },
-
+ { "getFieldBool", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)Z", (void*) ObjectOutputStream_getFieldBool },
+ { "getFieldByte", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)B", (void*) ObjectOutputStream_getFieldByte },
+ { "getFieldChar", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)C", (void*) ObjectOutputStream_getFieldChar },
+ { "getFieldDouble", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)D", (void*) ObjectOutputStream_getFieldDouble },
+ { "getFieldFloat", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)F", (void*) ObjectOutputStream_getFieldFloat },
+ { "getFieldInt", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)I", (void*) ObjectOutputStream_getFieldInt },
+ { "getFieldLong", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)J", (void*) ObjectOutputStream_getFieldLong },
+ { "getFieldObj", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;", (void*) ObjectOutputStream_getFieldObj },
+ { "getFieldShort", "(Ljava/lang/Object;Ljava/lang/Class;Ljava/lang/String;)S", (void*) ObjectOutputStream_getFieldShort },
};
int register_java_io_ObjectOutputStream(JNIEnv* env) {
return jniRegisterNativeMethods(env, "java/io/ObjectOutputStream", gMethods, NELEM(gMethods));