src.com.ibm.as400.access.DBReplyPackageInfo 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: DBReplyPackageInfo.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-2001 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.io.UnsupportedEncodingException; //@F1A
/**
Provides access to the package info portion of the reply data stream.
**/
class DBReplyPackageInfo {
private static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others.";
private byte[] data_;
private int offset_;
private int length_;
private int jobCCSID_; // @D1A
/**
Constructs a new DBReplyPackageInfo object. It initializes
the variables using the data provided.
* @param data
* @param offset
* @param length
* @param jobCCSID
**/
public DBReplyPackageInfo (byte[] data,
int offset,
int length,
int jobCCSID) // @D1A
{
data_ = data;
offset_ = offset;
length_ = length;
jobCCSID_ = jobCCSID; // @D1A
}
//---------------------------------------------------------
// The following structure is used to determine the amount
// needed to be added to the offset to get the appropriate
// data.
//
// offset+ field length
//
// 0 total length 4 bytes
// 4 ccsid 2 bytes
// 6 default collection 18 bytes
// 24 statement count 2 bytes
// 26 reserved 16 bytes
//
// 42 package entry info (repeated for each field)
// 0 statement needs default collection 1 byte
// 1 statement type 2 bytes
// 3 statement name 18 bytes
// 21 reserved 19 bytes
// 40 format offset 4 bytes
// 44 format length 4 bytes
// 48 text offset 4 bytes
// 52 text length 4 bytes
// 56 parameter marker format offset 4 bytes
// 60 parameter marker format length 4 bytes
//
// Note: these offsets are in terms of the start
// of the LL for this parameter (i.e.
// actually count from (offset_ - 6).
//
// x package statement text and formats
//
//---------------------------------------------------------
public DBDataFormat getDataFormat (int statementIndex)
throws DBDataStreamException
{
int offset = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 40);
int length = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 44);
if ((length != 6) && (length != 0)) { // @C0C
DBDataFormat dataFormat = new DBSQLDADataFormat(jobCCSID_); // @D1C
dataFormat.overlay (data_, (offset_ - 6) + offset);
return dataFormat;
}
else
return null;
}
public String getDefaultCollection (ConvTable converter) //@P0C
throws DBDataStreamException
{
return converter.byteArrayToString (data_, offset_ + 6, 18);
}
public int getCCSID ()
throws DBDataStreamException
{
return BinaryConverter.byteArrayToShort (data_, offset_ + 4);
}
private int getPackageEntryInfoOffset (int statementIndex)
{
return 42 + 64 * (statementIndex);
}
public DBDataFormat getParameterMarkerFormat (int statementIndex)
throws DBDataStreamException
{
int offset = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 56);
int length = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 60);
if ((length != 6) && (length != 0)) { // @C0C
DBDataFormat parameterMarkerFormat = new DBSQLDADataFormat(jobCCSID_); // @D1C
parameterMarkerFormat.overlay (data_, (offset_ - 6) + offset);
return parameterMarkerFormat;
}
else
return null;
}
public int getStatementCount ()
throws DBDataStreamException
{
return BinaryConverter.byteArrayToShort (data_, offset_ + 24);
}
public String getStatementName (int statementIndex, ConvTable converter) //@P0C
throws DBDataStreamException
{
try //@F1A
{
//@F1A Should use job CCSID, not unicode, to interpret statement name from datastream.
return ConvTable.getTable(jobCCSID_, null).byteArrayToString (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 3, 18); //@F1A
//@F1D return converter.byteArrayToString (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 3, 18);
//@F1A Changed code in JDPackageManager to now pass in null for converter.
}
catch (UnsupportedEncodingException uee) //@F1A
{
//@F1A Error shouldn't happen, but just in case, return "" so that
//@F1A code in AS400JDBCStatement which checks the length of what is
//@F1A returned from here to see if it's 0 will correctly detect that
//@F1A we are unable to use this name and will prepare the statement
//@F1A again on the system instead of taking a NullPointerException.
return ""; //@F1A
}
}
public int getStatementNeedsDefaultCollection (int statementIndex)
throws DBDataStreamException
{
return data_[offset_ + getPackageEntryInfoOffset (statementIndex)];
}
public String getStatementText (int statementIndex, ConvTable converter) //@P0C
throws DBDataStreamException
{
int offset = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 48);
int length = BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 52);
return converter.byteArrayToString (data_, (offset_ - 6) + offset, length);
}
public int getStatementTextLength (int statementIndex)
throws DBDataStreamException
{
return BinaryConverter.byteArrayToInt (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 52);
}
public int getStatementType (int statementIndex)
throws DBDataStreamException
{
return BinaryConverter.byteArrayToShort (data_, offset_ + getPackageEntryInfoOffset (statementIndex) + 1);
}
public int getTotalLength ()
throws DBDataStreamException
{
return BinaryConverter.byteArrayToInt (data_, offset_);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy