Field.java (toString): Use Method.appendClassName.
* java/lang/reflect/Field.java (toString): Use Method.appendClassName. * java/lang/reflect/Constructor.java (toString): Use Method.appendClassName. * java/lang/reflect/Method.java: Reindented. (appendClassName): New method. (toString): Use it. * defineclass.cc (handleMethod ): Initialize `throws' field of method. (read_one_method_attribute): Handle Exceptions attribute. * java/lang/reflect/natMethod.cc (ClassClass): Removed. (ObjectClass): Removed. (getType): Compute `exception_types'. * java/lang/Class.h (struct _Jv_Method): Added `throws' field. From-SVN: r45153
This commit is contained in:
parent
66b461ce02
commit
224b7b7b0c
8 changed files with 166 additions and 78 deletions
|
@ -25,24 +25,24 @@ import gnu.gcj.RawData;
|
|||
public final class Method extends AccessibleObject implements Member
|
||||
{
|
||||
public boolean equals (Object obj)
|
||||
{
|
||||
if (! (obj instanceof Method))
|
||||
return false;
|
||||
Method m = (Method) obj;
|
||||
return declaringClass == m.declaringClass && offset == m.offset;
|
||||
}
|
||||
{
|
||||
if (! (obj instanceof Method))
|
||||
return false;
|
||||
Method m = (Method) obj;
|
||||
return declaringClass == m.declaringClass && offset == m.offset;
|
||||
}
|
||||
|
||||
public Class getDeclaringClass ()
|
||||
{
|
||||
return declaringClass;
|
||||
}
|
||||
{
|
||||
return declaringClass;
|
||||
}
|
||||
|
||||
public Class[] getExceptionTypes ()
|
||||
{
|
||||
if (exception_types == null)
|
||||
getType();
|
||||
return (Class[]) exception_types.clone();
|
||||
}
|
||||
{
|
||||
if (exception_types == null)
|
||||
getType();
|
||||
return (Class[]) exception_types.clone();
|
||||
}
|
||||
|
||||
public native int getModifiers ();
|
||||
|
||||
|
@ -51,62 +51,82 @@ public final class Method extends AccessibleObject implements Member
|
|||
private native void getType ();
|
||||
|
||||
public Class[] getParameterTypes ()
|
||||
{
|
||||
if (parameter_types == null)
|
||||
getType();
|
||||
return (Class[]) parameter_types.clone();
|
||||
}
|
||||
{
|
||||
if (parameter_types == null)
|
||||
getType();
|
||||
return (Class[]) parameter_types.clone();
|
||||
}
|
||||
|
||||
public Class getReturnType ()
|
||||
{
|
||||
if (return_type == null)
|
||||
getType();
|
||||
return return_type;
|
||||
}
|
||||
{
|
||||
if (return_type == null)
|
||||
getType();
|
||||
return return_type;
|
||||
}
|
||||
|
||||
public int hashCode ()
|
||||
{
|
||||
// FIXME.
|
||||
return getName().hashCode() + declaringClass.getName().hashCode();
|
||||
}
|
||||
{
|
||||
// FIXME.
|
||||
return getName().hashCode() + declaringClass.getName().hashCode();
|
||||
}
|
||||
|
||||
public native Object invoke (Object obj, Object[] args)
|
||||
throws IllegalAccessException, IllegalArgumentException,
|
||||
InvocationTargetException;
|
||||
InvocationTargetException;
|
||||
|
||||
// Append a class name to a string buffer. We try to print the
|
||||
// fully-qualified name, the way that a Java programmer would expect
|
||||
// it to be written. Weirdly, Class has no appropriate method for
|
||||
// this.
|
||||
static void appendClassName (StringBuffer buf, Class k)
|
||||
{
|
||||
if (k.isArray ())
|
||||
{
|
||||
appendClassName (buf, k.getComponentType ());
|
||||
buf.append ("[]");
|
||||
}
|
||||
else
|
||||
{
|
||||
// This is correct for primitive and reference types. Really
|
||||
// we'd like `Main$Inner' to be printed as `Main.Inner', I
|
||||
// think, but that is a pain.
|
||||
buf.append (k.getName ());
|
||||
}
|
||||
}
|
||||
|
||||
public String toString ()
|
||||
{
|
||||
if (parameter_types == null)
|
||||
getType ();
|
||||
{
|
||||
if (parameter_types == null)
|
||||
getType ();
|
||||
|
||||
StringBuffer b = new StringBuffer ();
|
||||
Modifier.toString(getModifiers(), b);
|
||||
b.append(" ");
|
||||
b.append(return_type.getName());
|
||||
b.append(" ");
|
||||
b.append(declaringClass.getName());
|
||||
b.append(".");
|
||||
b.append(getName());
|
||||
b.append("(");
|
||||
for (int i = 0; i < parameter_types.length; ++i)
|
||||
{
|
||||
b.append(parameter_types[i].getName());
|
||||
if (i < parameter_types.length - 1)
|
||||
b.append(",");
|
||||
}
|
||||
b.append(")");
|
||||
if (exception_types.length > 0)
|
||||
{
|
||||
b.append(" throws ");
|
||||
for (int i = 0; i < exception_types.length; ++i)
|
||||
{
|
||||
b.append(exception_types[i].getName());
|
||||
if (i < exception_types.length - 1)
|
||||
b.append(",");
|
||||
}
|
||||
}
|
||||
return b.toString();
|
||||
}
|
||||
StringBuffer b = new StringBuffer ();
|
||||
Modifier.toString(getModifiers(), b);
|
||||
b.append(" ");
|
||||
appendClassName (b, return_type);
|
||||
b.append(" ");
|
||||
appendClassName (b, declaringClass);
|
||||
b.append(".");
|
||||
b.append(getName());
|
||||
b.append("(");
|
||||
for (int i = 0; i < parameter_types.length; ++i)
|
||||
{
|
||||
appendClassName (b, parameter_types[i]);
|
||||
if (i < parameter_types.length - 1)
|
||||
b.append(",");
|
||||
}
|
||||
b.append(")");
|
||||
if (exception_types.length > 0)
|
||||
{
|
||||
b.append(" throws ");
|
||||
for (int i = 0; i < exception_types.length; ++i)
|
||||
{
|
||||
appendClassName (b, exception_types[i]);
|
||||
if (i < exception_types.length - 1)
|
||||
b.append(",");
|
||||
}
|
||||
}
|
||||
return b.toString();
|
||||
}
|
||||
|
||||
private Method ()
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue