diff options
author | chibash <chiba@javassist.org> | 2015-07-15 15:45:22 +0900 |
---|---|---|
committer | chibash <chiba@javassist.org> | 2015-07-15 15:45:22 +0900 |
commit | ecd733a236b3963c36ad869e05d14d1f49e99a92 (patch) | |
tree | aaee0c11e59c0490f86e8e424c049aa9f65769c3 /src | |
parent | 11ef0b953e5e8fddf76fd4ab5fc1628fcbf1be1d (diff) | |
download | javassist-ecd733a236b3963c36ad869e05d14d1f49e99a92.tar.gz javassist-ecd733a236b3963c36ad869e05d14d1f49e99a92.zip |
fixed JIRA JASSIST-249
Diffstat (limited to 'src')
-rw-r--r-- | src/main/javassist/compiler/TypeChecker.java | 2 | ||||
-rw-r--r-- | src/test/javassist/JvstTest5.java | 9 | ||||
-rw-r--r-- | src/test/test5/BoolTest.java | 15 |
3 files changed, 25 insertions, 1 deletions
diff --git a/src/main/javassist/compiler/TypeChecker.java b/src/main/javassist/compiler/TypeChecker.java index d2814626..bd62f806 100644 --- a/src/main/javassist/compiler/TypeChecker.java +++ b/src/main/javassist/compiler/TypeChecker.java @@ -502,7 +502,7 @@ public class TypeChecker extends Visitor implements Opcode, TokenId { else insertCast(expr, type1, type2); - if (CodeGen.isP_INT(exprType)) + if (CodeGen.isP_INT(exprType) && exprType != BOOLEAN) exprType = INT; // type1 may be BYTE, ... } diff --git a/src/test/javassist/JvstTest5.java b/src/test/javassist/JvstTest5.java index fcbbbb99..cefc84fc 100644 --- a/src/test/javassist/JvstTest5.java +++ b/src/test/javassist/JvstTest5.java @@ -91,4 +91,13 @@ public class JvstTest5 extends JvstTestRoot { Object obj = make(cc.getName()); assertEquals(0, invoke(obj, "say")); } + + public void testJIRA249() throws Exception { + CtClass cc = sloader.get("test5.BoolTest"); + CtMethod testMethod = cc.getDeclaredMethod("test"); + testMethod.insertBefore("i = foo(true & true);"); + cc.writeFile(); + Object obj = make(cc.getName()); + assertEquals(1, invoke(obj, "run")); + } } diff --git a/src/test/test5/BoolTest.java b/src/test/test5/BoolTest.java new file mode 100644 index 00000000..0d9ca154 --- /dev/null +++ b/src/test/test5/BoolTest.java @@ -0,0 +1,15 @@ +package test5; + +public class BoolTest { + static boolean i = false; + public boolean test() { + return i; + } + public boolean foo(boolean b) { return b; } + public int run() { + if (test()) + return 1; + else + return 0; + } +} |