/** Class generation object representing the whole classfile */
public class ClassFile extends Type.Class.Body {
private final Type.Class thisType;
- private final Type.Class superType;
- private final Type.Class[] interfaces;
+ final Type.Class superType;
+ final Type.Class[] interfaces;
private final short minor;
private final short major;
private final Vector fields = new Vector();
- public final Vector methods = new Vector();
+ private final Vector methods = new Vector();
+
+ public Type.Class.Method.Body[] methods() {
+ Type.Class.Method.Body[] ret = new Type.Class.Method.Body[methods.size()];
+ methods.copyInto(ret);
+ return ret;
+ }
+
+ public Type.Class.Field.Body[] fields() {
+ Type.Class.Field.Body[] ret = new Type.Class.Field.Body[fields.size()];
+ fields.copyInto(ret);
+ return ret;
+ }
static String flagsToString(int flags, boolean isClass) {
StringBuffer sb = new StringBuffer(32);
public Type.Class getType() { return thisType; }
public int getFlags() { return flags; }
- String debugToString() { return debugToString(new StringBuffer(4096)).toString(); }
- StringBuffer debugToString(StringBuffer sb) {
+ public String toString() { return toString(new StringBuffer(4096)).toString(); }
+ StringBuffer toString(StringBuffer sb) {
sb.append(flagsToString(flags,true));
sb.append((flags & INTERFACE) != 0 ? "interface " : "class ");
- sb.append(thisType.debugToString());
- if (superType != null) sb.append(" extends " + superType.debugToString());
+ sb.append(thisType.toString());
+ if (superType != null) sb.append(" extends " + superType.toString());
if (interfaces != null && interfaces.length > 0) sb.append(" implements");
- for(int i=0; i<interfaces.length; i++) sb.append((i==0?" ":", ")+interfaces[i].debugToString());
+ for(int i=0; i<interfaces.length; i++) sb.append((i==0?" ":", ")+interfaces[i].toString());
sb.append(" {");
sb.append(" // v"+major+"."+minor);
ConstantPool.Utf8Key sourceFile = (ConstantPool.Utf8Key) attrs.get("SourceFile");
sb.append("\n");
for(int i=0; i<fields.size(); i++) {
sb.append(" ");
- ((FieldGen)fields.elementAt(i)).debugToString(sb);
+ ((FieldGen)fields.elementAt(i)).toString(sb);
sb.append("\n");
}
for(int i=0; i<methods.size(); i++) {
- ((MethodGen)methods.elementAt(i)).debugToString(sb,thisType.getShortName());
+ ((MethodGen)methods.elementAt(i)).toString(sb,thisType.getShortName());
sb.append("\n");
}
sb.append("}");
@see CGConst
*/
public final MethodGen addMethod(String name, Type ret, Type[] args, int flags) {
- MethodGen mg = new MethodGen(getType().method(name, ret, args), flags);
+ return addMethod(getType().method(name, ret, args),flags);
+ }
+ public final MethodGen addMethod(Type.Class.Method method,int flags) {
+ MethodGen mg = new MethodGen(method, flags);
+ methods.addElement(mg);
+ return mg;
+ }
+ public final MethodGen addMethod(Type.Class.Method m, int flags) {
+ MethodGen mg = new MethodGen(m, flags);
methods.addElement(mg);
return mg;
}
@see CGConst
*/
public final FieldGen addField(String name, Type type, int flags) {
- FieldGen fg = new FieldGen(getType().field(name, type), flags);
+ return addField(getType().field(name,type),flags);
+ }
+ public final FieldGen addField(Type.Class.Field field, int flags) {
+ FieldGen fg = new FieldGen(field , flags);
fields.addElement(fg);
return fg;
}
}
else if (args.length==1) {
if (args[0].endsWith(".class")) {
- System.out.println(new ClassFile(new DataInputStream(new FileInputStream(args[0]))).debugToString());
+ System.out.println(new ClassFile(new DataInputStream(new FileInputStream(args[0]))).toString());
} else {
InputStream is = Class.forName(args[0]).getClassLoader().getResourceAsStream(args[0].replace('.', '/')+".class");
- System.out.println(new ClassFile(new DataInputStream(is)).debugToString());
+ System.out.println(new ClassFile(new DataInputStream(is)).toString());
}
} else {
/*