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