All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.DDMS38OpenFeedback Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: DDMS38OpenFeedback.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-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.IOException;

/**
 *Class representing the open feedback structure.  The structure
 *is described by CINC WWODPOFB.
**/
class DDMS38OpenFeedback
{
  // offsets and byte lengths of the various portions of the feedback structure
  // that we are interested in
  private static final int FILE_OPEN_TYPE = 10;
  private static final int FILE_NAME = 11;
  private static final int FILE_NAME_LENGTH = 10;
  private static final int LIB_NAME = 21;
  private static final int LIB_NAME_LENGTH = 10;
  private static final int MBR_NAME = 31;
  private static final int MBR_NAME_LENGTH = 10;
  private static final int RECORD_LEN = 41;
  private static final int INP_BUFFER_LEN = 45;
  private static final int OUT_BUFFER_LEN = 49;
  private static final int NUM_RECORDS = 53;
  private static final int ACCESS_TYPE = 57;
  private static final int ACCESS_TYPE_LENGTH = 2;
  private static final int SUPPORT_DUPLICATE_KEYS = 59;
  private static final int SUPPORT_DUPLICATE_KEYS_LENGTH = 1;
  private static final int SOURCE_FILE_INDICATOR = 60;
  private static final int SOURCE_FILE_INDICATOR_LENGTH = 1;
  private static final int UFCB_PARAMETERS = 61;
  private static final int UFCB_PARAMETERS_LENGTH = 10;
  private static final int MAX_BLOCKED_RECORDS_TRANSFERRED = 71;
  private static final int RECORD_INCREMENT = 73;
  private static final int OPEN_FLAGS_1= 75;   // Contains info on if MBR(*ALL) was specified, if this
                                       // is a logical join file, etc.
  private static final int NUMBER_OF_ASSOCIATED_PHYS_FILE_MBRS = 76;
  private static final int MAX_RECORD_LENGTH = 82;
  private static final int RECORD_WAIT_TIME = 84;
  private static final int OPEN_FLAGS_2 = 88;  // Contains info indicating if file contains variable
                                       // length fields, whether variable length processing will
                                       // be done, ODP scope, etc.
  private static final int NULL_FIELD_BYTE_MAP = 90;
  private static final int NULL_KEY_FIELD_BYTE_MAP = 92;
  private static final int CCSID = 98;
  private static final int FIXED_FIELD_LEN = 100; // Total length of the fixed fields in a variable length
                                         // record.
  private static final int MIN_RECORD_LEN = 102;

  // The openfeedback data
  byte[] data_;
  // The offset into the data.
  int offset_;
  // Converter for EBCDIC to ASCII conversions
  ConverterImplRemote conv_; //@B5C

  /**
   *Construct a DDMS38OpenFeedback object from the specified data.
   *@param system the system from which to get the CCSID for converions.
   *@param data the data from which to obtain the open feedback information.
  **/
  DDMS38OpenFeedback(AS400ImplRemote system, byte[] data) //@B5C
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    this(system, data, 0);
  }

  /**
   *Construct a DDMS38OpenFeedback object from the specified data.
   *@param system the system from which to get the CCSID for converions.
   *@param data the data from which to obtain the open feedback information.
  **/
  DDMS38OpenFeedback(AS400ImplRemote system, byte[] data, int offset) //@B5C
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    data_ = data;
    offset_ = offset;
    conv_ = ConverterImplRemote.getConverter(system.getCcsid(), system); //@B5C
  }

  /**
   *Returns the access type of the file.
   *@return the access type if the the file.
  **/
  String getAccessType()
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    return conv_.byteArrayToString(data_, offset_ + ACCESS_TYPE,
                                   ACCESS_TYPE_LENGTH);
  }

  /**
   *Returns the CCSID of the file.
   *@return the CCSID of the file.
  **/
  int getCCSID()
  {
    return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ + CCSID);
  }

  /**
   *Indicates if duplicate keys are supported by the file.
   *@return true if duplicate keys are supported; false otherwise.
  **/
  boolean duplicateKeysSupported()
  {
    if (data_[offset_ + SUPPORT_DUPLICATE_KEYS] == (byte)0xC4)
    {
      return true;
    }
    return false;
  }

  /**
   *Returns the file name of the file.
   *@return the file name of the file.
  **/
  String getFileName()
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    return conv_.byteArrayToString(data_, offset_ + FILE_NAME,
                                   FILE_NAME_LENGTH);
  }

  /**
   *Returns the input buffer length for the file.
   *@return the input buffer length.
  **/
  int getInputBufferLength()
  {
    return BinaryConverter.byteArrayToInt(data_, offset_ + INP_BUFFER_LEN);
  }

  /**
   *Returns the library name of the file.
   *@return the library name of the file.
  **/
  String getLibraryName()
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    return conv_.byteArrayToString(data_, offset_ + LIB_NAME, LIB_NAME_LENGTH);
  }

  /**
   *Returns the maximum number of records that can read or written at one time.
   *@return the maximum number of records that can be transferred at one time.
  **/
  int getMaxNumberOfRecordsTransferred()
  {
    return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ + MAX_BLOCKED_RECORDS_TRANSFERRED);
  }

  /**
   *Returns the member name.
   *@return the member name.
  **/
  String getMemberName()
    throws AS400SecurityException,
           InterruptedException,
           IOException
  {
    return conv_.byteArrayToString(data_, offset_ + MBR_NAME, MBR_NAME_LENGTH);
  }

  /**
   *Returns the offset to the null field byte map for a record.
   *@return the offset to the null field byte map.
  **/
  int getNullFieldByteMapOffset()
  {
    return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ + NULL_FIELD_BYTE_MAP);
  }

  /**
   *Returns the number of records in the file at open time.
   *@return the number of records in the file at open time.
  **/
  int getNumberOfRecords()
  {
    return BinaryConverter.byteArrayToInt(data_, offset_ + NUM_RECORDS);
  }

  /**
   *Returns the type of open for which the file is opened.
   *@return the type of open for which the file is opened.
  **/
  int getOpenType()
  {
    int type = data_[offset_ + FILE_OPEN_TYPE] & 0xFFFF;
    if (type == 64 || type == 68 || type == 192 || type == 196)
    {
      return AS400FileConstants.READ_ONLY; //@B0C
    }
    else if (type == 32 || type == 36 || type == 160 || type == 164)
    {
      return AS400FileConstants.WRITE_ONLY; //@B0C
    }
    else
    {
      return AS400FileConstants.READ_WRITE; //@B0C
    }
  }

  /**
   *Returns the output buffer length for the file.
   *@return the output buffer length.
  **/
  int getOutputBufferLength()
  {
    return BinaryConverter.byteArrayToInt(data_, offset_ + OUT_BUFFER_LEN);
  }

  /**
   *Returns the record increment for the records in the file.  This is the number
   *of bytes that will be returned or that need to be sent for a single record.
   *It includes bytes for the record data, a gap of zero or more bytes and bytes
   *for the null field byte map.
   *@return the record increment.
  **/
  int getRecordIncrement()
  {
    return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ +  RECORD_INCREMENT);
  }

  /**
   *Returns the record length of the records in the file.
   *@return the record length of the records in the file.
  **/
  int getRecordLength()
  {
    return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ + RECORD_LEN);
  }

  /**
   *Indicates if the file contains variable length fields.
   *@return true if the file contains variable length fields; false otherwise.
  **/
  boolean hasVariableLengthFields()
  {
    if ((data_[offset_ + OPEN_FLAGS_2 + 1] & 0x80) == 0x80)
    {
      return true;
    }
    return false;
  }

  /**
   *Indicates if the file is a logical file.
   *@return true if the file is a logical file; false otherwise.
  **/
  boolean isLogicalFile()
  {
    if ((data_[offset_ + OPEN_FLAGS_1] & 0x80) == 0x80)
    {
      return true;
    }
    return false;
  }

  /**
   *Indicates if the file is a logical join file.
   *@return true if the file is a logical join file; false otherwise.
  **/
  boolean isLogicalJoinFile()
  {
    if ((data_[offset_ + OPEN_FLAGS_1] & 0x04) == 0x04)
    {
      return true;
    }
    return false;
  }

  /**
   *Indicates if the file contains null capable fields.
   *@return true if the file contains null capable fields; false otherwise.
  **/
  boolean isNullCapable()
  {
    if ((data_[offset_ + OPEN_FLAGS_2 + 1] & 0x40) == 0x40)
    {
      return true;
    }
    return false;
  }

  /**
   *Indicates if the file is a source file.
   *@return true if the file is a source file; false otherwise.
  **/
  boolean isSourceFile()
  {
    return (data_[offset_ + SOURCE_FILE_INDICATOR] == (byte)0xE8);
  }

  /**
   *Returns the contents of the openfeedback area as a string.  Used for
   *logging diagnostic information regarding the open of a file.
   *@return the contents of the openfeedback area as a string.
  **/
  public String toString()
  {
    StringBuffer str = new StringBuffer(0);
    try
    {
      str.append("Open type: ");
      str.append(getOpenType());
      str.append("\n");

      str.append("Library name: ");
      str.append(getLibraryName());
      str.append("\n");

      str.append("File name: ");
      str.append(getFileName());
      str.append("\n");

      str.append("Member name: ");
      str.append(getMemberName());
      str.append("\n");

      str.append("Record length: ");
      str.append(getRecordLength());
      str.append("\n");

      str.append("Input buffer length: ");
      str.append(getInputBufferLength());
      str.append("\n");

      str.append("Output buffer length: ");
      str.append(getOutputBufferLength());
      str.append("\n");

      str.append("Number of records: ");
      str.append(getNumberOfRecords());
      str.append("\n");

      str.append("Access type: ");
      str.append(getAccessType());
      str.append("\n");

      str.append("Duplicate keys supported: ");
      str.append(duplicateKeysSupported());
      str.append("\n");

      str.append("Source file: ");
      str.append(isSourceFile());
      str.append("\n");

      str.append("Max blocked records transferred: ");
      str.append(getMaxNumberOfRecordsTransferred());
      str.append("\n");

      str.append("Record increment: ");
      str.append(getRecordIncrement());
      str.append("\n");

      str.append("Has variable length fields: ");
      str.append(hasVariableLengthFields());
      str.append("\n");

      str.append("Is null capable: ");
      str.append(isNullCapable());
      str.append("\n");

      str.append("Offset to null byte field map: ");
      str.append(getNullFieldByteMapOffset());
      str.append("\n");

      str.append("Logical file: ");
      str.append(isLogicalFile());
      str.append("\n");

      str.append("Logical join file: ");
      str.append(isLogicalJoinFile());
      str.append("\n");

      str.append("CCSID: ");
      str.append(getCCSID());
      str.append("\n");
    }
    catch(Exception e)
    { // This should never happen; the AS400 object is connected when
      // it is provided to us on the constructor.  Need to shut up the compiler.
      Trace.log(Trace.ERROR, e);
      throw new InternalErrorException(InternalErrorException.UNKNOWN, e);
    }
    return str.toString();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy