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

src.com.ibm.as400.access.ConverterImplRemote Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename:  ConverterImplRemote.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.UnsupportedEncodingException;

public class ConverterImplRemote implements ConverterImpl
{
    private static final String copyright = "Copyright (C) 1997-2004 International Business Machines Corporation and others.";

    public ConvTable table_;

    public ConverterImplRemote()
    {
    }

    public ConverterImplRemote(ConvTable table)
    {
        table_ = table;
    }

    String byteArrayToString(byte[] source)
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid. @C5C
        return byteArrayToString(source, 0, source.length, new BidiConversionProperties());
    }

    String byteArrayToString(byte[] source, int offset)
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid. @C5C
        return byteArrayToString(source, offset, source.length - offset, new BidiConversionProperties());
    }

    public String byteArrayToString(byte[] source, int offset, int length)
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid. @C5C
        return byteArrayToString(source, offset, length, new BidiConversionProperties());
    }                                                                     

    public String byteArrayToString(byte[] source, int offset, int length, int type)
    {
        return byteArrayToString(source, offset, length, new BidiConversionProperties(type));
    }

    public String byteArrayToString(byte[] source, int offset, int length, BidiConversionProperties properties)
    {
        return table_.byteArrayToString(source, offset, length, properties);
    }

    static ConverterImplRemote getConverter(int ccsid, AS400ImplRemote system) throws UnsupportedEncodingException
    {
        return new ConverterImplRemote(ConvTable.getTable(ccsid, system));
    }

    public String getEncoding()
    {
        return table_.getEncoding();
    }

    public int getCcsid()
    {
        return table_.getCcsid();
    }

    // Returns the string type of the text based on the ccsid.  If the text is bidi, then the string type will be set accordingly.  
    // If not, the default it LTR (left-to-right) text.
    // @return  The string type.
    int getStringType(int ccsid)
    {
        if (AS400BidiTransform.isBidiCcsid(ccsid))
        {
            return AS400BidiTransform.getStringType(ccsid);
        }
        else
        {
            return BidiStringType.DEFAULT;
        }
    }

    public void setCcsid(int ccsid, AS400Impl system) throws UnsupportedEncodingException
    {
        table_ = ConvTable.getTable(ccsid, null);
    }

    public void setEncoding(String encoding) throws UnsupportedEncodingException
    {
        table_ = ConvTable.getTable(encoding);
    }

    public byte[] stringToByteArray(String source)
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid.  @C5C
        return stringToByteArray(source, new BidiConversionProperties());
    }

    public byte[] stringToByteArray(String source, int type)
    {
        return stringToByteArray(source, new BidiConversionProperties(type));
    }

    public byte[] stringToByteArray(String source, BidiConversionProperties properties)
    {
        return table_.stringToByteArray(source, properties);
    }

    void stringToByteArray(String source, byte[] destination) throws CharConversionException
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid.  @C5C
        byte[] convertedBytes = stringToByteArray(source, new BidiConversionProperties());
        if (convertedBytes.length > destination.length)
        {
            // Copy as much as will fit.
            System.arraycopy(convertedBytes, 0, destination, 0, destination.length);
            if (Trace.traceOn_) Trace.log(Trace.CONVERSION, "Destination not large enough during conversion: " + source.length()+"," + destination.length);
            throw new CharConversionException();
        }
        System.arraycopy(convertedBytes, 0, destination, 0, convertedBytes.length);
    }

    void stringToByteArray(String source, byte[] destination, int offset) throws CharConversionException
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid.  @C5C
        byte[] convertedBytes = stringToByteArray(source, new BidiConversionProperties());
        if (convertedBytes.length > destination.length - offset)
        {
            // Copy as much as will fit.
            System.arraycopy(convertedBytes, 0, destination, offset, destination.length - offset);
            if (Trace.traceOn_) Trace.log(Trace.CONVERSION, "Destination not large enough during conversion: " + source.length() + "," + destination.length + "," + offset);
            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 length of data to write into the array.
    // @exception  CharConversionException  If destination is not large enough to hold the converted string.
    void stringToByteArray(String source, byte[] destination, int offset, int length) throws CharConversionException
    {
    	// Note:  The type of BidiConversionProperties reflects the Java String type.
    	//        This should be the default value instead of being set from the ccsid.  @C5C
        stringToByteArray(source, destination, offset, length, new BidiConversionProperties());
    }

    // 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 length of data to write into the array.
    // @param  type  the bidi string type.
    // @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));
    }

    void stringToByteArray(String source, byte[] destination, int offset, int length, BidiConversionProperties properties) throws CharConversionException
    {
        byte[] convertedBytes = stringToByteArray(source, properties);
        if (convertedBytes.length > length)
        {
            // Copy as much as will fit.
            System.arraycopy(convertedBytes, 0, destination, offset, length);
            if (Trace.traceOn_) Trace.log(Trace.CONVERSION, "Destination not large enough during conversion: " + source.length() + "," + destination.length + "," + offset + "," + length);
            throw new CharConversionException();
        }
        System.arraycopy(convertedBytes, 0, destination, offset, convertedBytes.length);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy