aboutsummaryrefslogtreecommitdiffstats
path: root/bcel-builder
diff options
context:
space:
mode:
Diffstat (limited to 'bcel-builder')
-rw-r--r--bcel-builder/src/org/aspectj/apache/bcel/classfile/GenericSignatureParser.java5
-rw-r--r--bcel-builder/src/org/aspectj/apache/bcel/classfile/Signature.java6
-rw-r--r--bcel-builder/testsrc/org/aspectj/apache/bcel/classfile/tests/GenericSignatureParserTest.java91
3 files changed, 98 insertions, 4 deletions
diff --git a/bcel-builder/src/org/aspectj/apache/bcel/classfile/GenericSignatureParser.java b/bcel-builder/src/org/aspectj/apache/bcel/classfile/GenericSignatureParser.java
index 775a8b930..230a055c1 100644
--- a/bcel-builder/src/org/aspectj/apache/bcel/classfile/GenericSignatureParser.java
+++ b/bcel-builder/src/org/aspectj/apache/bcel/classfile/GenericSignatureParser.java
@@ -163,7 +163,6 @@ public class GenericSignatureParser {
private ArrayTypeSignature parseArrayTypeSignature() {
// opening [ already eaten
- eat("["); // grammar adds another one!
FieldTypeSignature fieldType = parseFieldTypeSignature(true);
if (fieldType != null) {
return new ArrayTypeSignature(fieldType);
@@ -273,6 +272,7 @@ public class GenericSignatureParser {
}
private boolean maybeEat(String token) {
+ if (tokenStream.length <= tokenIndex) return false;
if (tokenStream[tokenIndex].equals(token)) {
tokenIndex++;
return true;
@@ -329,6 +329,8 @@ public class GenericSignatureParser {
tokens.add(";");
break;
case '^':
+ if (identifier.length() > 0) tokens.add(identifier.toString());
+ identifier = new StringBuffer();
tokens.add("^");
break;
case '+':
@@ -350,6 +352,7 @@ public class GenericSignatureParser {
break;
case ')' :
tokens.add(")");
+ break;
case '[' :
tokens.add("[");
break;
diff --git a/bcel-builder/src/org/aspectj/apache/bcel/classfile/Signature.java b/bcel-builder/src/org/aspectj/apache/bcel/classfile/Signature.java
index c1546fac2..672b1171c 100644
--- a/bcel-builder/src/org/aspectj/apache/bcel/classfile/Signature.java
+++ b/bcel-builder/src/org/aspectj/apache/bcel/classfile/Signature.java
@@ -71,7 +71,7 @@ import org.aspectj.apache.bcel.Constants;
* This class is derived from <em>Attribute</em> and represents a reference
* to a <href="http://wwwipd.ira.uka.de/~pizza/gj/">GJ</a> attribute.
*
- * @version $Id: Signature.java,v 1.4 2005/07/01 09:10:45 acolyer Exp $
+ * @version $Id: Signature.java,v 1.5 2005/07/01 11:29:54 acolyer Exp $
* @author <A HREF="mailto:markus.dahm@berlin.de">M. Dahm</A>
* @see Attribute
*/
@@ -457,7 +457,7 @@ public final class Signature extends Attribute {
}
}
- static class TypeVariableSignature extends FieldTypeSignature {
+ public static class TypeVariableSignature extends FieldTypeSignature {
public String typeVariableName;
public TypeVariableSignature(String typeVarToken) {
this.typeVariableName = typeVarToken.substring(1);
@@ -468,7 +468,7 @@ public final class Signature extends Attribute {
}
}
- static class ArrayTypeSignature extends FieldTypeSignature {
+ public static class ArrayTypeSignature extends FieldTypeSignature {
public TypeSignature typeSig;
public ArrayTypeSignature(TypeSignature aTypeSig) {
this.typeSig = aTypeSig;
diff --git a/bcel-builder/testsrc/org/aspectj/apache/bcel/classfile/tests/GenericSignatureParserTest.java b/bcel-builder/testsrc/org/aspectj/apache/bcel/classfile/tests/GenericSignatureParserTest.java
index e4d97a818..9833a309c 100644
--- a/bcel-builder/testsrc/org/aspectj/apache/bcel/classfile/tests/GenericSignatureParserTest.java
+++ b/bcel-builder/testsrc/org/aspectj/apache/bcel/classfile/tests/GenericSignatureParserTest.java
@@ -1,13 +1,18 @@
package org.aspectj.apache.bcel.classfile.tests;
+
import org.aspectj.apache.bcel.classfile.GenericSignatureParser;
import org.aspectj.apache.bcel.classfile.JavaClass;
+import org.aspectj.apache.bcel.classfile.Method;
+import org.aspectj.apache.bcel.classfile.Signature;
import org.aspectj.apache.bcel.classfile.Signature.ClassSignature;
import org.aspectj.apache.bcel.classfile.Signature.ClassTypeSignature;
import org.aspectj.apache.bcel.classfile.Signature.FieldTypeSignature;
import org.aspectj.apache.bcel.classfile.Signature.SimpleClassTypeSignature;
import org.aspectj.apache.bcel.util.SyntheticRepository;
+import sun.reflect.generics.scope.MethodScope;
+
import junit.framework.TestCase;
public class GenericSignatureParserTest extends TestCase {
@@ -117,6 +122,92 @@ public class GenericSignatureParserTest extends TestCase {
assertEquals("Ljava/lang/String;",fsig.toString());
}
+ public void testFieldSignatureParsingArrayType() {
+ FieldTypeSignature fsig = parser.parseAsFieldSignature("[Ljava/lang/String;");
+ assertTrue("ArrayTypeSignature", fsig instanceof Signature.ArrayTypeSignature);
+ assertEquals("[Ljava/lang/String;",fsig.toString());
+ }
+
+ public void testFieldSignatureParsingTypeVariable() {
+ FieldTypeSignature fsig = parser.parseAsFieldSignature("TT;");
+ assertTrue("TypeVariableSignature",fsig instanceof Signature.TypeVariableSignature);
+ assertEquals("TT;",fsig.toString());
+ }
+
+ public void testSimpleMethodSignatureParsing() {
+ Signature.MethodTypeSignature mSig = parser.parseAsMethodSignature("()V");
+ assertEquals("No type parameters",0,mSig.formalTypeParameters.length);
+ assertEquals("No parameters",0,mSig.parameters.length);
+ assertEquals("Void return type","V",mSig.returnType.toString());
+ assertEquals("No throws",0,mSig.throwsSignatures.length);
+ }
+
+ public void testMethodSignatureTypeParams() {
+ Signature.MethodTypeSignature mSig = parser.parseAsMethodSignature("<T:>(TT;)V");
+ assertEquals("One type parameter",1,mSig.formalTypeParameters.length);
+ assertEquals("T",mSig.formalTypeParameters[0].identifier);
+ assertEquals("Ljava/lang/Object;",mSig.formalTypeParameters[0].classBound.toString());
+ assertEquals("One parameter",1,mSig.parameters.length);
+ assertEquals("TT;",mSig.parameters[0].toString());
+ assertEquals("Void return type","V",mSig.returnType.toString());
+ assertEquals("No throws",0,mSig.throwsSignatures.length);
+ }
+
+ public void testMethodSignatureGenericReturn() {
+ Signature.MethodTypeSignature mSig = parser.parseAsMethodSignature("<T:>()TT;");
+ assertEquals("One type parameter",1,mSig.formalTypeParameters.length);
+ assertEquals("T",mSig.formalTypeParameters[0].identifier);
+ assertEquals("Ljava/lang/Object;",mSig.formalTypeParameters[0].classBound.toString());
+ assertEquals("No parameters",0,mSig.parameters.length);
+ assertEquals("'T' return type","TT;",mSig.returnType.toString());
+ assertEquals("No throws",0,mSig.throwsSignatures.length);
+ }
+
+ public void testMethodSignatureThrows() {
+ Signature.MethodTypeSignature mSig = parser.parseAsMethodSignature("<T:>(TT;)V^Ljava/lang/Exception;^Ljava/lang/RuntimeException;");
+ assertEquals("One type parameter",1,mSig.formalTypeParameters.length);
+ assertEquals("T",mSig.formalTypeParameters[0].identifier);
+ assertEquals("Ljava/lang/Object;",mSig.formalTypeParameters[0].classBound.toString());
+ assertEquals("One parameter",1,mSig.parameters.length);
+ assertEquals("TT;",mSig.parameters[0].toString());
+ assertEquals("Void return type","V",mSig.returnType.toString());
+ assertEquals("2 throws",2,mSig.throwsSignatures.length);
+ assertEquals("Ljava/lang/Exception;",mSig.throwsSignatures[0].toString());
+ assertEquals("Ljava/lang/RuntimeException;",mSig.throwsSignatures[1].toString());
+ }
+
+ public void testMethodSignatureParsingInJDK() throws Exception{
+ SyntheticRepository repository = SyntheticRepository.getInstance();
+ String[] testClasses = new String[] {
+ "java.lang.Comparable",
+ "java.lang.Iterable",
+ "java.lang.Class",
+ "java.lang.Enum",
+ "java.lang.InheritableThreadLocal",
+ "java.lang.ThreadLocal",
+ "java.util.Collection",
+ "java.util.Comparator",
+ "java.util.Enumeration",
+ "java.util.Iterator",
+ "java.util.List",
+ "java.util.ListIterator",
+ "java.util.Map",
+ "java.util.Map$Entry",
+ "java.util.Queue",
+ "java.util.Set",
+ "java.util.SortedMap",
+ "java.util.SortedSet"
+ };
+ for (int i = 0; i < testClasses.length; i++) {
+ JavaClass jc = repository.loadClass(testClasses[i]);
+ Method[] methods = jc.getMethods();
+ for (int j = 0; j < methods.length; j++) {
+ String sig = methods[j].getGenericSignature();
+ if (sig != null) parser.parseAsMethodSignature(sig);
+ }
+ }
+ }
+
private void assertEquals(String[] expected, String[] actual) {
if (actual.length != expected.length) {
int shorter = Math.min(expected.length,actual.length);