diff options
Diffstat (limited to 'runtime/native/java_lang_reflect_Field.cc')
-rw-r--r-- | runtime/native/java_lang_reflect_Field.cc | 256 |
1 files changed, 132 insertions, 124 deletions
diff --git a/runtime/native/java_lang_reflect_Field.cc b/runtime/native/java_lang_reflect_Field.cc index 9c5bde9c1e..0fe78b3281 100644 --- a/runtime/native/java_lang_reflect_Field.cc +++ b/runtime/native/java_lang_reflect_Field.cc @@ -21,23 +21,23 @@ #include "common_throws.h" #include "dex_file-inl.h" #include "jni_internal.h" -#include "mirror/art_field-inl.h" #include "mirror/art_method-inl.h" #include "mirror/class-inl.h" +#include "mirror/field.h" #include "reflection-inl.h" #include "scoped_fast_native_object_access.h" namespace art { template<bool kIsSet> -ALWAYS_INLINE inline static bool VerifyFieldAccess(Thread* self, mirror::ArtField* field, +ALWAYS_INLINE inline static bool VerifyFieldAccess(Thread* self, mirror::Field* field, mirror::Object* obj) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_) { if (kIsSet && field->IsFinal()) { ThrowIllegalAccessException( StringPrintf("Cannot set %s field %s of class %s", PrettyJavaAccessFlags(field->GetAccessFlags()).c_str(), - PrettyField(field).c_str(), + PrettyField(field->GetArtField()).c_str(), field->GetDeclaringClass() == nullptr ? "null" : PrettyClass(field->GetDeclaringClass()).c_str()).c_str()); return false; @@ -49,7 +49,7 @@ ALWAYS_INLINE inline static bool VerifyFieldAccess(Thread* self, mirror::ArtFiel StringPrintf("Class %s cannot access %s field %s of class %s", calling_class == nullptr ? "null" : PrettyClass(calling_class).c_str(), PrettyJavaAccessFlags(field->GetAccessFlags()).c_str(), - PrettyField(field).c_str(), + PrettyField(field->GetArtField()).c_str(), field->GetDeclaringClass() == nullptr ? "null" : PrettyClass(field->GetDeclaringClass()).c_str()).c_str()); return false; @@ -58,38 +58,37 @@ ALWAYS_INLINE inline static bool VerifyFieldAccess(Thread* self, mirror::ArtFiel } template<bool kAllowReferences> -ALWAYS_INLINE inline static bool GetFieldValue(mirror::Object* o, mirror::ArtField* f, +ALWAYS_INLINE inline static bool GetFieldValue(mirror::Object* o, mirror::Field* f, Primitive::Type field_type, JValue* value) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_) { DCHECK_EQ(value->GetJ(), INT64_C(0)); + MemberOffset offset(f->GetOffset()); + const bool is_volatile = f->IsVolatile(); switch (field_type) { case Primitive::kPrimBoolean: - value->SetZ(f->GetBoolean(o)); + value->SetZ(is_volatile ? o->GetFieldBooleanVolatile(offset) : o->GetFieldBoolean(offset)); return true; case Primitive::kPrimByte: - value->SetB(f->GetByte(o)); + value->SetB(is_volatile ? o->GetFieldByteVolatile(offset) : o->GetFieldByte(offset)); return true; case Primitive::kPrimChar: - value->SetC(f->GetChar(o)); - return true; - case Primitive::kPrimDouble: - value->SetD(f->GetDouble(o)); - return true; - case Primitive::kPrimFloat: - value->SetF(f->GetFloat(o)); + value->SetC(is_volatile ? o->GetFieldCharVolatile(offset) : o->GetFieldChar(offset)); return true; case Primitive::kPrimInt: - value->SetI(f->GetInt(o)); + case Primitive::kPrimFloat: + value->SetI(is_volatile ? o->GetField32Volatile(offset) : o->GetField32(offset)); return true; case Primitive::kPrimLong: - value->SetJ(f->GetLong(o)); + case Primitive::kPrimDouble: + value->SetJ(is_volatile ? o->GetField64Volatile(offset) : o->GetField64(offset)); return true; case Primitive::kPrimShort: - value->SetS(f->GetShort(o)); + value->SetS(is_volatile ? o->GetFieldShortVolatile(offset) : o->GetFieldShort(offset)); return true; case Primitive::kPrimNot: if (kAllowReferences) { - value->SetL(f->GetObject(o)); + value->SetL(is_volatile ? o->GetFieldObjectVolatile<mirror::Object>(offset) : + o->GetFieldObject<mirror::Object>(offset)); return true; } // Else break to report an error. @@ -98,23 +97,23 @@ ALWAYS_INLINE inline static bool GetFieldValue(mirror::Object* o, mirror::ArtFie // Never okay. break; } - ThrowIllegalArgumentException(StringPrintf("Not a primitive field: %s", - PrettyField(f).c_str()).c_str()); + ThrowIllegalArgumentException( + StringPrintf("Not a primitive field: %s", PrettyField(f->GetArtField()).c_str()).c_str()); return false; } ALWAYS_INLINE inline static bool CheckReceiver(const ScopedFastNativeObjectAccess& soa, - jobject j_rcvr, mirror::ArtField** f, + jobject j_rcvr, mirror::Field** f, mirror::Object** class_or_rcvr) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_) { soa.Self()->AssertThreadSuspensionIsAllowable(); mirror::Class* declaringClass = (*f)->GetDeclaringClass(); if ((*f)->IsStatic()) { if (UNLIKELY(!declaringClass->IsInitialized())) { - ClassLinker* class_linker = Runtime::Current()->GetClassLinker(); StackHandleScope<2> hs(soa.Self()); - HandleWrapper<mirror::ArtField> h_f(hs.NewHandleWrapper(f)); + HandleWrapper<mirror::Field> h_f(hs.NewHandleWrapper(f)); HandleWrapper<mirror::Class> h_klass(hs.NewHandleWrapper(&declaringClass)); + ClassLinker* const class_linker = Runtime::Current()->GetClassLinker(); if (UNLIKELY(!class_linker->EnsureInitialized(soa.Self(), h_klass, true, true))) { DCHECK(soa.Self()->IsExceptionPending()); return false; @@ -131,16 +130,16 @@ ALWAYS_INLINE inline static bool CheckReceiver(const ScopedFastNativeObjectAcces return true; } -static jobject Field_get(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { +static jobject Field_get(JNIEnv* env, jobject javaField, jobject javaObj) { ScopedFastNativeObjectAccess soa(env); - mirror::ArtField* f = mirror::ArtField::FromReflectedField(soa, javaField); + mirror::Field* f = soa.Decode<mirror::Field*>(javaField); mirror::Object* o = nullptr; if (!CheckReceiver(soa, javaObj, &f, &o)) { DCHECK(soa.Self()->IsExceptionPending()); return nullptr; } // If field is not set to be accessible, verify it can be accessed by the caller. - if ((accessible == JNI_FALSE) && !VerifyFieldAccess<false>(soa.Self(), f, o)) { + if (!f->IsAccessible() && !VerifyFieldAccess<false>(soa.Self(), f, o)) { DCHECK(soa.Self()->IsExceptionPending()); return nullptr; } @@ -157,9 +156,9 @@ static jobject Field_get(JNIEnv* env, jobject javaField, jobject javaObj, jboole template<Primitive::Type kPrimitiveType> ALWAYS_INLINE inline static JValue GetPrimitiveField(JNIEnv* env, jobject javaField, - jobject javaObj, jboolean accessible) { + jobject javaObj) { ScopedFastNativeObjectAccess soa(env); - mirror::ArtField* f = mirror::ArtField::FromReflectedField(soa, javaField); + mirror::Field* f = soa.Decode<mirror::Field*>(javaField); mirror::Object* o = nullptr; if (!CheckReceiver(soa, javaObj, &f, &o)) { DCHECK(soa.Self()->IsExceptionPending()); @@ -167,7 +166,7 @@ ALWAYS_INLINE inline static JValue GetPrimitiveField(JNIEnv* env, jobject javaFi } // If field is not set to be accessible, verify it can be accessed by the caller. - if (accessible == JNI_FALSE && !VerifyFieldAccess<false>(soa.Self(), f, o)) { + if (!f->IsAccessible() && !VerifyFieldAccess<false>(soa.Self(), f, o)) { DCHECK(soa.Self()->IsExceptionPending()); return JValue(); } @@ -198,72 +197,97 @@ ALWAYS_INLINE inline static JValue GetPrimitiveField(JNIEnv* env, jobject javaFi return wide_value; } -static jboolean Field_getBoolean(JNIEnv* env, jobject javaField, jobject javaObj, - jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimBoolean>(env, javaField, javaObj, accessible).GetZ(); +static jboolean Field_getBoolean(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimBoolean>(env, javaField, javaObj).GetZ(); } -static jbyte Field_getByte(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimByte>(env, javaField, javaObj, accessible).GetB(); +static jbyte Field_getByte(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimByte>(env, javaField, javaObj).GetB(); } -static jchar Field_getChar(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimChar>(env, javaField, javaObj, accessible).GetC(); +static jchar Field_getChar(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimChar>(env, javaField, javaObj).GetC(); } -static jdouble Field_getDouble(JNIEnv* env, jobject javaField, jobject javaObj, - jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimDouble>(env, javaField, javaObj, accessible).GetD(); +static jdouble Field_getDouble(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimDouble>(env, javaField, javaObj).GetD(); } -static jfloat Field_getFloat(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimFloat>(env, javaField, javaObj, accessible).GetF(); +static jfloat Field_getFloat(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimFloat>(env, javaField, javaObj).GetF(); } -static jint Field_getInt(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimInt>(env, javaField, javaObj, accessible).GetI(); +static jint Field_getInt(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimInt>(env, javaField, javaObj).GetI(); } -static jlong Field_getLong(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimLong>(env, javaField, javaObj, accessible).GetJ(); +static jlong Field_getLong(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimLong>(env, javaField, javaObj).GetJ(); } -static jshort Field_getShort(JNIEnv* env, jobject javaField, jobject javaObj, jboolean accessible) { - return GetPrimitiveField<Primitive::kPrimShort>(env, javaField, javaObj, accessible).GetS(); +static jshort Field_getShort(JNIEnv* env, jobject javaField, jobject javaObj) { + return GetPrimitiveField<Primitive::kPrimShort>(env, javaField, javaObj).GetS(); } -static void SetFieldValue(mirror::Object* o, mirror::ArtField* f, Primitive::Type field_type, - bool allow_references, const JValue& new_value) +ALWAYS_INLINE inline static void SetFieldValue(mirror::Object* o, mirror::Field* f, + Primitive::Type field_type, bool allow_references, + const JValue& new_value) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_) { DCHECK(f->GetDeclaringClass()->IsInitialized()); + MemberOffset offset(f->GetOffset()); + const bool is_volatile = f->IsVolatile(); switch (field_type) { case Primitive::kPrimBoolean: - f->SetBoolean<false>(o, new_value.GetZ()); + if (is_volatile) { + o->SetFieldBooleanVolatile<false>(offset, new_value.GetZ()); + } else { + o->SetFieldBoolean<false>(offset, new_value.GetZ()); + } break; case Primitive::kPrimByte: - f->SetByte<false>(o, new_value.GetB()); + if (is_volatile) { + o->SetFieldBooleanVolatile<false>(offset, new_value.GetB()); + } else { + o->SetFieldBoolean<false>(offset, new_value.GetB()); + } break; case Primitive::kPrimChar: - f->SetChar<false>(o, new_value.GetC()); - break; - case Primitive::kPrimDouble: - f->SetDouble<false>(o, new_value.GetD()); - break; - case Primitive::kPrimFloat: - f->SetFloat<false>(o, new_value.GetF()); + if (is_volatile) { + o->SetFieldBooleanVolatile<false>(offset, new_value.GetC()); + } else { + o->SetFieldBoolean<false>(offset, new_value.GetC()); + } break; case Primitive::kPrimInt: - f->SetInt<false>(o, new_value.GetI()); + case Primitive::kPrimFloat: + if (is_volatile) { + o->SetField32Volatile<false>(offset, new_value.GetI()); + } else { + o->SetField32<false>(offset, new_value.GetI()); + } break; case Primitive::kPrimLong: - f->SetLong<false>(o, new_value.GetJ()); + case Primitive::kPrimDouble: + if (is_volatile) { + o->SetField64Volatile<false>(offset, new_value.GetJ()); + } else { + o->SetField64<false>(offset, new_value.GetJ()); + } break; case Primitive::kPrimShort: - f->SetShort<false>(o, new_value.GetS()); + if (is_volatile) { + o->SetFieldShortVolatile<false>(offset, new_value.GetZ()); + } else { + o->SetFieldShort<false>(offset, new_value.GetZ()); + } break; case Primitive::kPrimNot: if (allow_references) { - f->SetObject<false>(o, new_value.GetL()); + if (is_volatile) { + o->SetFieldObjectVolatile<false>(offset, new_value.GetL()); + } else { + o->SetFieldObject<false>(offset, new_value.GetL()); + } break; } // Else fall through to report an error. @@ -271,15 +295,14 @@ static void SetFieldValue(mirror::Object* o, mirror::ArtField* f, Primitive::Typ case Primitive::kPrimVoid: // Never okay. ThrowIllegalArgumentException(StringPrintf("Not a primitive field: %s", - PrettyField(f).c_str()).c_str()); + PrettyField(f->GetArtField()).c_str()).c_str()); return; } } -static void Field_set(JNIEnv* env, jobject javaField, jobject javaObj, jobject javaValue, - jboolean accessible) { +static void Field_set(JNIEnv* env, jobject javaField, jobject javaObj, jobject javaValue) { ScopedFastNativeObjectAccess soa(env); - mirror::ArtField* f = mirror::ArtField::FromReflectedField(soa, javaField); + mirror::Field* f = soa.Decode<mirror::Field*>(javaField); // Check that the receiver is non-null and an instance of the field's declaring class. mirror::Object* o = nullptr; if (!CheckReceiver(soa, javaObj, &f, &o)) { @@ -287,18 +310,11 @@ static void Field_set(JNIEnv* env, jobject javaField, jobject javaObj, jobject j return; } mirror::Class* field_type; - const char* field_type_desciptor = f->GetTypeDescriptor(); + const char* field_type_desciptor = f->GetArtField()->GetTypeDescriptor(); Primitive::Type field_prim_type = Primitive::GetType(field_type_desciptor[0]); if (field_prim_type == Primitive::kPrimNot) { - StackHandleScope<2> hs(soa.Self()); - HandleWrapper<mirror::Object> h_o(hs.NewHandleWrapper(&o)); - HandleWrapper<mirror::ArtField> h_f(hs.NewHandleWrapper(&f)); - // May cause resolution. - field_type = h_f->GetType(true); - if (field_type == nullptr) { - DCHECK(soa.Self()->IsExceptionPending()); - return; - } + field_type = f->GetType(); + DCHECK(field_type != nullptr); } else { field_type = Runtime::Current()->GetClassLinker()->FindPrimitiveClass(field_type_desciptor[0]); } @@ -306,12 +322,12 @@ static void Field_set(JNIEnv* env, jobject javaField, jobject javaObj, jobject j // Unbox the value, if necessary. mirror::Object* boxed_value = soa.Decode<mirror::Object*>(javaValue); JValue unboxed_value; - if (!UnboxPrimitiveForField(boxed_value, field_type, f, &unboxed_value)) { + if (!UnboxPrimitiveForField(boxed_value, field_type, f->GetArtField(), &unboxed_value)) { DCHECK(soa.Self()->IsExceptionPending()); return; } // If field is not set to be accessible, verify it can be accessed by the caller. - if ((accessible == JNI_FALSE) && !VerifyFieldAccess<true>(soa.Self(), f, o)) { + if (!f->IsAccessible() && !VerifyFieldAccess<true>(soa.Self(), f, o)) { DCHECK(soa.Self()->IsExceptionPending()); return; } @@ -320,9 +336,9 @@ static void Field_set(JNIEnv* env, jobject javaField, jobject javaObj, jobject j template<Primitive::Type kPrimitiveType> static void SetPrimitiveField(JNIEnv* env, jobject javaField, jobject javaObj, - const JValue& new_value, jboolean accessible) { + const JValue& new_value) { ScopedFastNativeObjectAccess soa(env); - mirror::ArtField* f = mirror::ArtField::FromReflectedField(soa, javaField); + mirror::Field* f = soa.Decode<mirror::Field*>(javaField); mirror::Object* o = nullptr; if (!CheckReceiver(soa, javaObj, &f, &o)) { return; @@ -330,7 +346,7 @@ static void SetPrimitiveField(JNIEnv* env, jobject javaField, jobject javaObj, Primitive::Type field_type = f->GetTypeAsPrimitiveType(); if (UNLIKELY(field_type == Primitive::kPrimNot)) { ThrowIllegalArgumentException(StringPrintf("Not a primitive field: %s", - PrettyField(f).c_str()).c_str()); + PrettyField(f->GetArtField()).c_str()).c_str()); return; } @@ -342,7 +358,7 @@ static void SetPrimitiveField(JNIEnv* env, jobject javaField, jobject javaObj, } // If field is not set to be accessible, verify it can be accessed by the caller. - if ((accessible == JNI_FALSE) && !VerifyFieldAccess<true>(soa.Self(), f, o)) { + if (!f->IsAccessible() && !VerifyFieldAccess<true>(soa.Self(), f, o)) { DCHECK(soa.Self()->IsExceptionPending()); return; } @@ -351,81 +367,73 @@ static void SetPrimitiveField(JNIEnv* env, jobject javaField, jobject javaObj, SetFieldValue(o, f, field_type, false, wide_value); } -static void Field_setBoolean(JNIEnv* env, jobject javaField, jobject javaObj, jboolean z, - jboolean accessible) { +static void Field_setBoolean(JNIEnv* env, jobject javaField, jobject javaObj, jboolean z) { JValue value; value.SetZ(z); - SetPrimitiveField<Primitive::kPrimBoolean>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimBoolean>(env, javaField, javaObj, value); } -static void Field_setByte(JNIEnv* env, jobject javaField, jobject javaObj, jbyte b, - jboolean accessible) { +static void Field_setByte(JNIEnv* env, jobject javaField, jobject javaObj, jbyte b) { JValue value; value.SetB(b); - SetPrimitiveField<Primitive::kPrimByte>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimByte>(env, javaField, javaObj, value); } -static void Field_setChar(JNIEnv* env, jobject javaField, jobject javaObj, jchar c, - jboolean accessible) { +static void Field_setChar(JNIEnv* env, jobject javaField, jobject javaObj, jchar c) { JValue value; value.SetC(c); - SetPrimitiveField<Primitive::kPrimChar>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimChar>(env, javaField, javaObj, value); } -static void Field_setDouble(JNIEnv* env, jobject javaField, jobject javaObj, jdouble d, - jboolean accessible) { +static void Field_setDouble(JNIEnv* env, jobject javaField, jobject javaObj, jdouble d) { JValue value; value.SetD(d); - SetPrimitiveField<Primitive::kPrimDouble>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimDouble>(env, javaField, javaObj, value); } -static void Field_setFloat(JNIEnv* env, jobject javaField, jobject javaObj, jfloat f, - jboolean accessible) { +static void Field_setFloat(JNIEnv* env, jobject javaField, jobject javaObj, jfloat f) { JValue value; value.SetF(f); - SetPrimitiveField<Primitive::kPrimFloat>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimFloat>(env, javaField, javaObj, value); } -static void Field_setInt(JNIEnv* env, jobject javaField, jobject javaObj, jint i, - jboolean accessible) { +static void Field_setInt(JNIEnv* env, jobject javaField, jobject javaObj, jint i) { JValue value; value.SetI(i); - SetPrimitiveField<Primitive::kPrimInt>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimInt>(env, javaField, javaObj, value); } -static void Field_setLong(JNIEnv* env, jobject javaField, jobject javaObj, jlong j, - jboolean accessible) { +static void Field_setLong(JNIEnv* env, jobject javaField, jobject javaObj, jlong j) { JValue value; value.SetJ(j); - SetPrimitiveField<Primitive::kPrimLong>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimLong>(env, javaField, javaObj, value); } -static void Field_setShort(JNIEnv* env, jobject javaField, jobject javaObj, jshort s, - jboolean accessible) { +static void Field_setShort(JNIEnv* env, jobject javaField, jobject javaObj, jshort s) { JValue value; value.SetS(s); - SetPrimitiveField<Primitive::kPrimShort>(env, javaField, javaObj, value, accessible); + SetPrimitiveField<Primitive::kPrimShort>(env, javaField, javaObj, value); } static JNINativeMethod gMethods[] = { - NATIVE_METHOD(Field, get, "!(Ljava/lang/Object;Z)Ljava/lang/Object;"), - NATIVE_METHOD(Field, getBoolean, "!(Ljava/lang/Object;Z)Z"), - NATIVE_METHOD(Field, getByte, "!(Ljava/lang/Object;Z)B"), - NATIVE_METHOD(Field, getChar, "!(Ljava/lang/Object;Z)C"), - NATIVE_METHOD(Field, getDouble, "!(Ljava/lang/Object;Z)D"), - NATIVE_METHOD(Field, getFloat, "!(Ljava/lang/Object;Z)F"), - NATIVE_METHOD(Field, getInt, "!(Ljava/lang/Object;Z)I"), - NATIVE_METHOD(Field, getLong, "!(Ljava/lang/Object;Z)J"), - NATIVE_METHOD(Field, getShort, "!(Ljava/lang/Object;Z)S"), - NATIVE_METHOD(Field, set, "!(Ljava/lang/Object;Ljava/lang/Object;Z)V"), - NATIVE_METHOD(Field, setBoolean, "!(Ljava/lang/Object;ZZ)V"), - NATIVE_METHOD(Field, setByte, "!(Ljava/lang/Object;BZ)V"), - NATIVE_METHOD(Field, setChar, "!(Ljava/lang/Object;CZ)V"), - NATIVE_METHOD(Field, setDouble, "!(Ljava/lang/Object;DZ)V"), - NATIVE_METHOD(Field, setFloat, "!(Ljava/lang/Object;FZ)V"), - NATIVE_METHOD(Field, setInt, "!(Ljava/lang/Object;IZ)V"), - NATIVE_METHOD(Field, setLong, "!(Ljava/lang/Object;JZ)V"), - NATIVE_METHOD(Field, setShort, "!(Ljava/lang/Object;SZ)V"), + NATIVE_METHOD(Field, get, "!(Ljava/lang/Object;)Ljava/lang/Object;"), + NATIVE_METHOD(Field, getBoolean, "!(Ljava/lang/Object;)Z"), + NATIVE_METHOD(Field, getByte, "!(Ljava/lang/Object;)B"), + NATIVE_METHOD(Field, getChar, "!(Ljava/lang/Object;)C"), + NATIVE_METHOD(Field, getDouble, "!(Ljava/lang/Object;)D"), + NATIVE_METHOD(Field, getFloat, "!(Ljava/lang/Object;)F"), + NATIVE_METHOD(Field, getInt, "!(Ljava/lang/Object;)I"), + NATIVE_METHOD(Field, getLong, "!(Ljava/lang/Object;)J"), + NATIVE_METHOD(Field, getShort, "!(Ljava/lang/Object;)S"), + NATIVE_METHOD(Field, set, "!(Ljava/lang/Object;Ljava/lang/Object;)V"), + NATIVE_METHOD(Field, setBoolean, "!(Ljava/lang/Object;Z)V"), + NATIVE_METHOD(Field, setByte, "!(Ljava/lang/Object;B)V"), + NATIVE_METHOD(Field, setChar, "!(Ljava/lang/Object;C)V"), + NATIVE_METHOD(Field, setDouble, "!(Ljava/lang/Object;D)V"), + NATIVE_METHOD(Field, setFloat, "!(Ljava/lang/Object;F)V"), + NATIVE_METHOD(Field, setInt, "!(Ljava/lang/Object;I)V"), + NATIVE_METHOD(Field, setLong, "!(Ljava/lang/Object;J)V"), + NATIVE_METHOD(Field, setShort, "!(Ljava/lang/Object;S)V"), }; void register_java_lang_reflect_Field(JNIEnv* env) { |