src.com.ibm.as400.access.DataArea Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: DecimalDataArea.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;
import java.io.Serializable;
import java.io.IOException;
import java.util.Vector;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeSupport;
import java.beans.VetoableChangeListener;
import java.net.UnknownHostException;
/**
The DataArea class is an abstract base class that represents a
data area object.
DataArea objects generate the following events:
- DataAreaEvent
- DA_CLEARED
- DA_CREATED
- DA_DELETED
- DA_READ
- DA_WRITTEN
- PropertyChangeEvent
- VetoableChangeEvent
**/
public abstract class DataArea implements Serializable
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
static final long serialVersionUID = 4L;
/**
Constants
**/
static final int UNKNOWN_LENGTH = 0;
// Type of data area.
static final int UNINITIALIZED = 0;
static final int CHARACTER_DATA_AREA = 1;
static final int DECIMAL_DATA_AREA = 2;
static final int LOCAL_DATA_AREA = 3;
static final int LOGICAL_DATA_AREA = 4;
/**
Variables
**/
private AS400 system_ = null; // The system where the data area is located.
private String dataAreaPathName_ = null; // The full path name of the data area,
// as specified by the user.
private String name_ = null; // The name of the data area.
private QSYSObjectPathName ifsPathName_ = null; // The full path name of the data area.
// Should be "private protected" but are really package scope
// so the subclasses can get at them.
//@B0 It was decided that the data area length should NOT be a bean property
// because the property getter getLength() needs to go the system. Bean property
// constructors, getters, and setters should not make connections to the system
// because of the way a visual builder environment manipulates bean objects.
int length_ = UNKNOWN_LENGTH; // The maximum number of bytes the data area can contain.
String textDescription_ = "*BLANK"; // A text description of the data area.
String authority_ = "*LIBCRTAUT"; // The authority level that public has to the data area.
int dataAreaType_ = UNINITIALIZED;
private transient Vector daListeners_;
private transient PropertyChangeSupport changes_ ;
private transient VetoableChangeSupport vetos_;
transient DataAreaImpl impl_;
/**
Constructs a DataArea object.
It creates a default DataArea object. The system and path
properties must be set before attempting a connection.
**/
public DataArea()
{
super();
initializeTransient();
}
/**
Constructs a DataArea object.
It creates a DataArea instance that represents the data area path
on system.
@param system The system that contains the data area.
@param path The fully qualified integrated file system path name. The
integrated file system file extension for a data area is DTAARA. An example of a
fully qualified integrated file system path to a data area "MYDATA" in library
"MYLIB" is: /QSYS.LIB/MYLIB.LIB/MYDATA.DTAARA
**/
public DataArea(AS400 system, String path)
{
super();
// Validate system parm.
if (system == null)
throw new NullPointerException("system");
// Validate path parm.
if (path == null)
throw new NullPointerException("path");
initializeTransient();
ifsPathName_ = new QSYSObjectPathName(path, "DTAARA");
name_ = ifsPathName_.getObjectName();
system_ = system;
dataAreaPathName_ = path;
}
/**
Adds a data area listener to receive data area events from this data area.
@see #removeDataAreaListener
@param listener The data area listener.
**/
public void addDataAreaListener(DataAreaListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
this.daListeners_.addElement(listener);
}
/**
Adds a PropertyChangeListener. The specified PropertyChangeListener's
propertyChange method will be called each time the value of any
bound property is changed.
@see #removePropertyChangeListener
@param listener The PropertyChangeListener.
**/
public void addPropertyChangeListener(PropertyChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
this.changes_.addPropertyChangeListener(listener);
}
/**
Adds the VetoableChangeListener. The specified VetoableChangeListener's
vetoableChange method will be called each time the value of any
constrained property is changed.
@see #removeVetoableChangeListener
@param listener The VetoableChangeListener.
**/
public void addVetoableChangeListener(VetoableChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
this.vetos_.addVetoableChangeListener(listener);
}
/**
Chooses the appropriate implementation.
This method is available for use by subclasses.
Subclasses must first set dataAreaType_ to a valid value:
either CHARACTER_DATA_AREA, DECIMAL_DATA_AREA, LOCAL_DATA_AREA,
or LOGICAL_DATA_AREA.
**/
void chooseImpl ()
throws AS400SecurityException, IOException
{
// Verify required attributes have been set.
if (system_ == null)
{
Trace.log(Trace.ERROR, "Attempt to connect before setting system.");
throw new ExtendedIllegalStateException("System", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
if (ifsPathName_ == null)
{
Trace.log(Trace.ERROR, "Attempt to connect before setting data area pathname.");
throw new ExtendedIllegalStateException("Path", ExtendedIllegalStateException.PROPERTY_NOT_SET);
}
// Assume that dataAreaType_ is a valid.
impl_ = (DataAreaImpl) system_.loadImpl2
("com.ibm.as400.access.DataAreaImplRemote",
"com.ibm.as400.access.DataAreaImplProxy");
system_.connectService(AS400.COMMAND);
impl_.setAttributes(system_.getImpl(), ifsPathName_, dataAreaType_);
}
// Returns the descriptive text name corresponding to a specified data area type.
static String dataAreaTypeToString(int dataAreaType)
{
String type = null;
switch (dataAreaType)
{
case CHARACTER_DATA_AREA :
type = "Character";
break;
case DECIMAL_DATA_AREA :
type = "Decimal";
break;
case LOCAL_DATA_AREA :
type = "Local";
break;
case LOGICAL_DATA_AREA :
type = "Logical";
break;
case UNINITIALIZED :
type = "Uninitialized";
break;
default :
Trace.log(Trace.ERROR, "Unrecognized data area type: " + dataAreaType);
type = "Unrecognized";
break;
}
return type;
}
/**
Removes the data area from the system.
This is a common implementation for the delete() methods of the subclasses.
@exception AS400SecurityException If a security or authority error occurs.
@exception ErrorCompletingRequestException If an error occurs before the request is completed.
@exception InterruptedException If this thread is interrupted.
@exception IOException If an error occurs while communicating with the system.
@exception ObjectDoesNotExistException If the object does not exist.
**/
void delete0()
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
if (impl_ == null)
chooseImpl();
impl_.delete();
// Fire the DELETED event.
fireDeleted();
}
/**
Fires a DA_CLEARED event.
@param obj The source object from which the event originated.
**/
void fireCleared()
{
Vector targets = (Vector) daListeners_.clone();
DataAreaEvent event = new DataAreaEvent(this, DataAreaEvent.DA_CLEARED);
for (int i=0; idataLength bytes, without conversion,
beginning at offset dataAreaOffset in the data area.
Note that the first byte in the data area is at offset 0.
@param dataBuffer The buffer into which to read the data. Must be non-null.
@param dataBufferOffset The starting offset in dataBuffer.
@param dataAreaOffset The offset in the data area at which to start reading.
@param dataLength The number of bytes to read. Valid values are from
1 through (data area size - dataAreaOffset).
@return The total number of bytes read into the buffer.
@exception AS400SecurityException If a security or authority error occurs.
@exception ErrorCompletingRequestException If an error occurs before the request is completed.
@exception IllegalObjectTypeException If the system object is not the required type.
@exception InterruptedException If this thread is interrupted.
@exception IOException If an error occurs while communicating with the system.
@exception ObjectDoesNotExistException If the system object does not exist.
**/
int read(byte[] dataBuffer, int dataBufferOffset, int dataAreaOffset, int dataLength)
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// Validate the data parameter.
if (dataBuffer == null)
throw new NullPointerException("dataBuffer");
// Get size of the data area.
if (length_ == UNKNOWN_LENGTH)
{
try {
length_ = getLength();
}
catch(IllegalObjectTypeException iote) {
if (Trace.isTraceOn() && Trace.isTraceWarningOn()) {
Trace.log(Trace.WARNING, "Unexpected exception when retrieving length for data area.", iote);
}
}
}
// Validate the data length.
if (dataBuffer.length < 1)
throw new ExtendedIllegalArgumentException("dataBuffer",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
// Validate the dataBufferOffset parameter.
if (dataBufferOffset < 0 || dataBufferOffset > dataBuffer.length-1)
throw new ExtendedIllegalArgumentException("dataBufferOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the dataAreaOffset parameter.
if (dataAreaOffset < 0 || dataAreaOffset >= length_)
throw new ExtendedIllegalArgumentException("dataAreaOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the dataLength parameter.
if (dataLength < 1 || dataLength > dataBuffer.length)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataBufferOffset, dataLength) combination.
if (dataBufferOffset+dataLength > dataBuffer.length)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataAreaOffset, dataLength) combination.
if (dataAreaOffset+dataLength > length_)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
if (impl_ == null)
chooseImpl();
// Do the read
int bytesRead = impl_.readBytes(dataBuffer, dataBufferOffset, dataAreaOffset, dataLength);
// Fire the READ event.
fireRead();
return bytesRead;
}
/**
Refreshes the attributes of the data area.
This method should be called if the underlying system data area has changed
and it is desired that this object should reflect those changes.
@exception AS400SecurityException If a security or authority error occurs.
@exception ErrorCompletingRequestException If an error occurs before the request is completed.
@exception IllegalObjectTypeException If the system object is not the required type.
@exception InterruptedException If this thread is interrupted.
@exception IOException If an error occurs while communicating with the system.
@exception ObjectDoesNotExistException If the system object does not exist.
**/
public void refreshAttributes()
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
if (impl_ == null)
chooseImpl();
impl_.refreshAttributes();
}
/**
Removes the DataAreaListener from the internal list.
If the DataAreaListener is not on the list, nothing is done.
@see #addDataAreaListener
@param listener The data area listener.
**/
public void removeDataAreaListener(DataAreaListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
daListeners_.removeElement(listener);
}
/**
Removes the PropertyChangeListener from the internal list.
If the PropertyChangeListener is not on the list, nothing is done.
@see #addPropertyChangeListener
@param listener The PropertyChangeListener.
**/
public void removePropertyChangeListener(PropertyChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
changes_.removePropertyChangeListener(listener);
}
/**
Removes the VetoableChangeListener from the internal list.
If the VetoableChangeListener is not on the list, nothing is done.
@see #addVetoableChangeListener
@param listener The VetoableChangeListener.
**/
public void removeVetoableChangeListener(VetoableChangeListener listener)
{
if (listener == null)
throw new NullPointerException("listener");
vetos_.removeVetoableChangeListener(listener);
}
/**
Sets the type of data area.
This method is only used internally, by subclasses.
Valid values are: CHARACTER_DATA_AREA, DECIMAL_DATA_AREA,
LOCAL_DATA_AREA, LOGICAL_DATA_AREA.
**/
void setImplType(int dataAreaType)
{
dataAreaType_ = dataAreaType; // Trust that the argument is valid.
}
/**
Sets the fully qualified data area name. Note this method is NOT public.
It is overridden as a public method in the subclasses that use it.
@exception PropertyVetoException If the change is vetoed.
**/
void setPath(String path) throws PropertyVetoException
{
// check parm
if (path == null)
throw new NullPointerException("path");
// Make sure we have not already connected.
if (impl_ != null)
{
Trace.log(Trace.ERROR, "Cannot set property after connect.");
throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED);
}
// Ask for any vetos.
String old = dataAreaPathName_;
vetos_.fireVetoableChange("path", old, path );
// Verify name is valid IFS path name.
ifsPathName_ = new QSYSObjectPathName(path, "DTAARA");
// Set instance vars.
name_ = ifsPathName_.getObjectName();
dataAreaPathName_ = path;
changes_.firePropertyChange("path", old, path );
}
/**
Sets the system on which the data area exists. The system cannot be set
if a connection has already been established.
@param system The system on which the data area exists.
@exception PropertyVetoException If the change is vetoed.
**/
public void setSystem(AS400 system) throws PropertyVetoException
{
// check parm
if (system == null)
throw new NullPointerException("system");
// Make sure we have not already connected.
if (impl_ != null)
{
Trace.log(Trace.ERROR, "Cannot set property after connect.");
throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED);
}
AS400 old = system_;
vetos_.fireVetoableChange("system", old, system);
// Set instance var.
system_ = system;
changes_.firePropertyChange("system", old, system_);
}
// Design note: This method is relevant only to CharacterDataArea and LocalDataArea.
// It is irrelevant to DecimalDataArea and LogicalDataArea, since those types of data
// areas have restrictions on what byte values can exist in them.
/**
Writes the data to the data area.
It writes the specified bytes, without conversion, to the data area, at offset dataAreaOffset.
Note that the first byte in the data area is at offset 0.
@param dataBuffer The data to be written. Must be non-null.
@param dataBufferOffset The starting offset in dataBuffer.
@param dataAreaOffset The offset in the data area at which to start writing.
@param dataLength The number of bytes to write.
@exception AS400SecurityException If a security or authority error occurs.
@exception ErrorCompletingRequestException If an error occurs before the request is completed.
@exception InterruptedException If this thread is interrupted.
@exception IOException If an error occurs while communicating with the system.
@exception ObjectDoesNotExistException If the system object does not exist.
**/
void write(byte[] dataBuffer, int dataBufferOffset, int dataAreaOffset, int dataLength)
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// Validate the data parameter.
if (dataBuffer == null)
throw new NullPointerException("dataBuffer");
// Get size of the data area.
if (length_ == UNKNOWN_LENGTH)
{
try {
length_ = getLength();
}
catch(IllegalObjectTypeException iote) {
if (Trace.isTraceOn() && Trace.isTraceWarningOn()) {
Trace.log(Trace.WARNING, "Unexpected exception when retrieving length for data area.", iote);
}
}
}
// Validate the data length.
if (dataBuffer.length < 1)
throw new ExtendedIllegalArgumentException("dataBuffer",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
// Validate the dataBufferOffset parameter.
if (dataBufferOffset < 0 || dataBufferOffset > dataBuffer.length-1)
throw new ExtendedIllegalArgumentException("dataBufferOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the dataAreaOffset parameter.
if (dataAreaOffset < 0 || dataAreaOffset >= length_)
throw new ExtendedIllegalArgumentException("dataAreaOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the dataLength parameter.
if (dataLength < 1 || dataLength > dataBuffer.length)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataBufferOffset, dataLength) combination.
if (dataBufferOffset+dataLength > dataBuffer.length)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataAreaOffset, dataLength) combination.
if (dataAreaOffset+dataLength > length_)
throw new ExtendedIllegalArgumentException("dataLength",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
if (impl_ == null)
chooseImpl();
// Do the write
impl_.write(dataBuffer, dataBufferOffset, dataAreaOffset, dataLength);
// Fire the WRITTEN event.
fireWritten();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy