CharactersStorage.avt

Переключить прокрутку окна
Загрузить этот исходный код

/*
    Реализация среды исполнения языка программирования
    Объектно-ориентированный продвинутый векторный транслятор

    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 }
}