blob: 6d3fb908e6265f9581feb3c43637cc799d7e1ae4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.fontbox.cff;
import java.io.IOException;
/**
* This class implements the DataInput interface using a byte buffer as source.
*
* @author Villu Ruusmann
*/
public class DataInputByteArray implements DataInput
{
private final byte[] inputBuffer;
private int bufferPosition = 0;
/**
* Constructor.
* @param buffer the buffer to be read
*/
public DataInputByteArray(byte[] buffer)
{
inputBuffer = buffer;
}
/**
* Determines if there are any bytes left to read or not.
* @return true if there are any bytes left to read
*/
@Override
public boolean hasRemaining() throws IOException
{
return bufferPosition < inputBuffer.length;
}
/**
* Returns the current position.
* @return current position
*/
@Override
public int getPosition()
{
return bufferPosition;
}
/**
* Sets the current position to the given value.
*
* @param position the given position
* @throws IOException if the new position ist out of range
*/
@Override
public void setPosition(int position) throws IOException
{
if (position < 0)
{
throw new IOException("position is negative");
}
if (position >= inputBuffer.length)
{
throw new IOException(
"New position is out of range " + position + " >= " + inputBuffer.length);
}
bufferPosition = position;
}
/**
* Read one single byte from the buffer.
* @return the byte
* @throws IOException if an error occurs during reading
*/
@Override
public byte readByte() throws IOException
{
if (!hasRemaining())
{
throw new IOException("End off buffer reached");
}
return inputBuffer[bufferPosition++];
}
/**
* Read one single unsigned byte from the buffer.
* @return the unsigned byte as int
* @throws IOException if an error occurs during reading
*/
@Override
public int readUnsignedByte() throws IOException
{
if (!hasRemaining())
{
throw new IOException("End off buffer reached");
}
return inputBuffer[bufferPosition++] & 0xff;
}
/**
* Peeks one single unsigned byte from the buffer.
*
* @param offset offset to the byte to be peeked
* @return the unsigned byte as int
* @throws IOException if an error occurs during reading
*/
@Override
public int peekUnsignedByte(int offset) throws IOException
{
if (offset < 0)
{
throw new IOException("offset is negative");
}
if (bufferPosition + offset >= inputBuffer.length)
{
throw new IOException("Offset position is out of range " + (bufferPosition + offset)
+ " >= " + inputBuffer.length);
}
return inputBuffer[bufferPosition + offset] & 0xff;
}
/**
* Read a number of single byte values from the buffer.
* @param length the number of bytes to be read
* @return an array with containing the bytes from the buffer
* @throws IOException if an error occurs during reading
*/
@Override
public byte[] readBytes(int length) throws IOException
{
if (length < 0)
{
throw new IOException("length is negative");
}
if (inputBuffer.length - bufferPosition < length)
{
throw new IOException("Premature end of buffer reached");
}
byte[] bytes = new byte[length];
System.arraycopy(inputBuffer, bufferPosition, bytes, 0, length);
bufferPosition += length;
return bytes;
}
@Override
public int length() throws IOException
{
return inputBuffer.length;
}
}