From 5e1d22fe58b22867bd07b35d9932bd77ffcccacb Mon Sep 17 00:00:00 2001 From: rtrimana Date: Tue, 18 Jun 2019 12:56:09 -0700 Subject: [PATCH] Adding ParameterizedTypeImpl.java for parameterized types. --- .../ParameterizedTypeImpl.java | 167 ++++++++++++++++++ .../reflectiveObjects/TypeVariableImpl.java | 17 +- 2 files changed, 168 insertions(+), 16 deletions(-) create mode 100644 src/classes/sun/reflect/generics/reflectiveObjects/ParameterizedTypeImpl.java diff --git a/src/classes/sun/reflect/generics/reflectiveObjects/ParameterizedTypeImpl.java b/src/classes/sun/reflect/generics/reflectiveObjects/ParameterizedTypeImpl.java new file mode 100644 index 0000000..6b105e6 --- /dev/null +++ b/src/classes/sun/reflect/generics/reflectiveObjects/ParameterizedTypeImpl.java @@ -0,0 +1,167 @@ +package sun.reflect.generics.reflectiveObjects; + +import sun.reflect.generics.tree.FieldTypeSignature; + +import java.lang.reflect.MalformedParameterizedTypeException; +import java.lang.reflect.Method; +import java.lang.reflect.ParameterizedType; +import java.lang.reflect.Type; +import java.lang.reflect.TypeVariable; +import java.util.Arrays; +import java.util.Objects; + +/** + * MJI model class for sun.reflect.generics.reflectiveObjects.ParameterizedTypeImpl + * + * This is a JPF specific version of a system class because we can't use the real, + * platform VM specific version (it's native all over the place, its field + * structure isn't documented, most of its methods are private, hence we can't + * even instantiate it properly). + * + * Note that this class never gets seen by the real VM - it's for JPF's eyes only. + * + */ + +/** Implementing class for ParameterizedType interface. */ +public class ParameterizedTypeImpl implements ParameterizedType { + private final Type[] actualTypeArguments; + private final Class rawType; + private final Type ownerType; + + private ParameterizedTypeImpl(Class rawType, + Type[] actualTypeArguments, + Type ownerType) { + this.actualTypeArguments = actualTypeArguments; + this.rawType = rawType; + this.ownerType = (ownerType != null) ? ownerType : rawType.getDeclaringClass(); + validateConstructorArguments(); + } + + private void validateConstructorArguments() { + TypeVariable[] formals = rawType.getTypeParameters(); + // check correct arity of actual type args + if (formals.length != actualTypeArguments.length){ + throw new MalformedParameterizedTypeException(); + } + for (int i = 0; i < actualTypeArguments.length; i++) { + // check actuals against formals' bounds + } + } + + /** + * Static factory. Given a (generic) class, actual type arguments + * and an owner type, creates a parameterized type. + */ + public static ParameterizedTypeImpl make(Class rawType, + Type[] actualTypeArguments, + Type ownerType) { + return new ParameterizedTypeImpl(rawType, actualTypeArguments, + ownerType); + } + + public Type[] getActualTypeArguments() { + return actualTypeArguments.clone(); + } + + /** + * Returns the Type object representing the class or interface + * that declared this type. + * + * @return the Type object representing the class or interface + * that declared this type + */ + public Class getRawType() { + return rawType; + } + + + public Type getOwnerType() { + return ownerType; + } + + @Override + public boolean equals(Object o) { + if (o instanceof ParameterizedType) { + // Check that information is equivalent + ParameterizedType that = (ParameterizedType) o; + + if (this == that) + return true; + + Type thatOwner = that.getOwnerType(); + Type thatRawType = that.getRawType(); + + if (false) { // Debugging + boolean ownerEquality = (ownerType == null ? + thatOwner == null : + ownerType.equals(thatOwner)); + boolean rawEquality = (rawType == null ? + thatRawType == null : + rawType.equals(thatRawType)); + + boolean typeArgEquality = Arrays.equals(actualTypeArguments, // avoid clone + that.getActualTypeArguments()); + for (Type t : actualTypeArguments) { + System.out.printf("\t\t%s%s%n", t, t.getClass()); + } + + System.out.printf("\towner %s\traw %s\ttypeArg %s%n", + ownerEquality, rawEquality, typeArgEquality); + return ownerEquality && rawEquality && typeArgEquality; + } + + return + Objects.equals(ownerType, thatOwner) && + Objects.equals(rawType, thatRawType) && + Arrays.equals(actualTypeArguments, // avoid clone + that.getActualTypeArguments()); + } else + return false; + } + + @Override + public int hashCode() { + return + Arrays.hashCode(actualTypeArguments) ^ + Objects.hashCode(ownerType) ^ + Objects.hashCode(rawType); + } + + public String toString() { + StringBuilder sb = new StringBuilder(); + + if (ownerType != null) { + if (ownerType instanceof Class) + sb.append(((Class)ownerType).getName()); + else + sb.append(ownerType.toString()); + + sb.append("."); + + if (ownerType instanceof ParameterizedTypeImpl) { + // Find simple name of nested type by removing the + // shared prefix with owner. + sb.append(rawType.getName().replace( ((ParameterizedTypeImpl)ownerType).rawType.getName() + "$", + "")); + } else + sb.append(rawType.getName()); + } else + sb.append(rawType.getName()); + + if (actualTypeArguments != null && + actualTypeArguments.length > 0) { + sb.append("<"); + boolean first = true; + for(Type t: actualTypeArguments) { + if (!first) + sb.append(", "); + sb.append(t.getTypeName()); + first = false; + } + sb.append(">"); + } + + return sb.toString(); + } +} + diff --git a/src/classes/sun/reflect/generics/reflectiveObjects/TypeVariableImpl.java b/src/classes/sun/reflect/generics/reflectiveObjects/TypeVariableImpl.java index 50392ca..fcb0521 100644 --- a/src/classes/sun/reflect/generics/reflectiveObjects/TypeVariableImpl.java +++ b/src/classes/sun/reflect/generics/reflectiveObjects/TypeVariableImpl.java @@ -12,7 +12,7 @@ import sun.reflect.generics.factory.GenericsFactory; import sun.reflect.generics.tree.FieldTypeSignature; /** - * MJI model class for sun.reflect.generics.reflectiveObjects.TypeVariableImple + * MJI model class for sun.reflect.generics.reflectiveObjects.TypeVariableImpl * * This is a JPF specific version of a system class because we can't use the real, * platform VM specific version (it's native all over the place, its field @@ -44,15 +44,6 @@ public class TypeVariableImpl /** * Factory method. - * @param decl - the reflective object that declared the type variable - * that this method should create - * @param name - the name of the type variable to be returned - * @param bs - an array of ASTs representing the bounds for the type - * variable to be created - * @param f - a factory that can be used to manufacture reflective - * objects that represent the bounds of this type variable - * @return A type variable with name, bounds, declaration and factory - * specified */ public static TypeVariableImpl make(T decl, String name, @@ -77,12 +68,6 @@ public class TypeVariableImpl throw new UnsupportedOperationException(); } - - /** - * Returns the name of this type variable, as it occurs in the source code. - * - * @return the name of this type variable, as it appears in the source code - */ public String getName() { return name; } public String toString() {return getName();} -- 2.34.1