/******************************************************************************* * Copyright (c) 2001, 2005 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.jem.internal.proxy.remote; /* */ import org.eclipse.jem.internal.proxy.common.MapTypes; import org.eclipse.jem.internal.proxy.core.*; /** * Array Type Proxy for the IDE VM. * * The class is final because array's are special and shouldn't have * any subclasses since the factory would never call it. */ public final class REMArrayBeanTypeProxy extends REMAbstractBeanTypeProxy implements IArrayBeanTypeProxy { /** * Create with a registry and a class. It is package so that only * the factory with this IDE package can call it. */ protected REMArrayBeanTypeProxy(REMProxyFactoryRegistry aRegistry, Integer anID, String aClassname, IBeanTypeProxy objectType) { super(aRegistry, anID, aClassname, objectType); } /** * This is an array type! */ public boolean isArray() { return true; } /** * Return the final component type. */ public IBeanTypeProxy getFinalComponentType() { // Component type is strip off all '[' and return class name (if we ever add classLoader support, this won't work). // However, if the type is a primitive we need to go through the change table). int typeStart = getTypeName().lastIndexOf('[')+1; if (getTypeName().charAt(typeStart) == 'L') { // It is a class. // Strip off up to the 'L', and the trailing ';'. That is the class name. return fRegistry.getBeanTypeProxyFactory().getBeanTypeProxy(getTypeName().substring(typeStart+1, getTypeName().length()-1)); } else { // It is a type. Need to map it. Class aType = (Class) MapTypes.MAP_SHORTSIG_TO_TYPE.get(getTypeName().substring(typeStart, typeStart+1)); return aType != null ? fRegistry.getBeanTypeProxyFactory().getBeanTypeProxy(aType.getName()) : null; } } /** * Return the component type. */ public IBeanTypeProxy getComponentType() { // Component type is strip off first '[' and return class name (if we ever add classLoader support, this won't work). // However, if the type is a primitive we need to go through the change table). if (getTypeName().charAt(1) != '[') { // It is a one dimensional array, just send to getFinalComponentType to figure out the type. return getFinalComponentType(); } else { // It is a multi-dimensional array. Just strip off one '[' and send that to the bean type factory. return fRegistry.getBeanTypeProxyFactory().getBeanTypeProxy(getTypeName().substring(1)); } } /** * Return the number of dimensions. */ public int getDimensions() { return getTypeName().lastIndexOf('[')+1; } /** * Create a new bean proxy with the specified object * Use the constructor that allows the type proxy to be set as well as the bean * because we are the type and by setting it now we might avoid it being lookup for in the * factory the first time it is asked for. */ public IREMBeanProxy newBeanProxy(Integer anID) { return new REMArrayBeanProxy(fRegistry, anID, this); } /** * newBeanTypeForClass: Create a new beantypeproxy of this kind for the given class. * This is used by beantype proxy factory when creating a beantype proxy for a subclass. * This is because subclasses, unless explicitly overridden, should use the same kind * of beantype proxy. This way if anything special is needed for a specific type, then * that can be done. * * Arrays can't be subclassed. */ public IREMBeanTypeProxy newBeanTypeForClass(Integer anID, String aClassname, boolean anAbstract) { throw new UnsupportedOperationException(); } /** * Return the null ctor proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IConstructorProxy getNullConstructorProxy() { throw new UnsupportedOperationException(); } /** * Return a proxy to the constructor for the target VM being the same as the REM * For all of the array types, this is an invalid operation. */ public IConstructorProxy getConstructorProxy(String[] argumentClassNames) { throw new UnsupportedOperationException(); } /** * Return a proxy to the constructor for the target VM being the same as the REM * For all of the array types, this is an invalid operation. */ public IConstructorProxy getConstructorProxy(IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IConstructorProxy[] getConstructors() { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IConstructorProxy[] getDeclaredConstructors() { throw new UnsupportedOperationException(); } /** * Return a proxy to the constructor for the target VM being the same as the REM * For all of the array types, this is an invalid operation. */ public IConstructorProxy getDeclaredConstructorProxy(String[] argumentClassNames) { throw new UnsupportedOperationException(); } /** * Return a proxy to the constructor for the target VM being the same as the REM * For all of the array types, this is an invalid operation. */ public IConstructorProxy getDeclaredConstructorProxy(IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } /** * Return a proxy to the field for the target VM being the same as the REM * For all of the array types, this is an invalid operation. */ public IFieldProxy getFieldProxy(String fieldName) { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IFieldProxy[] getFields() { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IFieldProxy[] getDeclaredFields() { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IMethodProxy[] getMethods() { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getConstructors() * * For all of the array types, this is an invalid operation. */ public IMethodProxy[] getDeclaredMethods() { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getMethodProxy(String methodName, IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getMethodProxy(String methodName, String[] argumentClassNames) { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getDeclaredMethodProxy(String methodName, IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getDeclaredMethodProxy(String methodName, String[] argumentClassNames) { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getMethodProxy(String methodName, String argumentQualifiedTypeName) { throw new UnsupportedOperationException(); } /** * Return the method proxy for this method with these arguments. * For all of the array types, this is an invalid operation. */ public IMethodProxy getMethodProxy(String methodName) { throw new UnsupportedOperationException(); } /** * Create an array bean proxy. * * - (int, new int[2] {3, 4}) will create: * int [3] [4] * * - (int[], new int[1] {1}) * int [1] * * - (int[], new int[2] {2,3}) * int [2] [3] * * * - (int[], null) or (int[], new int[0]) or (int, null) or (int, new int[0]) * int [0] * (int[][], null) or (int[][], new int[0]) * int[0][] * This is because an array instance with no dimensions specified is not valid. * * - (int[][], new int[1] {3}) * int[3][] * * It is package protected so that only the REM Factory can call it. */ REMArrayBeanProxy createBeanProxyWith(int[] dimensions) throws ThrowableProxy { // If the dimensions is null or zero length, then create the // array as a 0 sized array one dimensional array. if (dimensions == null || dimensions.length == 0) return createBeanProxyWith(new int[] {0}); // Remove from this type the number of dimensions specified // coming in, up to but no further than the final component. // From here we can then use the appropriate java.lang.reflect.Array // method to create the array. IBeanTypeProxy compType = null; // The type of array to create (it may be different number of dimensions). int numDims = getDimensions(); if (numDims <= dimensions.length) compType = getFinalComponentType(); // There are the same or more requested dimensions, so use final component type else { // There are fewer requested dimensions, so strip off that many String compClass = getTypeName().substring(dimensions.length); compType = fRegistry.getBeanTypeProxyFactory().getBeanTypeProxy(compClass); } if (dimensions.length == 1) { // Use the one dimension call Object[] parms = new Object[] {compType, new Integer(dimensions[0])}; return (REMArrayBeanProxy) ((IREMMethodProxy) REMStandardBeanProxyConstants.getConstants(fRegistry).getArrayNewInstanceOneDimension()).invokeWithParms(null, parms); } else { // Use the multi dimension call Object[] parms = new Object[] {compType, dimensions}; return (REMArrayBeanProxy) ((IREMMethodProxy) REMStandardBeanProxyConstants.getConstants(fRegistry).getArrayNewInstanceMultiDimension()).invokeWithParms(null, parms); } } /** * @see IBeanTypeProxy#getFormalTypeName() */ public String getFormalTypeName() { String name = getTypeName(); int dims = name.lastIndexOf('[') + 1; String type = getFinalComponentType().getTypeName(); StringBuffer formalType = new StringBuffer(type.length()+("[]".length()*dims)); //$NON-NLS-1$ formalType.append(type); for (int i=0; i<dims; i++) formalType.append("[]"); //$NON-NLS-1$ return formalType.toString(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getCompatibleConstructor(org.eclipse.jem.internal.proxy.core.IBeanTypeProxy[]) */ public IConstructorProxy getCompatibleConstructor(IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } /* (non-Javadoc) * @see org.eclipse.jem.internal.proxy.core.IBeanTypeProxy#getCompatibleMethod(java.lang.String, org.eclipse.jem.internal.proxy.core.IBeanTypeProxy[]) */ public IMethodProxy getCompatibleMethod(String methodName, IBeanTypeProxy[] argumentTypes) { throw new UnsupportedOperationException(); } }