src.com.ibm.as400.access.AS400Array Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: AS400Array.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2004 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
/**
* The AS400Array class provides a composite data type representing an array of AS400DataType objects.
**/
public class AS400Array implements AS400DataType
{
static final long serialVersionUID = 4L;
private AS400DataType arrayType = null;
private int arraySize = -1;
private boolean allowChanges = true; // For beans: allow changes after null constructor until conversion method called
/**
* Constructs an AS400Array object. The setNumberOfElements() and setType() methods must be called before a call to any conversion methods or the getByteLength() on this object.
**/
public AS400Array()
{
}
/**
* Constructs an AS400Array object.
* @param type The type of the array.
* @param size The number of elements in the array. It must be greater than or equal to zero.
**/
public AS400Array(AS400DataType type, int size)
{
if (size < 0)
{
throw new ExtendedIllegalArgumentException("size (" + String.valueOf(size) + ")", ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
}
this.allowChanges = false;
// only store clones
this.arrayType = (AS400DataType)type.clone(); // let this line throw NullPointerException
this.arraySize = size;
}
/**
* Creates a new AS400Array object that is identical to the current instance.
* @return The new object.
**/
public Object clone()
{
try
{
AS400Array nObj = (AS400Array)super.clone(); // Object.clone does not throw exception
nObj.arrayType = (this.arrayType == null) ?
null :
(AS400DataType)this.arrayType.clone(); // Data Types do not throw exception
return nObj;
}
catch (CloneNotSupportedException e)
{
Trace.log(Trace.ERROR, "Unexpected cloning error", e);
throw new InternalErrorException(InternalErrorException.UNKNOWN);
}
}
/**
* Returns the byte length of the data type. The type and number of elements in this array must be set before calling this method.
* @return The number of bytes in the IBM i representation of the data type.
**/
public int getByteLength()
{
AS400DataType element = this.arrayType;
int size = this.arraySize;
// Check for valid state
if (element == null)
{
throw new ExtendedIllegalStateException("Type", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
if (size == -1)
{
throw new ExtendedIllegalStateException("NumberOfElements", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
this.allowChanges = false; // Check before setting so don't have unfixable object
// Length is number of elements * size of the element
return this.arraySize*this.arrayType.getByteLength();
}
/**
* Returns a Java object that represents the default value of the data type.
* @return The zero-length Object array.
**/
public Object getDefaultValue()
{
int size = ( this.arraySize == -1 ? 0 : this.arraySize );
Object[] returnArray = new Object[size];
Object elementDefaultValue = ( this.arrayType == null ? null : this.arrayType.getDefaultValue() );
for (int i = 0; i < size; ++i)
{
returnArray[i] = elementDefaultValue;
}
return returnArray;
}
/**
* Returns {@link com.ibm.as400.access.AS400DataType#TYPE_ARRAY TYPE_ARRAY}.
* @return AS400DataType.TYPE_ARRAY.
**/
public int getInstanceType()
{
return AS400DataType.TYPE_ARRAY;
}
/**
* Returns the Java class that corresponds with this data type.
* @return Object[].class.
**/
public Class getJavaType()
{
return Object[].class;
}
/**
* Returns the number of elements in the data type.
* @return The number of elements in the array data type. If the number of elements has not been set, negative one (-1) is returned.
**/
public int getNumberOfElements()
{
return this.arraySize;
}
/**
* Returns the type of the array.
* @return The type of this array data type. If the array type has not been set, null is returned.
**/
public AS400DataType getType()
{
return (this.arrayType == null) ?
null :
(AS400DataType)this.arrayType.clone(); // only give out clones
}
/**
* Sets the number of elements in the data type. This method must be called after a call to the null constructor and before a call to any of the conversion methods or getByteLength().
* @param size The number of elements in the array. It must be greater than or equal to zero.
**/
public void setNumberOfElements(int size)
{
if (!this.allowChanges)
{
throw new ExtendedIllegalStateException("NumberOfElements", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED);
}
if (size < 0)
{
throw new ExtendedIllegalArgumentException("size (" + String.valueOf(size) + ")", ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
}
this.arraySize = size;
}
/**
* Sets the type of the array. This method must be called after a call to the null constructor and before a call to any of the conversion methods or getByteLength().
* @param type The type of the array.
**/
public void setType(AS400DataType type)
{
if (!this.allowChanges)
{
throw new ExtendedIllegalStateException("Type", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED);
}
// only store clones
this.arrayType = (AS400DataType)type.clone(); // Let this line throw NullPointerException
}
/**
* Converts the specified Java object to IBM i format. The type and number of elements in this array must be set before calling this method.
* @param javaValue The object corresponding to the data type. It must be an Object array; the array must contain the correct number of elements, and each element must be of the correct type.
* @return The IBM i representation of the data type.
**/
public byte[] toBytes(Object javaValue)
{
byte[] as400Value = new byte[this.getByteLength()]; // let getByteLength check state
this.toBytes(javaValue, as400Value, 0);
return as400Value;
}
/**
* Converts the specified Java object into IBM i format in the specified byte array. The type and number of elements in this array must be set before calling this method.
* @param javaValue The object corresponding to the data type. It must be an Object array; the array must contain the correct number of elements, and each element must be of the correct type.
* @param as400Value The array to receive the data type in IBM i format. There must be enough space to hold the value.
* @return The number of bytes in the IBM i representation of the data type.
**/
public int toBytes(Object javaValue, byte[] as400Value)
{
return this.toBytes(javaValue, as400Value, 0);
}
/**
* Converts the specified Java object into IBM i format in the specified byte array. The type and number of elements in this array must be set before calling this method.
* @param javaValue The object corresponding to the data type. It must be an Object array; the array must contain the correct number of elements, and each element must be of the correct type.
* @param as400Value The array to receive the data type in IBM i format. There must be enough space to hold the value.
* @param offset The offset into the byte array for the start of the IBM i value. It must be greater than or equal to zero.
* @return The number of bytes in the IBM i representation of the data type.
**/
public int toBytes(Object javaValue, byte[] as400Value, int offset)
{
AS400DataType element = this.arrayType;
int size = this.arraySize;
// Check for valid state
if (element == null)
{
throw new ExtendedIllegalStateException("Type", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
if (size == -1)
{
throw new ExtendedIllegalStateException("NumberOfElements", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
this.allowChanges = false; // Check before setting so don't have unfixable object
Object[] javaArray = (Object[])javaValue; // let this line to throw ClassCastException
if (javaArray.length != size) // Check for correct number of elements
{
throw new ExtendedIllegalArgumentException("javaValue (" + javaValue.toString() + ")", ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
}
// Convert array by iterating over elements, allow elements to do own validity checking
for (int i = 0; i < size; ++i)
{
offset += element.toBytes(javaArray[i], as400Value, offset);
}
return element.getByteLength()*size;
}
/**
* Converts the specified IBM i data type to a Java object. The type and number of elements in this array must be set before calling this method.
* @param as400Value The array containing the data type in IBM i format. The entire data type must be represented.
* @return The array of Object. Each element of this array is an Object corresponding to the type of this AS400Array object.
**/
public Object toObject(byte[] as400Value)
{
return this.toObject(as400Value, 0);
}
/**
* Converts the specified IBM i data type to a Java object. The type and number of elements in this array must be set before calling this method.
* @param as400Value The array containing the data type in IBM i format. The entire data type must be represented.
* @param offset The offset into the byte array for the start of the IBM i value. It must be greater than or equal to zero.
* @return The array of Object. Each element of this array is an Object corresponding to the type of this AS400Array object.
**/
public Object toObject(byte[] as400Value, int offset)
{
AS400DataType element = this.arrayType;
int size = this.arraySize;
// Check for valid state
if (element == null)
{
throw new ExtendedIllegalStateException("Type", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
if (size == -1)
{
throw new ExtendedIllegalStateException("NumberOfElements", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
this.allowChanges = false; // Check before setting so don't have unfixable object
int elementSize = element.getByteLength();
Object[] returnArray = new Object[size];
// Convert array by iterating over elements, allow elements to do own validity checking
for (int i = 0; i < size; ++i)
{
returnArray[i] = element.toObject(as400Value, offset);
offset += elementSize;
}
return returnArray;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy