Ejemplo n.º 1
0
    public static void EncodeDecimal64(
        Span <byte> destination, decimal value, int precision, int scale)
    {
        long encodedValue = DecimalUtil.EncodeDecimal64(value, precision, scale);

        EncodeInt64(destination, encodedValue);
    }
Ejemplo n.º 2
0
    public static void EncodeDecimal128(
        Span <byte> destination, decimal value, int precision, int scale)
    {
        var encodedValue = DecimalUtil.EncodeDecimal128(value, precision, scale);

        EncodeInt128(destination, encodedValue);
    }
Ejemplo n.º 3
0
    [InlineData(-667386670618854952, 7376056636151202432, 35)] //-123.1111111111111111111111111111
    public void KuduDecimalTooLarge(long high, ulong low, int scale)
    {
        var value = new KuduInt128(high, low);

        Assert.Throws <OverflowException>(
            () => DecimalUtil.DecodeDecimal128(value, scale));
    }
Ejemplo n.º 4
0
    /// <summary>
    /// Utility method to return a random decimal value.
    /// </summary>
    public static decimal RandomDecimal(ColumnTypeAttributes attributes, Random random)
    {
        int numBits        = NumBits(attributes.Precision.GetValueOrDefault());
        var randomUnscaled = NextBigInteger(numBits, random);

        return(DecimalUtil.SetScale((decimal)randomUnscaled, attributes.Scale.GetValueOrDefault()));
    }
Ejemplo n.º 5
0
    public static void EncodeDecimal(
        Span <byte> destination, KuduType kuduType, decimal value, int precision, int scale)
    {
        switch (kuduType)
        {
        case KuduType.Decimal32:
            int intVal = DecimalUtil.EncodeDecimal32(value, precision, scale);
            EncodeInt32(destination, intVal);
            break;

        case KuduType.Decimal64:
            long longVal = DecimalUtil.EncodeDecimal64(value, precision, scale);
            EncodeInt64(destination, longVal);
            break;

        default:
            var int128Val = DecimalUtil.EncodeDecimal128(value, precision, scale);
            EncodeInt128(destination, int128Val);
            break;
        }
    }
Ejemplo n.º 6
0
    /// <summary>
    /// Increments the column at the given index, returning false if the
    /// value is already the maximum.
    /// </summary>
    /// <param name="index">The column index to increment.</param>
    internal bool IncrementColumn(int index)
    {
        if (!IsSet(index))
        {
            throw new ArgumentException($"Column index {index} has not been set.");
        }

        ColumnSchema column = Schema.GetColumn(index);

        if (column.IsFixedSize)
        {
            KuduType    type = column.Type;
            Span <byte> data = GetRowAllocColumn(index, column.Size);

            switch (type)
            {
            case KuduType.Bool:
            {
                bool isFalse = data[0] == 0;
                data[0] = 1;
                return(isFalse);
            }

            case KuduType.Int8:
            {
                sbyte existing = KuduEncoder.DecodeInt8(data);
                if (existing == sbyte.MaxValue)
                {
                    return(false);
                }

                KuduEncoder.EncodeInt8(data, (sbyte)(existing + 1));
                return(true);
            }

            case KuduType.Int16:
            {
                short existing = KuduEncoder.DecodeInt16(data);
                if (existing == short.MaxValue)
                {
                    return(false);
                }

                KuduEncoder.EncodeInt16(data, (short)(existing + 1));
                return(true);
            }

            case KuduType.Int32:
            {
                int existing = KuduEncoder.DecodeInt32(data);
                if (existing == int.MaxValue)
                {
                    return(false);
                }

                KuduEncoder.EncodeInt32(data, existing + 1);
                return(true);
            }

            case KuduType.Date:
            {
                int existing = KuduEncoder.DecodeInt32(data);
                if (existing == EpochTime.MaxDateValue)
                {
                    return(false);
                }

                KuduEncoder.EncodeInt32(data, existing + 1);
                return(true);
            }

            case KuduType.Int64:
            case KuduType.UnixtimeMicros:
            {
                long existing = KuduEncoder.DecodeInt64(data);
                if (existing == long.MaxValue)
                {
                    return(false);
                }

                KuduEncoder.EncodeInt64(data, existing + 1);
                return(true);
            }

            case KuduType.Float:
            {
                float existing    = KuduEncoder.DecodeFloat(data);
                float incremented = existing.NextUp();
                if (existing == incremented)
                {
                    return(false);
                }

                KuduEncoder.EncodeFloat(data, incremented);
                return(true);
            }

            case KuduType.Double:
            {
                double existing    = KuduEncoder.DecodeDouble(data);
                double incremented = existing.NextUp();
                if (existing == incremented)
                {
                    return(false);
                }

                KuduEncoder.EncodeDouble(data, incremented);
                return(true);
            }

            case KuduType.Decimal32:
            {
                int existing  = KuduEncoder.DecodeInt32(data);
                int precision = column.TypeAttributes !.Precision.GetValueOrDefault();
                if (existing == DecimalUtil.MaxDecimal32(precision))
                {
                    return(false);
                }

                KuduEncoder.EncodeInt32(data, existing + 1);
                return(true);
            }

            case KuduType.Decimal64:
            {
                long existing  = KuduEncoder.DecodeInt64(data);
                int  precision = column.TypeAttributes !.Precision.GetValueOrDefault();
                if (existing == DecimalUtil.MaxDecimal64(precision))
                {
                    return(false);
                }

                KuduEncoder.EncodeInt64(data, existing + 1);
                return(true);
            }

            case KuduType.Decimal128:
            {
                KuduInt128 existing  = KuduEncoder.DecodeInt128(data);
                int        precision = column.TypeAttributes !.Precision.GetValueOrDefault();
                if (existing == DecimalUtil.MaxDecimal128(precision))
                {
                    return(false);
                }

                KuduEncoder.EncodeInt128(data, existing + 1);
                return(true);
            }

            default:
                throw new Exception($"Unsupported data type {type}");
            }
        }
        else
        {
            // Column is either string, binary, or varchar.
            ReadOnlySpan <byte> data = GetVarLengthColumn(index);
            var incremented          = new byte[data.Length + 1];
            data.CopyTo(incremented);
            WriteBinary(index, incremented);
            return(true);
        }
    }
Ejemplo n.º 7
0
    public static byte[] EncodeDecimal128(decimal value, int precision, int scale)
    {
        var intVal = DecimalUtil.EncodeDecimal128(value, precision, scale);

        return(EncodeInt128(intVal));
    }
Ejemplo n.º 8
0
    public static byte[] EncodeDecimal64(decimal value, int precision, int scale)
    {
        long longVal = DecimalUtil.EncodeDecimal64(value, precision, scale);

        return(EncodeInt64(longVal));
    }
Ejemplo n.º 9
0
    public static byte[] EncodeDecimal32(decimal value, int precision, int scale)
    {
        int intVal = DecimalUtil.EncodeDecimal32(value, precision, scale);

        return(EncodeInt32(intVal));
    }