src.com.ibm.as400.access.SCS5224Writer 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: SCS5224Writer.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.OutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
/**
* The SCS5224Writer class writes an SCS 5224 data stream to an output stream,
* translating characters into bytes of the specified CCSID.
* SCS5224Writer extends the SCS5256Writer and adds support for
* setting the characters per inch (CPI) and lines per inch (LPI).
*
* @see SCS5256Writer
**/
/* @A1C
* Fix setCPI() and setLPI() so that they call initPage() if the page has not
* been started yet.
*/
public class SCS5224Writer extends SCS5256Writer
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
private static final byte [] SCD = {0x2B, (byte)0xD2, 0x04, 0x29,
0x00, 0x00};
private static final byte [] SCGL = {0x2B, (byte)0xD1, 0x03,
(byte)0x81, (byte)0xFF};
private static final byte [] SLD = {0x2B, (byte)0xC6, 0x02, 0x00};
private byte LPI = 0x06;
/* Because a font can override the CPI, and vice versa, we need */
/* to keep a flag indicating which command to use to initialize */
/* the page. */
static final boolean FONT_ = false;
static final boolean CPI_ = true;
boolean fontOrCPI = CPI_;
byte CPI = 0x0A;
/**
* Constructs a SCS5224Writer. The default encoding will be used.
*
* @param out An OutputStream.
*
* @deprecated Replaced by SCS5224Writer(OutputStream, int, AS400).
Any SCS5224Writer object that is created without
specifying an AS400 system object on its constructor may
not behave as expected in certain environments.
**/
public SCS5224Writer(OutputStream out)
{
super(out);
}
/**
* Constructs a SCS5224Writer.
*
* @param out An OutputStream.
* @param ccsid The name of the target CCSID to be used.
*
* @exception UnsupportedEncodingException If ccsid is invalid.
* @deprecated Replaced by SCS5224Writer(OutputStream, int, AS400).
Any SCS5224Writer object that is created without
specifying an AS400 system object on its constructor may
not behave as expected in certain environments.
**/
public SCS5224Writer(OutputStream out,
int ccsid)
throws UnsupportedEncodingException
{
super(out, ccsid);
}
// @B1A
/**
* Constructs a SCS5224Writer.
*
* @param out An OutputStream.
* @param ccsid The name of the target CCSID to be used.
* @param system The system.
*
* @exception UnsupportedEncodingException If ccsid is invalid.
**/
public SCS5224Writer(OutputStream out,
int ccsid,
AS400 system)
throws UnsupportedEncodingException
{
super(out, ccsid, system);
}
/**
* Constructs a SCS5224Writer.
*
* @param out An OutputStream.
* @param encoding The name of the target encoding to be used.
*
* @exception UnsupportedEncodingException If encoding is invalid.
* @deprecated Replaced by SCS5224Writer(OutputStream, int, AS400).
Any SCS5224Writer object that is created without
specifying an AS400 system object on its constructor may
not behave as expected in certain environments.
**/
public SCS5224Writer(OutputStream out,
String encoding)
throws UnsupportedEncodingException
{
super(out, encoding);
}
/* Sends out controls to initialize the start of a page.
*
*/
void initPage()
throws IOException
{
super.initPage();
if (fontOrCPI == CPI_) setCPI(CPI);
setLPI(LPI);
setCodePage();
}
/* Sends SCGL command to set the code page
*
*/
void setCodePage()
throws IOException
{
byte [] cmd = SCGL;
int ccsid = getCcsid();
// SCSFontData fd = new SCSFontData();
int[] codePage = SCSFontData.codePage;
int length = codePage.length;
/* Loop through the list of code pages looking for a match. */
/* If one is found, add the corresponding ID to the command. */
/* If no match is found, the default ID is sent. */
for (int i = 0; i < length; i++)
{
if (ccsid == codePage[i])
{
cmd[cmd.length-1] = SCSFontData.codePageID[i];
break;
}
}
addToBuffer(cmd);
}
/** Sets characters per inch. All following text will be
* in the set pitch.
*
* @param cpi The characters per inch. Valid values are 10 and 15.
*
* @exception IOException If an error occurs while communicating
* with the system.
**/
public void setCPI(int cpi)
throws IOException
{
switch (cpi) {
case 10:
CPI = 10;
break;
case 15:
CPI = 15;
break;
default:
String arg = "CPI (" + String.valueOf(cpi) + ")";
throw new ExtendedIllegalArgumentException(arg, 2);
} /* endswitch */
fontOrCPI = CPI_;
// if (pageStarted_ == true) { @A1D
if (pageStarted_ == false) //@A1A
initPage(); //@A1A
else //@A1A
{
byte [] cmd = SCD;
cmd[cmd.length-1] = CPI;
addToBuffer(cmd);
}
}
/** Sets lines per inch. All following lines will be in the set
* lines per inch.
*
* @param lpi The lines per inch. Valid values are 4, 6, 8, 9, and
* 12.
*
* @exception IOException If an error occurs while communicating
* with the system.
**/
public void setLPI(int lpi)
throws IOException
{
byte LPI1440;
switch (lpi) {
case 4:
LPI = 4;
LPI1440 = 0x12;
break;
case 6:
LPI = 6;
LPI1440 = 0x0C;
break;
case 8:
LPI = 8;
LPI1440 = 0x09;
break;
case 9:
LPI = 9;
LPI1440 = 0x08;
break;
case 12:
LPI = 12;
LPI1440 = 0x06;
break;
default:
String arg = "LPI (" + String.valueOf(lpi) + ")";
throw new ExtendedIllegalArgumentException(arg, 2);
} /* endswitch */
// if (pageStarted_ == true) { @A1D
if (pageStarted_ == false) //@A1A
initPage(); //@A1A
else //@A1A
{
byte [] cmd = SLD;
cmd[cmd.length-1] = LPI1440;
addToBuffer(cmd);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy