[multiple changes]
2005-02-21 Bryce McKinlay <mckinlay@redhat.com> Merge serialization from GNU Classpath. * gcj/method.h: Add missing #includes. * java/io/ObjectInputStream.java (readClassDescriptor): Check for primitive class IDs on the stream here... (resolveClass): ...not here. * java/io/ObjectStreamField.java: Use VMObjectStream class calls to set fields. * java/io/VMObjectStreamClass.java (setDoubleNative, setFloatNative, setLongNative, setIntNative, setShortNative, setCharNative, setByteNative, setBooleanNative, setObjectNative): New native methods. * java/io/natVMObjectStreamClass.java (setDoubleNative, setFloatNative, setLongNative, setIntNative, setShortNative, setCharNative, setByteNative, setBooleanNative, setObjectNative): Implement them. * java/io/natObjectInputStream.cc (allocateObject): Add new parameters from Classpath's version. Use _Jv_FromReflectedConstructor(). Call the constructor here. (callConstructor): Removed. (getCallersClassLoader): Removed. * java/lang/reflect/Field.java (setByte, setShort, setInt, setLong, setFloat, setDouble, setChar, setBoolean): Add 'checkFinal' parameter to control whether setting final field values is permitted. Call getAddr() with checkFinal parameter instead of setAddr(). * java/lang/reflect/natField.cc (getType): Lookup and resolve field only if not done already. (getAddr): Add checkFinal parameter. Do the final field check only if checkFinal is set. (setAddr): Removed. 2005-02-21 Mark Wielaard <mark@klomp.org> # Fixes bug #11957 * java/io/ObjectInputStream.java (resolveClass): Don't check "void" twice. 2005-02-21 Mark Wielaard <mark@klomp.org> Fixes bug #11618. * java/io/ObjectInputStream.java (readClassDescriptor): Handle classes without a super class and us ObjectStreamClass.lookupForClassObject(). (resolveClass): Check for primitive types. (lookupClass): Return null when argument is null. 2005-02-21 Jeroen Frijters <jeroen@frijters.net> * java/io/ObjectInputStream.java (readObject): Fix to consume TC_ENDBLOCKDATA after readExternal. 2005-02-21 Jeroen Frijters <jeroen@frijters.net> * java/io/ObjectOutputStream.java (writeObject, callWriteMethod): Replaced reflection with accessing cached info in ObjectStreamClass. (getMethod): Removed. * java/io/ObjectStreamClass.java (findMethod): Added check to make sure the method found has the right modifiers. (cacheMethods): Added writeReplace and writeObject methods. (setFlags): Look at new writeObjectMethod field instead of doing reflection again. (writeReplaceMethod): New field. (writeObjectMethod): New field. 2005-02-21 Guilhem Lavaux <guilhem@kaffe.org> Jeroen Frijters <jeroen@frijters.net> * java/io/ObjectInputStream.java (newObject): Changed prototype. Get a constructor reflect object directly. (callConstructor): Removed. (allocateObject): Changed prototype. (readClassDescriptor): Build the constructor reflection directly. (readObject): Invoke newObject using the new prototype. * java/io/ObjectStreamClass.java (firstNonSerializableParent): Removed. (firstNonSerializableParentConstructor): Added. From-SVN: r95378
This commit is contained in:
parent
bb2e164049
commit
f4294557b7
10 changed files with 454 additions and 255 deletions
|
@ -23,6 +23,9 @@ public final class Field extends AccessibleObject implements Member
|
|||
// Offset in bytes from the start of declaringClass's fields array.
|
||||
private int offset;
|
||||
|
||||
// The Class (or primitive TYPE) of this field.
|
||||
private Class type;
|
||||
|
||||
// This is instantiated by Class sometimes, but it uses C++ and
|
||||
// avoids the Java protection check.
|
||||
Field ()
|
||||
|
@ -136,76 +139,79 @@ public final class Field extends AccessibleObject implements Member
|
|||
public void setByte (Object obj, byte b)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setByte(null, obj, b);
|
||||
setByte(null, obj, b, true);
|
||||
}
|
||||
|
||||
public void setShort (Object obj, short s)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setShort(null, obj, s);
|
||||
setShort(null, obj, s, true);
|
||||
}
|
||||
|
||||
public void setInt (Object obj, int i)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setInt(null, obj, i);
|
||||
setInt(null, obj, i, true);
|
||||
}
|
||||
|
||||
public void setLong (Object obj, long l)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setLong(null, obj, l);
|
||||
setLong(null, obj, l, true);
|
||||
}
|
||||
|
||||
public void setFloat (Object obj, float f)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setFloat(null, obj, f);
|
||||
setFloat(null, obj, f, true);
|
||||
}
|
||||
|
||||
public void setDouble (Object obj, double d)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setDouble(null, obj, d);
|
||||
setDouble(null, obj, d, true);
|
||||
}
|
||||
|
||||
public void setChar (Object obj, char c)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setChar(null, obj, c);
|
||||
setChar(null, obj, c, true);
|
||||
}
|
||||
|
||||
public void setBoolean (Object obj, boolean b)
|
||||
throws IllegalArgumentException, IllegalAccessException
|
||||
{
|
||||
setBoolean(null, obj, b);
|
||||
setBoolean(null, obj, b, true);
|
||||
}
|
||||
|
||||
private native void setByte (Class caller, Object obj, byte b)
|
||||
native void setByte (Class caller, Object obj, byte b, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setShort (Class caller, Object obj, short s)
|
||||
native void setShort (Class caller, Object obj, short s, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setInt (Class caller, Object obj, int i)
|
||||
native void setInt (Class caller, Object obj, int i, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setLong (Class caller, Object obj, long l)
|
||||
native void setLong (Class caller, Object obj, long l, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setFloat (Class caller, Object obj, float f)
|
||||
native void setFloat (Class caller, Object obj, float f, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setDouble (Class caller, Object obj, double d)
|
||||
native void setDouble (Class caller, Object obj, double d,
|
||||
boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setChar (Class caller, Object obj, char c)
|
||||
native void setChar (Class caller, Object obj, char c, boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void setBoolean (Class caller, Object obj, boolean b)
|
||||
native void setBoolean (Class caller, Object obj, boolean b,
|
||||
boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
private native void set (Class caller, Object obj, Object val, Class type)
|
||||
native void set (Class caller, Object obj, Object val, Class type,
|
||||
boolean checkFinal)
|
||||
throws IllegalArgumentException, IllegalAccessException;
|
||||
|
||||
public void set (Object object, Object value)
|
||||
|
@ -219,23 +225,23 @@ public final class Field extends AccessibleObject implements Member
|
|||
{
|
||||
Class type = getType();
|
||||
if (! type.isPrimitive())
|
||||
set(caller, object, value, type);
|
||||
set(caller, object, value, type, true);
|
||||
else if (value instanceof Byte)
|
||||
setByte(caller, object, ((Byte) value).byteValue());
|
||||
setByte(caller, object, ((Byte) value).byteValue(), true);
|
||||
else if (value instanceof Short)
|
||||
setShort (caller, object, ((Short) value).shortValue());
|
||||
setShort (caller, object, ((Short) value).shortValue(), true);
|
||||
else if (value instanceof Integer)
|
||||
setInt(caller, object, ((Integer) value).intValue());
|
||||
setInt(caller, object, ((Integer) value).intValue(), true);
|
||||
else if (value instanceof Long)
|
||||
setLong(caller, object, ((Long) value).longValue());
|
||||
setLong(caller, object, ((Long) value).longValue(), true);
|
||||
else if (value instanceof Float)
|
||||
setFloat(caller, object, ((Float) value).floatValue());
|
||||
setFloat(caller, object, ((Float) value).floatValue(), true);
|
||||
else if (value instanceof Double)
|
||||
setDouble(caller, object, ((Double) value).doubleValue());
|
||||
setDouble(caller, object, ((Double) value).doubleValue(), true);
|
||||
else if (value instanceof Character)
|
||||
setChar(caller, object, ((Character) value).charValue());
|
||||
setChar(caller, object, ((Character) value).charValue(), true);
|
||||
else if (value instanceof Boolean)
|
||||
setBoolean(caller, object, ((Boolean) value).booleanValue());
|
||||
setBoolean(caller, object, ((Boolean) value).booleanValue(), true);
|
||||
else
|
||||
throw new IllegalArgumentException();
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue