CharSequence.avt

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

/*
    Исходный код среды исполнения ПВТ-ОО.

    Этот исходный код является частью проекта ПВТ-ОО.

    Copyright © 2021 Малик Разработчик

    Это свободная программа: вы можете перераспространять её и/или
    изменять её на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
    в каком она была опубликована Фондом свободного программного обеспечения;
    либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.

    Эта программа распространяется в надежде, что она может быть полезна,
    но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
    или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЁННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
    общественной лицензии GNU.

    Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
    вместе с этой программой. Если это не так, см.
    <http://www.gnu.org/licenses/>.
*/

package avt.lang;

import avt.lang.array.*;
import platform.independent.streamformat.*;

public abstract service CharSequence(Object, Cloneable, DataHolder, CharArray, Measureable)
{
    public abstract CharSequence subsequence(int beginIndex);

    public abstract CharSequence subsequence(int beginIndex, int endIndex);

    public void getChars(int beginIndex, int endIndex, MutableCharArray dst, int offset) {
        int length = this.length;
        if((beginIndex | endIndex) < 0 || beginIndex > length || endIndex > length || beginIndex > endIndex)
        {
            throw new StringIndexOutOfBoundsException("индекс символа строки выходит из диапазона");
        }
        if(dst == null)
        {
            throw new NullPointerException("аргумент dst равен нулевой ссылке");
        }
        Array.checkBounds(dst, offset, length = endIndex - beginIndex);
        while(length-- > 0) dst[offset++] = this[beginIndex++];
    }

    public void copyInto(MutableCharArray dst, int offset) { getChars(0, length, dst, offset); }

    public char[] toCharArray() {
        int length = this.length;
        char[] result = new char[length];
        getChars(0, length, result, 0);
        return result;
    }

    public String join(CharSequence anot) {
        if(anot == null) return convertToString();
        int thisLength = this.length;
        int anotLength = anot.length;
        long resultLength = (long) thisLength + (long) anotLength;
        if(resultLength > Int.MAX_VALUE)
        {
            throw new BufferTooLargeError("объём буфера очень велик");
        }
        char[] result = new char[(int) resultLength];
        this.getChars(0, thisLength, result, 0);
        anot.getChars(0, anotLength, result, thisLength);
        return new String(result);
    }

    public String join(CharSequence[] seqs) {
        if(seqs == null) return convertToString();
        int thisLength = this.length;
        int seqsLength = seqs.length;
        int[] seqsLengths = new int[seqsLength];
        CharSequence[] seqsCopy = new CharSequence[seqsLength];
        long resultLength = (long) thisLength;
        for(int i = 0; i < seqsLength; i++)
        {
            Measureable seq = seqsCopy[i] = seqs[i];
            int anotLength = seq == null ? 0 : seq.length;
            if((resultLength += (long) anotLength) > Int.MAX_VALUE)
            {
                throw new BufferTooLargeError("объём буфера очень велик");
            }
            seqsLengths[i] = anotLength;
        }
        char[] result = new char[(int) resultLength];
        for(int position = thisLength, getChars(0, thisLength, result, 0), int i = 0; i < seqsLength; i++)
        {
            CharSequence seq = seqsCopy[i];
            int anotLength = seq == null ? 0 : seq.length;
            seq.getChars(0, anotLength, result, position);
            position += anotLength;
        }
        return new String(result);
    }

    private String convertToString() { return this instanceof String ? (String) this : new String(toCharArray()); }
}