aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/javassist/compiler
diff options
context:
space:
mode:
authorchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2003-07-08 02:20:59 +0000
committerchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2003-07-08 02:20:59 +0000
commit5a846bbe359bb0ff658d79e31c319276e47da4e9 (patch)
treea22efbdb289fcea2f9b9a645c137550149a93b91 /src/main/javassist/compiler
parent5372926c9102cd4fbc16bb8297bd80c50f3d8ab6 (diff)
downloadjavassist-5a846bbe359bb0ff658d79e31c319276e47da4e9.tar.gz
javassist-5a846bbe359bb0ff658d79e31c319276e47da4e9.zip
minor bugs have been fixed.
git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@27 30ef5769-5b8d-40dd-aea6-55b5d6557bb3
Diffstat (limited to 'src/main/javassist/compiler')
-rw-r--r--src/main/javassist/compiler/CodeGen.java4
-rw-r--r--src/main/javassist/compiler/Javac.java6
2 files changed, 9 insertions, 1 deletions
diff --git a/src/main/javassist/compiler/CodeGen.java b/src/main/javassist/compiler/CodeGen.java
index d0009429..9d6f7690 100644
--- a/src/main/javassist/compiler/CodeGen.java
+++ b/src/main/javassist/compiler/CodeGen.java
@@ -250,6 +250,10 @@ public abstract class CodeGen extends Visitor implements Opcode, TokenId {
method.getReturn().getType() == VOID);
}
+ /**
+ * @param isCons true if super() must be called.
+ * false if the method is a class initializer.
+ */
public void atMethodBody(Stmnt s, boolean isCons, boolean isVoid)
throws CompileError
{
diff --git a/src/main/javassist/compiler/Javac.java b/src/main/javassist/compiler/Javac.java
index 491cff45..45d370bb 100644
--- a/src/main/javassist/compiler/Javac.java
+++ b/src/main/javassist/compiler/Javac.java
@@ -200,7 +200,11 @@ public class Javac {
Parser p = new Parser(new Lex(src));
SymbolTable stb = new SymbolTable(stable);
Stmnt s = p.parseStatement(stb);
- gen.atMethodBody(s, method instanceof CtConstructor, isVoid);
+ boolean callSuper = false;
+ if (method instanceof CtConstructor)
+ callSuper = !((CtConstructor)method).isClassInitializer();
+
+ gen.atMethodBody(s, callSuper, isVoid);
}
return bytecode;