/*
Реализация среды исполнения языка программирования
Объектно-ориентированный продвинутый векторный транслятор
Copyright © 2021, 2024 Малик Разработчик
Это свободная программа: вы можете перераспространять ее и/или изменять
ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
в каком она была опубликована Фондом свободного программного обеспечения;
либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
Эта программа распространяется в надежде, что она будет полезной,
но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
общественной лицензии GNU.
Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
вместе с этой программой. Если это не так, см.
<https://www.gnu.org/licenses/>.
*/
package avt.io.charset;
import avt.io.*;
import avt.io.extension.*;
import avt.lang.array.*;
public final class CharactersStorage(Object, Closeable, CharReader, Extension, LimitedSizeExtension, Extendable, Measureable)
{
private int fldPosition;
private final int fldLength;
private final char[] fldContent;
public (char[] content) {
fldLength = content == null ? 0 : content.length;
fldContent = content;
}
public (char[] content, int length) {
int clength = content == null ? 0 : content.length;
fldLength = length < 0 ? 0 : length < clength ? length : clength;
fldContent = content;
}
public (char[] content, int length, int position) {
int clength = content == null ? 0 : content.length;
int slength = fldLength = length < 0 ? 0 : length < clength ? length : clength;
fldPosition = position < 0 ? 0 : position < slength ? position : slength;
fldContent = content;
}
public void close() { }
public int read() {
int position = fldPosition;
if(position >= fldLength) return -1;
int result = fldContent[position++];
fldPosition = position;
return result;
}
public int read(char[] dst) { return read(dst, 0, dst == null ? 0 : dst.length); }
public int read(char[] 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 = length < remainder ? length : remainder;
Array.copy(fldContent, position, dst, offset, result);
fldPosition = position + result;
return result;
}
public long skip(long charsQuantity) {
if(charsQuantity <= 0L) return 0L;
int length = charsQuantity > (long) Int.MAX_VALUE ? Int.MAX_VALUE : (int) charsQuantity;
int position = fldPosition;
int remainder = fldLength - position;
int result = length < remainder ? length : remainder;
fldPosition = position + result;
return (long) result;
}
public long available() { return (long) (fldLength - fldPosition); }
public Extension[] getExtensions() { return new Extension[] { this }; }
public int length { read = fldLength }
public int position { read = fldPosition }
}