/* Copyright (c) 2001-2019, The HSQL Development Group
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * Redistributions of source code must retain the above copyright notice, this
 * list of conditions and the following disclaimer.
 *
 * Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * Neither the name of the HSQL Development Group nor the names of its
 * contributors may be used to endorse or promote products derived from this
 * software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG,
 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */


package org.hsqldb.rowio;

import java.io.EOFException;
import java.io.IOException;
import java.math.BigDecimal;
import java.math.BigInteger;

import org.hsqldb.error.Error;
import org.hsqldb.error.ErrorCode;
import org.hsqldb.lib.StringConverter;
import org.hsqldb.map.ValuePool;
import org.hsqldb.types.BinaryData;
import org.hsqldb.types.BlobData;
import org.hsqldb.types.BlobDataID;
import org.hsqldb.types.ClobData;
import org.hsqldb.types.ClobDataID;
import org.hsqldb.types.IntervalMonthData;
import org.hsqldb.types.IntervalSecondData;
import org.hsqldb.types.IntervalType;
import org.hsqldb.types.JavaObjectData;
import org.hsqldb.types.TimeData;
import org.hsqldb.types.TimestampData;
import org.hsqldb.types.Type;
import org.hsqldb.types.Types;

Provides methods for reading the data for a row from a byte array. The format of data is that used for storage of cached tables by v.1.6.x databases, apart from strings.
Author:Bob Preston (sqlbob@users dot sourceforge.net), Fred Toussi (fredt@users dot sourceforge.net)
Version:2.5.0
Since:1.7.0
/** * Provides methods for reading the data for a row from a * byte array. The format of data is that used for storage of cached * tables by v.1.6.x databases, apart from strings. * * @author Bob Preston (sqlbob@users dot sourceforge.net) * @author Fred Toussi (fredt@users dot sourceforge.net) * @version 2.5.0 * @since 1.7.0 */
public class RowInputBinary extends RowInputBase implements RowInputInterface { public boolean ignoreDataErrors; private RowOutputBinary out; public RowInputBinary() { this(64); } public RowInputBinary(int size) { super(size); } public RowInputBinary(byte[] buf) { super(buf); }
uses the byte[] buffer from out. At each reset, the buffer is set to the current one for out.
/** * uses the byte[] buffer from out. At each reset, the buffer is set * to the current one for out. */
public RowInputBinary(RowOutputBinary out) { super(out.getBuffer()); this.out = out; } public void readFully(byte[] b) { try { super.readFully(b); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public long readLong() { try { return super.readLong(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public int readInt() { try { return super.readInt(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public short readShort() { try { return super.readShort(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public char readChar() { try { return super.readChar(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public byte readByte() { try { return super.readByte(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public boolean readBoolean() { try { return super.readBoolean(); } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public int readType() { return readShort(); } public String readString() { try { int length = readInt(); if (length < 0) { throw Error.error(ErrorCode.GENERAL_IO_ERROR, "RowInputBinary - negative length"); } String s = StringConverter.readUTF(buffer, pos, length); s = ValuePool.getString(s); pos += length; return s; } catch (IOException e) { throw Error.error(e, ErrorCode.GENERAL_IO_ERROR, "RowInputBinary" + ' ' + getFilePosition()); } } public boolean readNull() { int b = readByte(); return b == 0; } protected String readChar(Type type) { return readString(); } protected Integer readSmallint() { return ValuePool.getInt(readShort()); } protected Integer readInteger() { return ValuePool.getInt(readInt()); } protected Long readBigint() { return ValuePool.getLong(readLong()); } protected Double readReal() { return ValuePool.getDouble(readLong()); } protected BigDecimal readDecimal(Type type) { byte[] bytes = readByteArray(); int scale = readInt(); BigInteger bigint = new BigInteger(bytes); return ValuePool.getBigDecimal(new BigDecimal(bigint, scale)); } protected Boolean readBoole() { return readBoolean() ? Boolean.TRUE : Boolean.FALSE; } protected TimeData readTime(Type type) { if (type.typeCode == Types.SQL_TIME) { return new TimeData(readInt(), readInt(), 0); } else { return new TimeData(readInt(), readInt(), readInt()); } } protected TimestampData readDate(Type type) { long date = readLong(); return new TimestampData(date); } protected TimestampData readTimestamp(Type type) { if (type.typeCode == Types.SQL_TIMESTAMP) { return new TimestampData(readLong(), readInt()); } else { return new TimestampData(readLong(), readInt(), readInt()); } } protected IntervalMonthData readYearMonthInterval(Type type) { long months = readLong(); return new IntervalMonthData(months, (IntervalType) type); } protected IntervalSecondData readDaySecondInterval(Type type) { long seconds = readLong(); int nanos = readInt(); return new IntervalSecondData(seconds, nanos, (IntervalType) type); } protected Object readOther() { return new JavaObjectData(readByteArray()); } protected BinaryData readBit() { int length = readInt(); byte[] b = new byte[(length + 7) / 8]; readFully(b); return BinaryData.getBitData(b, length); } protected BinaryData readUUID() { return new BinaryData(readByteArray(), false); } protected BinaryData readBinary() { return new BinaryData(readByteArray(), false); } protected ClobData readClob() { long id = readLong(); return new ClobDataID(id); } protected BlobData readBlob() { long id = readLong(); return new BlobDataID(id); } protected Object[] readArray(Type type) { type = type.collectionBaseType(); int size = readInt(); Object[] data = new Object[size]; for (int i = 0; i < size; i++) { data[i] = readData(type); } return data; }
Nulls in array are treated as 0
/** * Nulls in array are treated as 0 */
public int[] readIntArray() throws IOException { int size = readInt(); int[] data = new int[size]; for (int i = 0; i < size; i++) { if (!readNull()) { data[i] = readInt(); } } return data; } public Object[] readData(Type[] colTypes) { if (ignoreDataErrors) { return new Object[colTypes.length]; } return super.readData(colTypes); } // helper methods public byte[] readByteArray() { int length = readInt(); byte[] b = new byte[length]; readFully(b); return b; } public byte[] readByteArray16() { byte[] b = new byte[16]; readFully(b); return b; } public char[] readCharArray() throws IOException { int length = readInt(); char[] c = new char[length]; if (count - pos < c.length) { pos = count; throw new EOFException(); } for (int i = 0; i < c.length; i++) { int ch1 = buffer[pos++] & 0xff; int ch2 = buffer[pos++] & 0xff; c[i] = (char) ((ch1 << 8) + (ch2)); } return c; }
Used to reset the row, ready for Result data to be written into the byte[] buffer by an external routine.
/** * Used to reset the row, ready for Result data to be written into the * byte[] buffer by an external routine. * */
public void resetRow(int rowsize) { if (out != null) { out.reset(rowsize); buffer = out.getBuffer(); } super.reset(); }
Used to reset the row, ready for a new db row to be written into the byte[] buffer by an external routine.
/** * Used to reset the row, ready for a new db row to be written into the * byte[] buffer by an external routine. * */
public void resetRow(long filepos, int rowsize) { if (out != null) { out.reset(rowsize); buffer = out.getBuffer(); } super.resetRow(filepos, rowsize); } }