aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoraclement <aclement>2008-05-28 21:34:08 +0000
committeraclement <aclement>2008-05-28 21:34:08 +0000
commit3d89dc1c587cf386aea8032745f214e3fa446e0b (patch)
tree7246cd3fe816cabba410394026655e771ef2f0ff
parentf48735601f07796a846fa2d619b74e10349bb334 (diff)
downloadaspectj-3d89dc1c587cf386aea8032745f214e3fa446e0b.tar.gz
aspectj-3d89dc1c587cf386aea8032745f214e3fa446e0b.zip
spelling and optimization opportunities noted
-rw-r--r--weaver/src/org/aspectj/weaver/UnresolvedType.java11
1 files changed, 7 insertions, 4 deletions
diff --git a/weaver/src/org/aspectj/weaver/UnresolvedType.java b/weaver/src/org/aspectj/weaver/UnresolvedType.java
index 3c9c11324..951294536 100644
--- a/weaver/src/org/aspectj/weaver/UnresolvedType.java
+++ b/weaver/src/org/aspectj/weaver/UnresolvedType.java
@@ -26,7 +26,7 @@ import org.aspectj.weaver.tools.Traceable;
/**
* A UnresolvedType represents a type to the weaver. It has a basic signature that knows
- * nothing about type variables, type parameters, etc.. TypeXs are resolved in some World
+ * nothing about type variables, type parameters, etc.. UnresolvedTypes are resolved in some World
* (a repository of types). When a UnresolvedType is resolved it turns into a
* ResolvedType which may be a primitive type, an array type or a ReferenceType.
* ReferenceTypes may refer to simple, generic, parameterized or type-variable
@@ -121,8 +121,8 @@ public class UnresolvedType implements Traceable, TypeVariableDeclaringElement {
// this doesn't belong here and will get moved to ResolvedType later in the refactoring
public static final String MISSING_NAME = "@missing@";
-
-
+ // OPTIMIZE I dont think you can ask something unresolved what kind of type it is, how can it always know? Push down into resolvedtype
+ // that will force references to resolvedtypes to be correct rather than relying on unresolvedtypes to answer questions
protected TypeKind typeKind = TypeKind.SIMPLE; // what kind of type am I?
/**
@@ -217,6 +217,7 @@ public class UnresolvedType implements Traceable, TypeVariableDeclaringElement {
* that are type variable references are replaced by their matching type variable
* binding.
*/
+ // OPTIMIZE methods like this just allow callers to be lazy and not ensure they are working with the right (resolved) subtype
public UnresolvedType parameterize(Map typeBindings) {
throw new UnsupportedOperationException("unable to parameterize unresolved type: " + signature);
}
@@ -308,6 +309,7 @@ public class UnresolvedType implements Traceable, TypeVariableDeclaringElement {
* @param name the java language type name in question.
* @return a type object representing that java language type.
*/
+ // OPTIMIZE change users of this to use forSignature, especially for simple cases
public static UnresolvedType forName(String name) {
return forSignature(nameToSignature(name));
}
@@ -464,7 +466,7 @@ public class UnresolvedType implements Traceable, TypeVariableDeclaringElement {
/**
* Returns the name of this type in java language form (e.g. java.lang.Thread or boolean[]).
- * This produces a more esthetically pleasing string than {@link java.lang.Class#getName()}.
+ * This produces a more aesthetically pleasing string than {@link java.lang.Class#getName()}.
*
* @return the java language name of this type.
*/
@@ -905,6 +907,7 @@ public class UnresolvedType implements Traceable, TypeVariableDeclaringElement {
* from a generic method/ctor rather than a type variable from a generic type.
* Only subclasses know the answer...
*/
+ // OPTIMIZE don't allow this to be called, the caller must have a resolved entity
public boolean isParameterizedWithAMemberTypeVariable() {
throw new RuntimeException("I dont know - you should ask a resolved version of me: "+this);
}