Sha256: 822da2a31e2fecb87bd1a7c123e33c84a461a3ec826887b04e1deee70e910dc6

Contents?: true

Size: 1.5 KB

Versions: 28

Compression:

Stored size: 1.5 KB

Contents

using System;
using System.Collections.Generic;
using System.Linq;

public static class VariableLengthQuantity
{
    private const uint SevenBitsMask = 0x7fu;
    private const uint EightBitMask = 0x80u;

    public static uint[] Encode(uint[] numbers) => numbers.SelectMany(EncodeSingle).ToArray();

    private static IEnumerable<uint> EncodeSingle(uint number)
    {
        if (number == 0)
        {
            return new[] { 0u };
        }

        var bytes = new List<uint>(4);

        while (number > 0)
        {
            var tmp = number & SevenBitsMask;
            number >>= 7;

            if (bytes.Any())
            {
                tmp |= EightBitMask;
            }

            bytes.Add(tmp);
        }

        bytes.Reverse();
        return bytes;
    }

    public static uint[] Decode(uint[] bytes)
    {
        var numbers = new List<uint>();
        var tmp = 0u;

        for (var index = 0; index < bytes.Length; index++)
        {
            if ((tmp & 0xfe000000u) > 0)
            {
                throw new InvalidOperationException("Overflow exception.");
            }

            var b = bytes[index];
            tmp = (tmp << 7) | (b & 0x7fu);

            if ((b & 0x80) == 0)
            {
                numbers.Add(tmp);
                tmp = 0;
            }
            else if (index == bytes.Length - 1)
            {
                throw new InvalidOperationException("Incomplete byte sequence.");
            }
        }
        
        return numbers.ToArray();
    }
}

Version data entries

28 entries across 28 versions & 1 rubygems

Version Path
trackler-2.2.1.180 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.179 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.178 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.177 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.176 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.175 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.174 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.173 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.172 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.171 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.170 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.169 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.167 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.166 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.165 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.164 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.163 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.162 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.161 tracks/csharp/exercises/variable-length-quantity/Example.cs
trackler-2.2.1.160 tracks/csharp/exercises/variable-length-quantity/Example.cs