: m instanceof Type.Class.Method ? CONSTANT_METHODREF
: 0;
if (tag == 0) throw new Error("should never happen");
- ent = new MemberEnt(tag, m.getDeclaringClass(), m.name, m.getDescriptor());
+ ent = new MemberEnt(tag, m.getDeclaringClass(), m.name, m.getTypeDescriptor());
}
else {
throw new IllegalArgumentException("Unknown type passed to add");
*/
void finish(ConstantPool cp) {
cp.addUtf8(method.name);
- cp.addUtf8(method.getDescriptor());
+ cp.addUtf8(method.getTypeDescriptor());
for(Enumeration e = thrownExceptions.keys();e.hasMoreElements();)
cp.add(e.nextElement());
o.writeShort(flags);
o.writeShort(cp.getUtf8Index(method.name));
- o.writeShort(cp.getUtf8Index(method.getDescriptor()));
+ o.writeShort(cp.getUtf8Index(method.getTypeDescriptor()));
attrs.dump(o,cp);
}
private Member(String name) { this.name = name; }
public Type.Class getDeclaringClass() { return Type.Class.this; }
public abstract String getDescriptor();
+ public boolean equals(Object o_) {
+ if(!(o_ instanceof Member)) return false;
+ Member o = (Member) o_;
+ return o.getDeclaringClass().equals(getDeclaringClass()) &&
+ o.name.equals(name) &&
+ o.getDescriptor().equals(getDescriptor());
+ }
+ public int hashCode() { return getDeclaringClass().hashCode() ^ name.hashCode() ^ getDescriptor().hashCode(); }
public String toString() { return debugToString(); }
public abstract String debugToString();
}
public class Field extends Member {
public final Type type;
private Field(String name, Type t) { super(name); this.type = t; }
- public String getDescriptor() { return type.getDescriptor(); }
+ public String getTypeDescriptor() { return type.getDescriptor(); }
public Type getType() { return type; }
public String debugToString() { return getDeclaringClass()+"."+name+"["+type+"]"; }
public class Body extends HasFlags {
this.argTypes = argTypes;
this.returnType = returnType;
}
- //public Method.Body getBody(Context cx) { }
public String getDescriptor() {
StringBuffer sb = new StringBuffer(argTypes.length*4);
sb.append("(");