src.com.ibm.as400.access.DDMS38IOFB 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: DDMS38IOFB.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;
/**
*Class representing the S38IOFB data returned for the S38IOFB DDM term when
*a I/O operation is done on a database file.
**/
class DDMS38IOFB
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
private static final int RECORD_FORMAT = 0; // Offset to the record format name
private static final int RECORD_FORMAT_LENGTH = 10; // Length of the record format name
private static final int RECORD_LEN = 10; // Offset to the record length (4 bytes)
private static final int NUMBER_OF_RECORDS = 14; // Offset to the number of records returned
private static final int NUMBER_OF_RECORDS_LOCKED = 17; // Offset to the number of records locked
private static final int RRN_MOST_RECENTLY_LOCKED = 19; // Offset to the relative record number of the most recently locked record (4 bytes)
private static final int MEMBER_LOCKED = 23; // Offset to the member number of the most recently locked member
private static final int RECORD_NUMBER = 55; // Offset to record number of the record read
// Array containing IO feedback information
protected byte[] data_;
// Offset in data_ at which the IO feedback info starts
protected int offset_;
/**
*Constructs a DDMS38IOFB object from the specified data starting at the
*specified offset in data.
*@param data the data from which to extract the S38IOFB info.
*@param offset the offset in data at which the S38IOFB info starts.
**/
DDMS38IOFB(byte[] data, int offset)
{
// Set the instance data
// The getters will extract the information directly from data_ based on the
// defined constants and offset_.
// Both data and offset are expected to be valid and will not be checked here.
data_ = data;
offset_ = offset;
}
/**
*Returns the number of records returned from the i/o operation that this
*object provides feedback for.
*@return the number of records.
**/
int getNumberOfRecordsReturned()
{
return BinaryConverter.byteArrayToUnsignedShort(data_, offset_ + NUMBER_OF_RECORDS);
}
/**
*Returns the record length of the records for the i/o operation that this
*object provides feedback for.
*@return the record length.
**/
int getRecordLength()
{
return BinaryConverter.byteArrayToInt(data_, offset_ + RECORD_LEN);
}
/**
*Returns the record number of the record returned from the i/o operation that this
*object provides feedback for.
*@return the record number.
**/
int getRecordNumber()
{
return BinaryConverter.byteArrayToInt(data_, offset_ + RECORD_NUMBER);
}
/**
*Returns the information provided in the S38IOFB as a string. This method is
*used for logging S38IOFB information.
*@return the S38IOFB as a string.
**/
public String toString()
{
StringBuffer str = new StringBuffer();
str.append("Number of records returned: ");
str.append((new Integer(getNumberOfRecordsReturned())).toString());
str.append("\n");
str.append("Record length: ");
str.append((new Integer(getRecordLength())).toString());
str.append("\n");
return str.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy