aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/javassist/compiler
diff options
context:
space:
mode:
authorchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2004-08-30 17:10:34 +0000
committerchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2004-08-30 17:10:34 +0000
commitf39d058e65fb1a8b53a965f3ef20b38337ccfd76 (patch)
tree593db80f17e810672b344e47e77099375e6658e1 /src/main/javassist/compiler
parentbe3a1d153f56e20dde215368b2f7cb5f98ea9370 (diff)
downloadjavassist-f39d058e65fb1a8b53a965f3ef20b38337ccfd76.tar.gz
javassist-f39d058e65fb1a8b53a965f3ef20b38337ccfd76.zip
implemented CtField#getConstantValue().
git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@128 30ef5769-5b8d-40dd-aea6-55b5d6557bb3
Diffstat (limited to 'src/main/javassist/compiler')
-rw-r--r--src/main/javassist/compiler/ast/CastExpr.java2
-rw-r--r--src/main/javassist/compiler/ast/CondExpr.java2
-rw-r--r--src/main/javassist/compiler/ast/DoubleConst.java54
-rw-r--r--src/main/javassist/compiler/ast/Expr.java4
-rw-r--r--src/main/javassist/compiler/ast/IntConst.java98
5 files changed, 160 insertions, 0 deletions
diff --git a/src/main/javassist/compiler/ast/CastExpr.java b/src/main/javassist/compiler/ast/CastExpr.java
index f390d943..06565b38 100644
--- a/src/main/javassist/compiler/ast/CastExpr.java
+++ b/src/main/javassist/compiler/ast/CastExpr.java
@@ -47,6 +47,8 @@ public class CastExpr extends ASTList implements TokenId {
public ASTree getOprand() { return getRight().getLeft(); }
+ public void setOprand(ASTree t) { getRight().setLeft(t); }
+
public String getTag() { return "cast:" + castType + ":" + arrayDim; }
public void accept(Visitor v) throws CompileError { v.atCastExpr(this); }
diff --git a/src/main/javassist/compiler/ast/CondExpr.java b/src/main/javassist/compiler/ast/CondExpr.java
index 5eb786f3..f20da602 100644
--- a/src/main/javassist/compiler/ast/CondExpr.java
+++ b/src/main/javassist/compiler/ast/CondExpr.java
@@ -27,6 +27,8 @@ public class CondExpr extends ASTList {
public ASTree condExpr() { return head(); }
+ public void setCond(ASTree t) { setHead(t); }
+
public ASTree thenExpr() { return tail().head(); }
public void setThen(ASTree t) { tail().setHead(t); }
diff --git a/src/main/javassist/compiler/ast/DoubleConst.java b/src/main/javassist/compiler/ast/DoubleConst.java
index b7063714..27de8878 100644
--- a/src/main/javassist/compiler/ast/DoubleConst.java
+++ b/src/main/javassist/compiler/ast/DoubleConst.java
@@ -16,6 +16,7 @@
package javassist.compiler.ast;
import javassist.compiler.CompileError;
+import javassist.compiler.TokenId;
/**
* Double constant.
@@ -28,6 +29,8 @@ public class DoubleConst extends ASTree {
public double get() { return value; }
+ public void set(double v) { value = v; }
+
/* Returns DoubleConstant or FloatConstant
*/
public int getType() { return type; }
@@ -37,4 +40,55 @@ public class DoubleConst extends ASTree {
public void accept(Visitor v) throws CompileError {
v.atDoubleConst(this);
}
+
+ public ASTree compute(int op, ASTree right) {
+ if (right instanceof IntConst)
+ return compute0(op, (IntConst)right);
+ else if (right instanceof DoubleConst)
+ return compute0(op, (DoubleConst)right);
+ else
+ return null;
+ }
+
+ private DoubleConst compute0(int op, DoubleConst right) {
+ int newType;
+ if (this.type == TokenId.DoubleConstant
+ || right.type == TokenId.DoubleConstant)
+ newType = TokenId.DoubleConstant;
+ else
+ newType = TokenId.FloatConstant;
+
+ return compute(op, this.value, right.value, newType);
+ }
+
+ private DoubleConst compute0(int op, IntConst right) {
+ return compute(op, this.value, (double)right.value, this.type);
+ }
+
+ private static DoubleConst compute(int op, double value1, double value2,
+ int newType)
+ {
+ double newValue;
+ switch (op) {
+ case '+' :
+ newValue = value1 + value2;
+ break;
+ case '-' :
+ newValue = value1 - value2;
+ break;
+ case '*' :
+ newValue = value1 * value2;
+ break;
+ case '/' :
+ newValue = value1 / value2;
+ break;
+ case '%' :
+ newValue = value1 % value2;
+ break;
+ default :
+ return null;
+ }
+
+ return new DoubleConst(newValue, newType);
+ }
}
diff --git a/src/main/javassist/compiler/ast/Expr.java b/src/main/javassist/compiler/ast/Expr.java
index 88fc09e6..aafe8a75 100644
--- a/src/main/javassist/compiler/ast/Expr.java
+++ b/src/main/javassist/compiler/ast/Expr.java
@@ -52,6 +52,10 @@ public class Expr extends ASTList implements TokenId {
public ASTree oprand1() { return getLeft(); }
+ public void setOprand1(ASTree expr) {
+ setLeft(expr);
+ }
+
public ASTree oprand2() { return getRight().getLeft(); }
public void setOprand2(ASTree expr) {
diff --git a/src/main/javassist/compiler/ast/IntConst.java b/src/main/javassist/compiler/ast/IntConst.java
index d90f1438..b6204e1f 100644
--- a/src/main/javassist/compiler/ast/IntConst.java
+++ b/src/main/javassist/compiler/ast/IntConst.java
@@ -16,6 +16,7 @@
package javassist.compiler.ast;
import javassist.compiler.CompileError;
+import javassist.compiler.TokenId;
/**
* Integer constant.
@@ -28,6 +29,8 @@ public class IntConst extends ASTree {
public long get() { return value; }
+ public void set(long v) { value = v; }
+
/* Returns IntConstant, CharConstant, or LongConstant.
*/
public int getType() { return type; }
@@ -37,4 +40,99 @@ public class IntConst extends ASTree {
public void accept(Visitor v) throws CompileError {
v.atIntConst(this);
}
+
+ public ASTree compute(int op, ASTree right) {
+ if (right instanceof IntConst)
+ return compute0(op, (IntConst)right);
+ else if (right instanceof DoubleConst)
+ return compute0(op, (DoubleConst)right);
+ else
+ return null;
+ }
+
+ private IntConst compute0(int op, IntConst right) {
+ int type1 = this.type;
+ int type2 = right.type;
+ int newType;
+ if (type1 == TokenId.LongConstant || type2 == TokenId.LongConstant)
+ newType = TokenId.LongConstant;
+ else if (type1 == TokenId.CharConstant
+ && type2 == TokenId.CharConstant)
+ newType = TokenId.CharConstant;
+ else
+ newType = TokenId.IntConstant;
+
+ long value1 = this.value;
+ long value2 = right.value;
+ long newValue;
+ switch (op) {
+ case '+' :
+ newValue = value1 + value2;
+ break;
+ case '-' :
+ newValue = value1 - value2;
+ break;
+ case '*' :
+ newValue = value1 * value2;
+ break;
+ case '/' :
+ newValue = value1 / value2;
+ break;
+ case '%' :
+ newValue = value1 % value2;
+ break;
+ case '|' :
+ newValue = value1 | value2;
+ break;
+ case '^' :
+ newValue = value1 ^ value2;
+ break;
+ case '&' :
+ newValue = value1 & value2;
+ break;
+ case TokenId.LSHIFT :
+ newValue = value << (int)value2;
+ newType = type1;
+ break;
+ case TokenId.RSHIFT :
+ newValue = value >> (int)value2;
+ newType = type1;
+ break;
+ case TokenId.ARSHIFT :
+ newValue = value >>> (int)value2;
+ newType = type1;
+ break;
+ default :
+ return null;
+ }
+
+ return new IntConst(newValue, newType);
+ }
+
+ private DoubleConst compute0(int op, DoubleConst right) {
+ double value1 = (double)this.value;
+ double value2 = right.value;
+ double newValue;
+ switch (op) {
+ case '+' :
+ newValue = value1 + value2;
+ break;
+ case '-' :
+ newValue = value1 - value2;
+ break;
+ case '*' :
+ newValue = value1 * value2;
+ break;
+ case '/' :
+ newValue = value1 / value2;
+ break;
+ case '%' :
+ newValue = value1 % value2;
+ break;
+ default :
+ return null;
+ }
+
+ return new DoubleConst(newValue, right.type);
+ }
}