aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2003-12-07 17:17:07 +0000
committerchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2003-12-07 17:17:07 +0000
commit2467ddfb2132c361d0b36315c17055606487368d (patch)
tree8b5efe8bb64008c7570420d0bdea4618e6b06b38
parentcdca9771599b4c3337aaf42cf7460a27dc1719d5 (diff)
downloadjavassist-2467ddfb2132c361d0b36315c17055606487368d.tar.gz
javassist-2467ddfb2132c361d0b36315c17055606487368d.zip
made the compiler support inner classes appearing in type names.
git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@56 30ef5769-5b8d-40dd-aea6-55b5d6557bb3
-rw-r--r--src/main/javassist/ClassPool.java4
-rw-r--r--src/main/javassist/ClassPoolTail.java4
-rw-r--r--src/main/javassist/CtClass.java9
-rw-r--r--src/main/javassist/CtNewConstructor.java5
-rw-r--r--src/main/javassist/compiler/MemberCodeGen.java23
-rw-r--r--src/main/javassist/compiler/MemberResolver.java70
-rw-r--r--src/main/javassist/compiler/TypeChecker.java21
7 files changed, 90 insertions, 46 deletions
diff --git a/src/main/javassist/ClassPool.java b/src/main/javassist/ClassPool.java
index d8fb2df6..cb1fb755 100644
--- a/src/main/javassist/ClassPool.java
+++ b/src/main/javassist/ClassPool.java
@@ -537,7 +537,7 @@ public class ClassPool {
void checkNotFrozen(String classname, String errmsg)
throws RuntimeException
{
- CtClass c = (CtClass)classes.get(classname);
+ CtClass c = getCached(classname);
if (c != null && c.isFrozen())
throw new RuntimeException(errmsg);
}
@@ -576,7 +576,7 @@ public class ClassPool {
public synchronized CtClass get(String classname)
throws NotFoundException
{
- CtClass clazz = (CtClass)classes.get(classname);
+ CtClass clazz = getCached(classname);
if (clazz == null) {
clazz = get0(classname);
classes.put(classname, clazz);
diff --git a/src/main/javassist/ClassPoolTail.java b/src/main/javassist/ClassPoolTail.java
index 0756cf44..5b013bf8 100644
--- a/src/main/javassist/ClassPoolTail.java
+++ b/src/main/javassist/ClassPoolTail.java
@@ -171,9 +171,7 @@ final class ClassPoolTail extends ClassPool {
throw new RuntimeException("fatal error");
}
- void checkClassName(String classname)
- throws NotFoundException
- {
+ void checkClassName(String classname) throws NotFoundException {
InputStream fin = openClassfile(classname);
try {
fin.close();
diff --git a/src/main/javassist/CtClass.java b/src/main/javassist/CtClass.java
index b51fcd87..44cf76ae 100644
--- a/src/main/javassist/CtClass.java
+++ b/src/main/javassist/CtClass.java
@@ -35,7 +35,7 @@ public abstract class CtClass {
/**
* The version number of this release.
*/
- public static final String version = "2.7 beta 3";
+ public static final String version = "2.7 beta 4";
/**
* Prints the version number and the copyright notice.
@@ -636,7 +636,7 @@ public abstract class CtClass {
}
/**
- * Makes a class initializer (static constructor).
+ * Makes an empty class initializer (static constructor).
* If the class already includes a class initializer,
* this method returns it.
*
@@ -649,7 +649,10 @@ public abstract class CtClass {
}
/**
- * Adds a constructor.
+ * Adds a constructor. To add a class initializer (static constructor),
+ * call <code>makeClassInitializer()</code>.
+ *
+ * @see #makeClassInitializer()
*/
public void addConstructor(CtConstructor c)
throws CannotCompileException
diff --git a/src/main/javassist/CtNewConstructor.java b/src/main/javassist/CtNewConstructor.java
index 49e7465a..b9c3114f 100644
--- a/src/main/javassist/CtNewConstructor.java
+++ b/src/main/javassist/CtNewConstructor.java
@@ -24,6 +24,11 @@ import javassist.CtMethod.ConstParameter;
* A collection of static methods for creating a <code>CtConstructor</code>.
* An instance of this class does not make any sense.
*
+ * <p>A class initializer (static constructor) cannot be created by the
+ * methods in this class. Call <code>makeClassInitializer()</code> in
+ * <code>CtClass</code> and append code snippet to the body of the class
+ * initializer obtained by <code>makeClassInitializer()</code>.
+ *
* @see CtClass#addConstructor(CtConstructor)
*/
public class CtNewConstructor {
diff --git a/src/main/javassist/compiler/MemberCodeGen.java b/src/main/javassist/compiler/MemberCodeGen.java
index e6983d21..8499dfb0 100644
--- a/src/main/javassist/compiler/MemberCodeGen.java
+++ b/src/main/javassist/compiler/MemberCodeGen.java
@@ -263,7 +263,7 @@ public class MemberCodeGen extends CodeGen {
int op = e.getOperator();
if (op == MEMBER) { // static method
targetClass
- = resolver.lookupClass(((Symbol)e.oprand1()).get());
+ = resolver.lookupClass(((Symbol)e.oprand1()).get(), false);
isStatic = true;
}
else if (op == '.') {
@@ -287,7 +287,7 @@ public class MemberCodeGen extends CodeGen {
}
if (arrayDim > 0)
- targetClass = resolver.lookupClass(javaLangObject);
+ targetClass = resolver.lookupClass(javaLangObject, true);
else if (exprType == CLASS /* && arrayDim == 0 */)
targetClass = resolver.lookupClassByJvmName(className);
else
@@ -618,6 +618,7 @@ public class MemberCodeGen extends CodeGen {
Expr e = (Expr)expr;
int op = e.getOperator();
if (op == MEMBER) {
+ // static member by # (extension by Javassist)
f = resolver.lookupField(((Symbol)e.oprand1()).get(),
(Symbol)e.oprand2());
is_static = true;
@@ -639,18 +640,14 @@ public class MemberCodeGen extends CodeGen {
if (nfe.getExpr() != e.oprand1())
throw nfe;
+ /* EXPR should be a static field.
+ * If EXPR might be part of a qualified class name,
+ * lookupFieldByJvmName2() throws NoFieldException.
+ */
Symbol fname = (Symbol)e.oprand2();
- // it should be a static field.
- try {
- f = resolver.lookupFieldByJvmName(nfe.getField(),
- fname);
- is_static = true;
- }
- catch (CompileError ce) {
- // EXPR might be part of a qualified class name.
- throw new NoFieldException(nfe.getField() + "/"
- + fname.get(), expr);
- }
+ f = resolver.lookupFieldByJvmName2(nfe.getField(),
+ fname, expr);
+ is_static = true;
}
}
else
diff --git a/src/main/javassist/compiler/MemberResolver.java b/src/main/javassist/compiler/MemberResolver.java
index a716fa92..a96f3e66 100644
--- a/src/main/javassist/compiler/MemberResolver.java
+++ b/src/main/javassist/compiler/MemberResolver.java
@@ -208,20 +208,40 @@ public class MemberResolver implements TokenId {
}
/**
+ * Only used by fieldAccess() in MemberCodeGen.
+ *
* @param jvmClassName a JVM class name. e.g. java/lang/String
*/
- public CtField lookupFieldByJvmName(String jvmClassName, Symbol fieldName)
- throws CompileError
+ public CtField lookupFieldByJvmName2(String jvmClassName, Symbol fieldSym,
+ ASTree expr) throws NoFieldException
{
- return lookupField(jvmToJavaName(jvmClassName), fieldName);
+ String field = fieldSym.get();
+ CtClass cc = null;
+ try {
+ cc = lookupClass(jvmToJavaName(jvmClassName), true);
+ }
+ catch (CompileError e) {
+ // EXPR might be part of a qualified class name.
+ throw new NoFieldException(jvmClassName + "/" + field, expr);
+ }
+
+ try {
+ return cc.getField(field);
+ }
+ catch (NotFoundException e) {
+ // maybe an inner class.
+ jvmClassName = javaToJvmName(cc.getName());
+ throw new NoFieldException(jvmClassName + "$" + field, expr);
+ }
}
- // never used??
- private CtField lookupField2(ASTList className, Symbol fieldName)
+ /**
+ * @param jvmClassName a JVM class name. e.g. java/lang/String
+ */
+ public CtField lookupFieldByJvmName(String jvmClassName, Symbol fieldName)
throws CompileError
{
- return lookupField(Declarator.astToClassName(className, '.'),
- fieldName);
+ return lookupField(jvmToJavaName(jvmClassName), fieldName);
}
/**
@@ -230,7 +250,7 @@ public class MemberResolver implements TokenId {
public CtField lookupField(String className, Symbol fieldName)
throws CompileError
{
- CtClass cc = lookupClass(className);
+ CtClass cc = lookupClass(className, false);
try {
return cc.getField(fieldName.get());
}
@@ -239,11 +259,11 @@ public class MemberResolver implements TokenId {
}
public CtClass lookupClassByName(ASTList name) throws CompileError {
- return lookupClass(Declarator.astToClassName(name, '.'));
+ return lookupClass(Declarator.astToClassName(name, '.'), false);
}
public CtClass lookupClassByJvmName(String jvmName) throws CompileError {
- return lookupClass(jvmToJavaName(jvmName));
+ return lookupClass(jvmToJavaName(jvmName), false);
}
public CtClass lookupClass(Declarator decl) throws CompileError {
@@ -302,15 +322,17 @@ public class MemberResolver implements TokenId {
while (dim-- > 0)
cname += "[]";
- return lookupClass(cname);
+ return lookupClass(cname, false);
}
/**
* @param name a qualified class name. e.g. java.lang.String
*/
- public CtClass lookupClass(String name) throws CompileError {
+ public CtClass lookupClass(String name, boolean notCheckInner)
+ throws CompileError
+ {
try {
- return classPool.get(name);
+ return lookupClass0(name, notCheckInner);
}
catch (NotFoundException e) {}
@@ -323,6 +345,28 @@ public class MemberResolver implements TokenId {
throw new CompileError("no such class: " + name);
}
+ private CtClass lookupClass0(String classname, boolean notCheckInner)
+ throws NotFoundException
+ {
+ CtClass cc = null;
+ do {
+ try {
+ cc = classPool.get(classname);
+ }
+ catch (NotFoundException e) {
+ int i = classname.lastIndexOf('.');
+ if (notCheckInner || i < 0)
+ throw e;
+ else {
+ StringBuffer sbuf = new StringBuffer(classname);
+ sbuf.setCharAt(i, '$');
+ classname = sbuf.toString();
+ }
+ }
+ } while (cc == null);
+ return cc;
+ }
+
/* Converts a class name into a JVM-internal representation.
*
* It may also expand a simple class name to java.lang.*.
diff --git a/src/main/javassist/compiler/TypeChecker.java b/src/main/javassist/compiler/TypeChecker.java
index c8024b90..602f6c02 100644
--- a/src/main/javassist/compiler/TypeChecker.java
+++ b/src/main/javassist/compiler/TypeChecker.java
@@ -441,7 +441,8 @@ public class TypeChecker extends Visitor implements Opcode, TokenId {
int op = e.getOperator();
if (op == MEMBER) // static method
targetClass
- = resolver.lookupClass(((Symbol)e.oprand1()).get());
+ = resolver.lookupClass(((Symbol)e.oprand1()).get(),
+ false);
else if (op == '.') {
ASTree target = e.oprand1();
try {
@@ -458,7 +459,7 @@ public class TypeChecker extends Visitor implements Opcode, TokenId {
}
if (arrayDim > 0)
- targetClass = resolver.lookupClass(javaLangObject);
+ targetClass = resolver.lookupClass(javaLangObject, true);
else if (exprType == CLASS /* && arrayDim == 0 */)
targetClass = resolver.lookupClassByJvmName(className);
else
@@ -610,17 +611,13 @@ public class TypeChecker extends Visitor implements Opcode, TokenId {
if (nfe.getExpr() != e.oprand1())
throw nfe;
+ /* EXPR should be a static field.
+ * If EXPR might be part of a qualified class name,
+ * lookupFieldByJvmName2() throws NoFieldException.
+ */
Symbol fname = (Symbol)e.oprand2();
- // it should be a static field.
- try {
- return resolver.lookupFieldByJvmName(nfe.getField(),
- fname);
- }
- catch (CompileError ce) {
- // EXPR might be part of a qualified class name.
- throw new NoFieldException(nfe.getField() + "/"
- + fname.get(), expr);
- }
+ return resolver.lookupFieldByJvmName2(nfe.getField(),
+ fname, expr);
}
}