/*
Реализация среды исполнения языка программирования
Объектно-ориентированный продвинутый векторный транслятор
Copyright © 2021, 2024 Малик Разработчик
Это свободная программа: вы можете перераспространять ее и/или изменять
ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
в каком она была опубликована Фондом свободного программного обеспечения;
либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
Эта программа распространяется в надежде, что она будет полезной,
но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
общественной лицензии GNU.
Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
вместе с этой программой. Если это не так, см.
<https://www.gnu.org/licenses/>.
*/
package avt.io;
import avt.io.extension.*;
public class ByteArrayInputStream(Object, Closeable, Extension, MarkExtension, ByteReader, LimitedSizeExtension, SeekExtension, Extendable)
{
protected int fldMarked;
protected int fldLength;
protected int fldPosition;
protected byte[] fldArray;
public () { }
public (byte[] array) {
fldLength = array == null ? 0 : array.length;
fldArray = array;
}
public (byte[] array, int length) {
int alength = array == null ? 0 : array.length;
fldLength = length < 0 ? 0 : length < alength ? length : alength;
fldArray = array;
}
public (byte[] array, int length, int position) {
int alength = array == null ? 0 : array.length;
int slength = fldLength = length < 0 ? 0 : length < alength ? length : alength;
fldPosition = position < 0 ? 0 : position < slength ? position : slength;
fldArray = array;
}
public void close() { }
public void reset() { fldPosition = fldMarked; }
public void mark(int transferLimit) { fldMarked = fldPosition; }
public int read() {
int position = fldPosition;
if(position >= fldLength) return -1;
int result = fldArray[position++] & 0xffi;
fldPosition = position;
return result;
}
public int read(byte[] dst) { return read(dst, 0, dst == null ? 0 : dst.length); }
public int read(byte[] dst, int offset, int length) {
if(dst == null)
{
throw new NullPointerException(String.format(avt.lang.package.getResourceString("null-pointer.argument"), new Object[] { "dst" }));
}
Array.checkBounds(dst, offset, length);
if(length <= 0) return 0;
int position = fldPosition;
int remainder = fldLength - position;
if(remainder <= 0) return -1;
int result = remainder < length ? remainder : length;
Array.copy(fldArray, position, dst, offset, result);
fldPosition = position + result;
return result;
}
public long skip(long bytesQuantity) {
if(bytesQuantity <= 0L) return 0L;
int length = bytesQuantity < (long) Int.MAX_VALUE ? (int) bytesQuantity : Int.MAX_VALUE;
int position = fldPosition;
int remainder = fldLength - position;
int result = remainder < length ? remainder : length;
fldPosition = position + result;
return (long) result;
}
public long available() { return (long) (fldLength - fldPosition); }
public long position() { return (long) fldPosition; }
public long size() { return (long) fldLength; }
public long seek(long offset, int from) {
long position;
long length = (long) fldLength;
switch(from)
{
case BEGIN:
position = offset;
break;
case END:
position = offset + length;
break;
case CURRENT:
position = offset + (long) fldPosition;
break;
default:
throw new IllegalArgumentException(String.format(avt.lang.package.getResourceString("illegal-argument"), new Object[] { "from" }));
}
if(position < 0L) position = 0L;
if(position > length) position = length;
return (long) (fldPosition = (int) position);
}
public Extension[] getExtensions() { return new Extension[] { this }; }
}