src.com.ibm.as400.access.Converter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400-jdk8 Show documentation
Show all versions of jt400-jdk8 Show documentation
The Open Source version of the IBM Toolbox for Java
The newest version!
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: Converter.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.CharConversionException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.Serializable;
import java.io.UnsupportedEncodingException;
/** A character set converter between Java String objects
*
*/
public class Converter implements Serializable
{
static final long serialVersionUID = 4L;
private static final String BUFFER_OVERFLOWED = "Converted field overflows destination array.";
public transient ConverterImpl impl;
private String encoding_ = null;
private int ccsid_ = -1;
private AS400 system_ = null;
// Gets a Converter object from the pool using a "best guess" based on the default Locale.
public Converter()
{
ccsid_ = ExecutionEnvironment.getBestGuessAS400Ccsid();
try
{
chooseImpl();
}
catch (UnsupportedEncodingException e)
{
Trace.log(Trace.ERROR, "Unexpected CCSID returned from getBestGuessAS400Ccsid: " + ccsid_, e);
throw new InternalErrorException(InternalErrorException.UNEXPECTED_EXCEPTION, e);
}
}
// Constructs a character set conversion object using the specified character encoding.
// @param encoding The name of a character encoding.
// @exception UnsupportedEncodingException If the encoding is not supported.
public Converter(String encoding) throws UnsupportedEncodingException
{
encoding_ = encoding;
chooseImpl();
}
// Constructs a character set conversion object using the specified ccsid.
// @param ccsid The CCSID of the server text.
// @param system The system object representing the server with which to connect.
// @exception UnsupportedEncodingException If the ccsid is not supported.
public Converter(int ccsid) throws UnsupportedEncodingException
{
ccsid_ = ccsid;
chooseImpl();
}
// Constructs a character set conversion object using the specified ccsid.
// @param ccsid The CCSID of the server text.
// @param system The system object representing the server with which to connect.
// @exception UnsupportedEncodingException If the ccsid is not supported.
public Converter(int ccsid, AS400 system) throws UnsupportedEncodingException
{
ccsid_ = ccsid;
system_ = system;
chooseImpl();
}
// Deserializes and initializes transient data.
private void readObject(ObjectInputStream in) throws ClassNotFoundException, IOException
{
in.defaultReadObject();
chooseImpl();
}
// Get the proper implementation object.
private void chooseImpl() throws UnsupportedEncodingException
{
if (system_ == null)
{
// Only alternative is to try to load remote impl.
impl = (ConverterImpl)AS400.loadImpl("com.ibm.as400.access.ConverterImplRemote");
if (impl == null) throw new UnsupportedEncodingException();
if (encoding_ != null)
{
impl.setEncoding(encoding_);
}
else
{
impl.setCcsid(ccsid_, null);
}
}
else
{
// Load proxy or remote impl.
impl = (ConverterImpl)system_.loadImpl2("com.ibm.as400.access.ConverterImplRemote", "com.ibm.as400.access.ConverterImplProxy");
AS400Impl systemImpl = system_.getImpl();
try
{
impl.setCcsid(ccsid_, systemImpl);
}
catch (UnsupportedEncodingException e)
{
try
{
system_.connectService(AS400.CENTRAL);
impl.setCcsid(ccsid_, systemImpl);
}
catch (Exception ee)
{
throw e;
}
}
}
}
// Converts the specified bytes into a String.
// @param source The bytes to convert.
// @return The resultant String.
public String byteArrayToString(byte[] source)
{
return impl.byteArrayToString(source, 0, source.length);
}
// Converts the specified bytes into a String.
// @param source The bytes to convert.
// @param offset The offset into the source array for the start of the data.
// @return The resultant String.
public String byteArrayToString(byte[] source, int offset)
{
return impl.byteArrayToString(source, offset, source.length - offset);
}
// Converts the specified bytes into a String.
// @param source The bytes to convert.
// @param offset The offset into the source array for the start of the data.
// @param length The number of bytes of data to read from the array.
// @return The resultant String.
public String byteArrayToString(byte[] source, int offset, int length)
{
return impl.byteArrayToString(source, offset, length);
}
// Converts the specified bytes into a String.
// @param source The bytes to convert.
// @param offset The offset into the source array for the start of the data.
// @param length The number of bytes of data to read from the array.
// @param type The output string type as defined by the CDRA (Character Data Respresentation Architecture). One of the following constants defined in BidiStringType: ST5 (LTR), ST6 (RTL), ST10 (Contextual LTR), or ST11 (Contextual RTL).
// @return The resultant String.
String byteArrayToString(byte[] source, int offset, int length, int type)
{
return byteArrayToString(source, offset, length, new BidiConversionProperties(type));
}
// Converts the specified bytes into a String.
// @param source The bytes to convert.
// @param offset The offset into the source array for the start of the data.
// @param length The number of bytes of data to read from the array.
// @param properties The bidi conversion properties.
// @return The resultant String.
String byteArrayToString(byte[] source, int offset, int length, BidiConversionProperties properties)
{
return impl.byteArrayToString(source, offset, length, properties);
}
// Returns the ccsid of this conversion object.
// @return The ccsid.
public int getCcsid()
{
return impl.getCcsid();
}
// Returns the encoding of this conversion object.
// @return The encoding.
public String getEncoding()
{
return impl.getEncoding();
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @return The resultant byte array.
public byte[] stringToByteArray(String source)
{
return impl.stringToByteArray(source);
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param type The output string type as defined by the CDRA (Character Data Respresentation Architecture). One of the following constants defined in BidiStringType: ST5 (LTR), ST6 (RTL), ST10 (Contextual LTR), or ST11 (Contextual RTL).
// @return The resultant byte array.
byte[] stringToByteArray(String source, int type)
{
return stringToByteArray(source, new BidiConversionProperties(type));
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param properties The bidi conversion properties.
// @return The resultant byte array.
byte[] stringToByteArray(String source, BidiConversionProperties properties)
{
return impl.stringToByteArray(source, properties);
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param destination The destination byte array.
// @exception CharConversionException If destination is not large enough to hold the converted string.
public void stringToByteArray(String source, byte[] destination) throws CharConversionException
{
byte[] convertedBytes = impl.stringToByteArray(source);
if (convertedBytes.length > destination.length)
{
// Copy as much as will fit.
System.arraycopy(convertedBytes, 0, destination, 0, destination.length);
Trace.log(Trace.ERROR, BUFFER_OVERFLOWED);
throw new CharConversionException();
}
System.arraycopy(convertedBytes, 0, destination, 0, convertedBytes.length);
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param destination The destination byte array.
// @param offset The offset into the destination array for the start of the data.
// @exception CharConversionException If destination is not large enough to hold the converted string.
public void stringToByteArray(String source, byte[] destination, int offset) throws CharConversionException
{
byte[] convertedBytes = impl.stringToByteArray(source);
if (convertedBytes.length > destination.length - offset)
{
// Copy as much as will fit.
System.arraycopy(convertedBytes, 0, destination, offset, destination.length - offset);
Trace.log(Trace.ERROR, BUFFER_OVERFLOWED);
throw new CharConversionException();
}
System.arraycopy(convertedBytes, 0, destination, offset, convertedBytes.length);
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param destination The destination byte array.
// @param offset The offset into the destination array for the start of the data.
// @param length The number of bytes of data to write into the array.
// @exception CharConversionException If destination is not large enough to hold the converted string.
public void stringToByteArray(String source, byte[] destination, int offset, int length) throws CharConversionException
{
byte[] convertedBytes = impl.stringToByteArray(source);
if (convertedBytes.length > length)
{
// Copy as much as will fit.
System.arraycopy(convertedBytes, 0, destination, offset, length);
Trace.log(Trace.ERROR, BUFFER_OVERFLOWED);
throw new CharConversionException();
}
System.arraycopy(convertedBytes, 0, destination, offset, convertedBytes.length);
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param destination The destination byte array.
// @param offset The offset into the destination array for the start of the data.
// @param length The number of bytes of data to write into the array.
// @param type The output string type as defined by the CDRA (Character Data Respresentation Architecture). One of the following constants defined in BidiStringType: ST5 (LTR), ST6 (RTL), ST10 (Contextual LTR), or ST11 (Contextual RTL).
// @exception CharConversionException If destination is not large enough to hold the converted string.
void stringToByteArray(String source, byte[] destination, int offset, int length, int type) throws CharConversionException
{
stringToByteArray(source, destination, offset, length, new BidiConversionProperties(type));
}
// Converts the specified String into bytes.
// @param source The String to convert.
// @param destination The destination byte array.
// @param offset The offset into the destination array for the start of the data.
// @param length The number of bytes of data to write into the array.
// @param properties The bidi conversion properties.
// @exception CharConversionException If destination is not large enough to hold the converted string.
void stringToByteArray(String source, byte[] destination, int offset, int length, BidiConversionProperties properties) throws CharConversionException
{
byte[] convertedBytes = impl.stringToByteArray(source, properties);
if (convertedBytes.length > length)
{
// Copy as much as will fit.
System.arraycopy(convertedBytes, 0, destination, offset, length);
Trace.log(Trace.ERROR, BUFFER_OVERFLOWED);
throw new CharConversionException();
}
System.arraycopy(convertedBytes, 0, destination, offset, convertedBytes.length);
}
}