blob: 59bca7a9aa56d9426a833a98dfee0dd2c80510b1 [file] [log] [blame]
/*******************************************************************************
* 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;
/*
* $RCSfile: REMByteClassBeanTypeProxy.java,v $
* $Revision: 1.3 $ $Date: 2005/08/24 20:39:07 $
*/
import org.eclipse.jem.internal.proxy.core.*;
import org.eclipse.jem.internal.proxy.common.remote.Commands;
/**
* BeanType Proxy for Byte.class.
* Creation date: (2/6/00 9:01:40 AM)
* @author: Joe Winchester
*/
final class REMByteClassBeanTypeProxy extends REMAbstractNumberBeanTypeProxy {
// Some values are cache'd for speed
private final INumberBeanProxy zeroProxy;
private final INumberBeanProxy oneProxy;
private final INumberBeanProxy twoProxy;
private final INumberBeanProxy threeProxy;
/**
* REMIntegerBeanTypeProxy constructor comment.
* @param aClass java.lang.Class
*/
REMByteClassBeanTypeProxy(REMProxyFactoryRegistry aRegistry, IBeanTypeProxy numberType) {
super(aRegistry, new Integer(Commands.BYTE_CLASS), Byte.class.getName(), numberType);
// Create the cached values
zeroProxy = new REMByteClassBeanProxy(aRegistry, new Byte((byte)0));
oneProxy = new REMByteClassBeanProxy(aRegistry, new Byte((byte)1));
twoProxy = new REMByteClassBeanProxy(aRegistry, new Byte((byte)2));
threeProxy = new REMByteClassBeanProxy(aRegistry, new Byte((byte)3));
}
/**
* Helper to create a bean proxy
* Package protected because everyone should go through the factory API
* that is defined as part of IBeanProxyFactory
*/
INumberBeanProxy createByteBeanProxy(Byte aByte) {
switch(aByte.byteValue()) {
case 0: return zeroProxy;
case 1: return oneProxy ;
case 2: return twoProxy ;
case 3: return threeProxy ;
default: return new REMByteClassBeanProxy(fRegistry, aByte);
}
}
/**
* Generic way to create an Integer proxy, however, the Number must be an Integer.
*/
protected INumberBeanProxy createNumberBeanProxy(Number aNumber) {
return createByteBeanProxy((Byte) aNumber);
}
/**
* newInstance method. Number's don't have a default ctor, so the standard way won't work.
* Return the zero proxy for this case.
*/
public IBeanProxy newInstance() {
return zeroProxy;
}
/**
* Create a new bean proxy the ValueObject passed in.
* We will assume the object is correct type.
*/
public IBeanProxy newBeanProxy(Commands.ValueObject value) {
return createByteBeanProxy(new Byte(value.aByte));
}
}