Byte.avt

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

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

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

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

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

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

    Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
    вместе с этой программой. Если это не так, см.
    <http://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;

    /*<fold signum, compare>*/
        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);
    /*</fold>*/

    /*<fold arithmetic>*/
        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);
    /*</fold>*/

    /*<fold rotate, shift>*/
        public static native byte rotateLeft(byte value, int bits);

        public static native byte rotateRight(byte value, int bits);
    /*</fold>*/

    /*<fold parse>*/
        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("недопустимый формат числа");
            }
            return (byte) result;
        }

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

        public static byte parseUnsigned(CharArray string, int radix) {
            int result = Int.parse(string, radix);
            if(result < 0 || result > 0xff)
            {
                throw new NumberFormatException("недопустимый формат числа");
            }
            return (byte) result;
        }
    /*</fold>*/

    /*<fold string representation>*/
        public static String toBinaryString(byte value) { return Int.toBinaryString(value & 0xffi); }

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

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

        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 & 0xffi, 10); }

        public static String toUnsignedString(byte value, int radix) { return Int.toUnsignedString(value & 0xffi, radix); }
    /*</fold>*/

    /*<fold valueOf>*/
        public static Byte valueOf(byte 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);
        }
    /*</fold>*/


    private final byte fldValue;

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

    public boolean equals(Object anot) { return anot == this || anot instanceof Byte && fldValue == ((Byte) anot).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 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 }
}