diff options
-rw-r--r-- | src/main/javassist/CtClass.java | 5 | ||||
-rw-r--r-- | src/main/javassist/CtClassType.java | 1 | ||||
-rw-r--r-- | src/main/javassist/CtField.java | 39 |
3 files changed, 26 insertions, 19 deletions
diff --git a/src/main/javassist/CtClass.java b/src/main/javassist/CtClass.java index e7aafc26..e5033335 100644 --- a/src/main/javassist/CtClass.java +++ b/src/main/javassist/CtClass.java @@ -898,6 +898,11 @@ public abstract class CtClass { * <p>Here, the type of variable <code>cc</code> is <code>CtClass</code>. * The type of <code>f</code> is <code>CtField</code>. * + * <p>Note: do not change the modifier of the field + * (in particular, do not add or remove <code>static</code> + * to/from the modifier) + * after it is added to the class by <code>addField()</code>. + * * @param init an expression for the initial value. * * @see javassist.CtField.Initializer#byExpr(String) diff --git a/src/main/javassist/CtClassType.java b/src/main/javassist/CtClassType.java index d8182d10..13a2b871 100644 --- a/src/main/javassist/CtClassType.java +++ b/src/main/javassist/CtClassType.java @@ -1146,6 +1146,7 @@ class CtClassType extends CtClass { init = f.getInit(); if (init != null) { + init.check(f.getSignature()); int mod = f.getModifiers(); if (Modifier.isStatic(mod) && Modifier.isFinal(mod)) try { diff --git a/src/main/javassist/CtField.java b/src/main/javassist/CtField.java index ce9c6ddd..efc6b94b 100644 --- a/src/main/javassist/CtField.java +++ b/src/main/javassist/CtField.java @@ -413,13 +413,21 @@ public class CtField extends CtMember { public static abstract class Initializer { /** * Makes an initializer that assigns a constant integer value. - * The field must be integer type. + * The field must be integer, short, char, or byte type. */ public static Initializer constant(int i) { return new IntInitializer(i); } /** + * Makes an initializer that assigns a constant boolean value. + * The field must be boolean type. + */ + public static Initializer constant(boolean b) { + return new IntInitializer(b ? 1 : 0); + } + + /** * Makes an initializer that assigns a constant long value. * The field must be long type. */ @@ -751,7 +759,7 @@ public class CtField extends CtMember { // Check whether this initializer is valid for the field type. // If it is invaild, this method throws an exception. - void check(CtClass type) throws CannotCompileException {} + void check(String desc) throws CannotCompileException {} // produce codes for initialization abstract int compile(CtClass type, String name, Bytecode code, @@ -1100,8 +1108,9 @@ public class CtField extends CtMember { IntInitializer(int v) { value = v; } - void check(CtClass type) throws CannotCompileException { - if (type != CtClass.intType) + void check(String desc) throws CannotCompileException { + char c = desc.charAt(0); + if (c != 'I' && c != 'S' && c != 'B' && c != 'C' && c != 'Z') throw new CannotCompileException("type mismatch"); } @@ -1124,10 +1133,7 @@ public class CtField extends CtMember { } int getConstantValue(ConstPool cp, CtClass type) { - if (type == CtClass.intType) - return cp.addIntegerInfo(value); - else - return 0; + return cp.addIntegerInfo(value); } } @@ -1136,8 +1142,8 @@ public class CtField extends CtMember { LongInitializer(long v) { value = v; } - void check(CtClass type) throws CannotCompileException { - if (type != CtClass.longType) + void check(String desc) throws CannotCompileException { + if (!desc.equals("J")) throw new CannotCompileException("type mismatch"); } @@ -1172,8 +1178,8 @@ public class CtField extends CtMember { DoubleInitializer(double v) { value = v; } - void check(CtClass type) throws CannotCompileException { - if (type != CtClass.doubleType) + void check(String desc) throws CannotCompileException { + if (!desc.equals("D")) throw new CannotCompileException("type mismatch"); } @@ -1208,11 +1214,6 @@ public class CtField extends CtMember { StringInitializer(String v) { value = v; } - void check(CtClass type) throws CannotCompileException { - if (!type.getName().equals(javaLangString)) - throw new CannotCompileException("type mismatch"); - } - int compile(CtClass type, String name, Bytecode code, CtClass[] parameters, Javac drv) throws CannotCompileException @@ -1278,8 +1279,8 @@ public class CtField extends CtMember { MultiArrayInitializer(CtClass t, int[] d) { type = t; dim = d; } - void check(CtClass type) throws CannotCompileException { - if (!type.isArray()) + void check(String desc) throws CannotCompileException { + if (desc.charAt(0) != '[') throw new CannotCompileException("type mismatch"); } |