Char.avt

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

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

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

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

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

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

package avt.lang;

import avt.io.charset.basiclatin.*;
import avt.lang.locale.*;

public final class Char(Object, Numeric, Comparable, Cloneable)
{
    public static final char MIN_VALUE = '\u0000';
    public static final char MAX_VALUE = '\uffff';

    public static final int MIN_RADIX =  2;
    public static final int MAX_RADIX = 36;

    public static boolean isDigit(char character) {
        return BasicLatin.isDigit(character) || Locale.instance.isDigit(character);
    }

    public static boolean isLowerCase(char character) {
        return BasicLatin.isLowerCase(character) || Locale.instance.isLowerCase(character);
    }

    public static boolean isUpperCase(char character) {
        return BasicLatin.isUpperCase(character) || Locale.instance.isUpperCase(character);
    }

    public static char toLowerCase(char character) {
        return character < '\u0100' ? BasicLatin.toLowerCase(character) : Locale.instance.toLowerCase(character);
    }

    public static char toUpperCase(char character) {
        return character < '\u0100' ? BasicLatin.toUpperCase(character) : Locale.instance.toUpperCase(character);
    }

    public static char toChar(int digit) {
        return digit >= 0x00 && digit < 0x0a ? (char) (digit + '0') : digit >= 0x0a && digit < MAX_RADIX ? (char) (digit + ('a' - 0x0a)) : '?';
    }

    public static int toDigit(char character, int radix) {
        int result = -1;
        if(radix >= MIN_RADIX && radix <= MAX_RADIX)
        {
            if(character >= '0' && character <= '9')
            {
                result = character - '0';
            }
            else if(character >= 'a' && character <= 'z' || character >= 'A' && character <= 'Z')
            {
                result = (character & 0x1f) + 0x09;
            }
        }
        return result >= radix ? -1 : result;
    }

    public static int compareIgnoreCase(char character0, char character1) {
        if(((int) character0 | character1) < '\u0100')
        {
            return BasicLatin.toLowerCase(character0) - BasicLatin.toLowerCase(character1);
        }
        Locale locale = Locale.instance;
        return locale.toLowerCase(character0) - locale.toLowerCase(character1);
    }

    public static int compareLexicographically(char character0, char character1) {
        if(((int) character0 | character1) < '\u0100')
        {
            return BasicLatin.orderOf(character0) - BasicLatin.orderOf(character1);
        }
        Locale locale = Locale.instance;
        return locale.orderOf(character0) - locale.orderOf(character1);
    }

    private final char fldValue;

    public (int value) { fldValue = (char) value; }

    public boolean equals(Object anot) { return anot == this || anot instanceof Char && ((Char) anot).fldValue == fldValue; }

    public int hashCode() { return fldValue; }

    public long hashCodeAsLong() { return fldValue; }

    public String toString() { return new String(fldValue); }

    public char asChar() { return fldValue; }

    public byte asByte() { return (byte) fldValue; }

    public byte2 asByte2() { return (byte) fldValue; }

    public byte4 asByte4() { return (byte) fldValue; }

    public byte8 asByte8() { return (byte) fldValue; }

    public short asShort() { return (short) fldValue; }

    public short2 asShort2() { return (short) fldValue; }

    public short4 asShort4() { return (short) fldValue; }

    public short8 asShort8() { return (short) fldValue; }

    public int asInt() { return fldValue; }

    public int2 asInt2() { return fldValue; }

    public int4 asInt4() { return fldValue; }

    public int8 asInt8() { return fldValue; }

    public long asLong() { return fldValue; }

    public long2 asLong2() { return fldValue; }

    public long4 asLong4() { return fldValue; }

    public long8 asLong8() { return fldValue; }

    public float asFloat() { return fldValue; }

    public float2 asFloat2() { return fldValue; }

    public float4 asFloat4() { return fldValue; }

    public float8 asFloat8() { return fldValue; }

    public double asDouble() { return fldValue; }

    public double2 asDouble2() { return fldValue; }

    public double4 asDouble4() { return fldValue; }

    public double8 asDouble8() { return fldValue; }

    public real asReal() { return fldValue; }

    public int compareTo(Comparable anot) { return anot == this ? EQUALS : !(anot instanceof Char) ? INDEFINITE : Int.compare(fldValue, ((Char) anot).fldValue); }

    public Char clone() { return new Char(fldValue); }

    public int compareToIgnoreCase(Char anot) { return anot == this ? EQUALS : anot == null ? INDEFINITE : compareIgnoreCase(fldValue, anot.fldValue); }

    public int compareToLexicographically(Char anot) { return anot == this ? EQUALS : anot == null ? INDEFINITE : compareLexicographically(fldValue, anot.fldValue); }

    public int kind { read = Class.CHAR }

    public char charValue { read = fldValue }
}