src.com.ibm.as400.access.LocalDataArea Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: LocalDataArea.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.beans.PropertyVetoException;
import java.net.UnknownHostException;
// There is always a local data area associated with the current IBM i job.
// It is 1024 bytes in length and is accessed using the name "*LDA". Its text
// description is "*LDA FOR JOB jobnumber/username/jobname".
// IBM i allows only read and write operations on a local data area.
/**
The LocalDataArea class represents a local data area on the system.
A local data area exists as a character data area on the system. It is
automatically associated with a job and cannot be accessed from another
job; hence, it cannot be directly created or deleted by the user.
Care must be taken when using local data areas so that the IBM i job
is not ended prematurely. When the job ends, its local data area is
automatically deleted, at which point the LocalDataArea object that
is referencing it will no longer be valid.
The following example demonstrates the use of LocalDataArea:
// Prepare to work with the system named "My400".
AS400 system = new AS400("My400");
// Create a LocalDataArea object to access
// the local data area associated with this connection.
LocalDataArea dataArea = new LocalDataArea(system);
// Clear the data area
dataArea.clear();
// Write to the data area
dataArea.write("Hello world");
// Read from the data area
String data = dataArea.read();
Note: Most of the read() and write() methods of this class automatically
convert characters between Unicode and the CCSID associated with the AS400 object.
See {@link AS400#getCcsid AS400.getCcsid()}.
**/
public class LocalDataArea extends DataArea implements Serializable
{
static final long serialVersionUID = 4L;
/**
Constants
**/
static final int DEFAULT_LENGTH = 1024; // bytes
static final String DEFAULT_PATH = "/QSYS.LIB/ .LIB/*LDA.DTAARA";
/**
Variables
***/
/**
Constructs a LocalDataArea object.
It creates a default LocalDataArea object. The system property
must be set before attempting a connection.
**/
public LocalDataArea()
{
super();
try { super.setPath(DEFAULT_PATH); }
catch (PropertyVetoException e) {} // Will never happen.
length_ = DEFAULT_LENGTH;
dataAreaType_ = LOCAL_DATA_AREA;
}
/**
Constructs a LocalDataArea object.
It creates a LocalDataArea instance that represents the local data area
on system.
@param system The system that contains the data area.
**/
public LocalDataArea(AS400 system)
{
// See if we can squeeze a local data area past QSYSObjectPathName:
// The library name must be 10 blanks.
// The data area name must be *LDA
super(system, DEFAULT_PATH);
length_ = DEFAULT_LENGTH;
dataAreaType_ = LOCAL_DATA_AREA;
}
/**
Resets the data area to contain all blanks.
@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.
**/
public void clear()
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
if (impl_ == null)
chooseImpl();
impl_.clear();
// Fire the CLEARED event.
fireCleared();
}
/**
Reads the data from the data area.
It retrieves the entire contents of the data area. Note that if the data
does not completely fill the data area, this method will return data
padded with trailing blanks up to the length of the data area.
@return The data read from the data area.
@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 String read()
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
if (impl_ == null)
chooseImpl();
// Do the read
String val = impl_.retrieve(-1,1);
// Fire the READ event.
fireRead();
return val;
}
/**
Reads the data from the data area.
It retrieves the entire contents of the data area. Note that if the data
does not completely fill the data area, this method will return data
padded with trailing blanks up to the length of the data area.
@param type The Local Data Area bidi string type, as defined by the CDRA (Character
Data Representataion Architecture). See
BidiStringType for more information and valid values.
@return The data read from the data area.
@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 String read(int type) //$A2A
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
if (impl_ == null)
chooseImpl();
// Do the read
String val = impl_.retrieve(-1,1, type); //$A2C
// Fire the READ event.
fireRead();
return val;
}
/**
Reads the data from the data area.
It retrieves dataLength characters (or fewer if multi-byte characters) beginning at
dataAreaOffset in the data area. The first character in
the data area is at offset 0.
@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 data read from the data area.
@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 String read(int dataAreaOffset, int dataLength)
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// 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 > 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
String val = impl_.retrieve(dataAreaOffset, dataLength);
// Fire the READ event.
fireRead();
return val;
}
/**
Reads the data from the data area.
It retrieves dataLength characters (or fewer if multi-byte characters) beginning at
dataAreaOffset in the data area. The first character in
the data area is at offset 0.
@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).
@param type The Data Area bidi string type, as defined by the CDRA (Character
Data Representataion Architecture). See
BidiStringType for more information and valid values.
@return The data read from the data area.
@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 String read(int dataAreaOffset, int dataLength, int type) //$A2A
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// 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 > 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
String val = impl_.retrieve(dataAreaOffset, dataLength, type); //$A2C
// Fire the READ event.
fireRead();
return val;
}
/**
Reads the data from the data area.
It retrieves up to dataLength 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.
@see #write(byte[],int,int,int)
**/
public int read(byte[] dataBuffer, int dataBufferOffset, int dataAreaOffset, int dataLength)
throws AS400SecurityException,
ErrorCompletingRequestException,
IllegalObjectTypeException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
return super.read(dataBuffer, dataBufferOffset, dataAreaOffset, dataLength);
}
/**
Writes the data to the data area.
It writes data to the beginning of the data area. The remaining
characters in the data area are blank padded.
@param data The data to be written.
@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.
**/
public void write(String data)
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// Validate the data parameter.
if (data == null)
throw new NullPointerException("data");
if (data.length() < 1 || data.length() > length_)
throw new ExtendedIllegalArgumentException("data",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
if (impl_ == null)
chooseImpl();
// Do the write
impl_.write(data, 0);
// Fire the WRITTEN event.
fireWritten();
}
/**
Writes the data to the data area.
It writes data.length() characters from data to the
data area beginning at dataAreaOffset. The first character
in the data area is at offset 0.
@param data The data to be written.
@param dataAreaOffset The offset in the data area at which to start writing.
@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.
**/
public void write(String data, int dataAreaOffset)
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// Validate the data parameter.
if (data == null)
throw new NullPointerException("data");
// Validate the data length.
if (data.length() < 1 || data.length() > length_)
throw new ExtendedIllegalArgumentException("data",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
// Validate the dataAreaOffset parameter.
if (dataAreaOffset < 0 || dataAreaOffset >= length_)
throw new ExtendedIllegalArgumentException("dataAreaOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataAreaOffset, dataLength) combination.
if (dataAreaOffset+data.length() > length_)
throw new ExtendedIllegalArgumentException("data",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
if (impl_ == null)
chooseImpl();
// Do the write
impl_.write(data, dataAreaOffset);
// Fire the WRITTEN event.
fireWritten();
}
/**
Writes the data to the data area.
It writes data.length() characters from data to the
data area beginning at dataAreaOffset. The first character
in the data area is at offset 0.
@param data The data to be written.
@param dataAreaOffset The offset in the data area at which to start writing.
@param type The Data Area bidi string type, as defined by the CDRA (Character
Data Representataion Architecture). See
BidiStringType for more information and valid values.
@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.
**/
public void write(String data, int dataAreaOffset, int type) //$A2A
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
// Validate the data parameter.
if (data == null)
throw new NullPointerException("data");
// Validate the data length.
if (data.length() < 1 || data.length() > length_)
throw new ExtendedIllegalArgumentException("data",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
// Validate the dataAreaOffset parameter.
if (dataAreaOffset < 0 || dataAreaOffset >= length_)
throw new ExtendedIllegalArgumentException("dataAreaOffset",
ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
// Validate the (dataAreaOffset, dataLength) combination.
if (dataAreaOffset+data.length() > length_)
throw new ExtendedIllegalArgumentException("data",
ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
if (impl_ == null)
chooseImpl();
// Do the write
impl_.write(data, dataAreaOffset, type);
// Fire the WRITTEN event.
fireWritten();
}
/**
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.
@see #read(byte[],int,int,int)
**/
public void write(byte[] dataBuffer, int dataBufferOffset, int dataAreaOffset, int dataLength)
throws AS400SecurityException,
ErrorCompletingRequestException,
InterruptedException,
IOException,
ObjectDoesNotExistException
{
super.write(dataBuffer, dataBufferOffset, dataAreaOffset, dataLength);
}
}