/*
Исходный код среды исполнения ПВТ-ОО.
Этот исходный код является частью проекта ПВТ-ОО.
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()); }
}