Byte.avt

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

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

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

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

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

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

package avt.lang;

import avt.lang.array.*;

public final class Byte(Object, Numeric, Comparable, Cloneable)
{
    public static final byte MIN_VALUE = 0xffffff80;
    public static final byte MAX_VALUE = 0x0000007f;

    public static native byte max(byte value0, byte value1);

    public static native byte maxUnsigned(byte value0, byte value1);

    public static native byte min(byte value0, byte value1);

    public static native byte minUnsigned(byte value0, byte value1);

    public static native byte rotateLeft(byte value, int bits);

    public static native byte rotateRight(byte value, int bits);

    public static byte parse(CharArray string) { return parse(string, 10); }

    public static byte parse(CharArray string, int radix) {
        int result = Int.parse(string, radix);
        if(result < MIN_VALUE || result > MAX_VALUE)
        {
            throw new NumberFormatException(package.getResourceString("illegal-argument.number-format"));
        }
        return (byte) result;
    }

    public static byte parseUnsigned(CharArray string) { return parseUnsigned(string, 10); }

    public static byte parseUnsigned(CharArray string, int radix) {
        int result = Int.parseUnsigned(string, radix);
        if(result < 0 || result > 0xff)
        {
            throw new NumberFormatException(package.getResourceString("illegal-argument.number-format"));
        }
        return (byte) result;
    }

    public static native int signum(byte value);

    public static native int compare(byte value0, byte value1);

    public static native int compareUnsigned(byte value0, byte value1);

    public static String toBinaryString(byte value) { return Int.toBinaryString(value & 0xff); }

    public static String toOctalString(byte value) { return Int.toOctalString(value & 0xff); }

    public static String toHexString(byte value) { return Int.toHexString(value & 0xff); }

    public static String toString(byte value) { return Int.toString(value, 10); }

    public static String toString(byte value, int radix) { return Int.toString(value, radix); }

    public static String toUnsignedString(byte value) { return Int.toUnsignedString(value & 0xff, 10); }

    public static String toUnsignedString(byte value, int radix) { return Int.toUnsignedString(value & 0xff, radix); }

    public static String toLeadZeroString(byte value, int width) { return Int.toLeadZeroString(value, width, 10); }

    public static String toLeadZeroString(byte value, int width, int radix) { return Int.toLeadZeroString(value, width, radix); }

    public static Byte valueOf(byte value) { return new Byte(value); }

    public static Byte valueOf(short value) { return new Byte(value); }

    public static Byte valueOf(int value) { return new Byte(value); }

    public static Byte valueOf(long value) { return new Byte(value); }

    public static Byte valueOf(float value) { return new Byte(value); }

    public static Byte valueOf(double value) { return new Byte(value); }

    public static Byte valueOf(real value) { return new Byte(value); }

    public static Byte valueOf(CharArray string) {
        byte value = parse(string, 10);
        return new Byte(value);
    }

    public static Byte valueOf(CharArray string, int radix) {
        byte value = parse(string, radix);
        return new Byte(value);
    }

    private final byte fldValue;

    public (byte value) { fldValue = value; }

    public (short value) { fldValue = (byte) value; }

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

    public (long value) { fldValue = (byte) value; }

    public (float value) { fldValue = (byte) value; }

    public (double value) { fldValue = (byte) value; }

    public (real value) { fldValue = (byte) value; }

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

    public int hashCode() { return fldValue; }

    public long hashCodeAsLong() { return fldValue; }

    public String toString() { return Int.toString(fldValue, 10); }

    public byte asByte() { return fldValue; }

    public byte2 asByte2() { return fldValue; }

    public byte4 asByte4() { return fldValue; }

    public byte8 asByte8() { return fldValue; }

    public short asShort() { return fldValue; }

    public short2 asShort2() { return fldValue; }

    public short4 asShort4() { return fldValue; }

    public short8 asShort8() { return 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 Byte) ? INDEFINITE : compare(fldValue, ((Byte) anot).fldValue); }

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

    public int kind { read = Class.BYTE }

    public byte byteValue { read = fldValue }
}