varintes

Unsigned Varint encoding and decoding, exposed as ESModule

Usage no npm install needed!

<script type="module">
  import varintes from 'https://cdn.skypack.dev/varintes';
</script>

README

Varintes

Vision

Encode and decode numbers per unsigned-varint specification, exposed as pure ES Module.

History

We started this package as an ES Module version of varint package. Then we added few helpers used by existing varint package consumers.

Installation

npm install varintes

Usage

To encode a number as varint use encode function:

import * as varintes from "varintes";
const bytes = varintes.encode(4242); // Uint8Array(2) [ 146, 33 ]

To decode varint from bytes, use decode function. It returns decoded number, and amount of bytes read to decode. The bytes read number may be used to continue decoding of a long bytes sequence.

import * as varintes from "varintes";
const [number, bytesRead] = varintes.decode(new Uint8Array([146, 33])); // number = 4242, bytesRead = 2

encodingLength gives you length in bytes of a number when encoded as varint:

import * as varintes from "varintes";
const length = varintes.encodingLength(4242); // 2

Let's call tight packing of varints an encoding where varints' bytes follow each other. There are two functions for tight packing and unpacking provided - encodePach and decodePack:

import * as varintes from "varintes";
const packed = varintes.encodePack([1, 17, 4242]); // Uint8Array(4) [ 1, 17, 146, 33 ]
const unpacked = varintes.decodePack(packed); // [1, 17, 4242]

License

MIT or APACHE-2.0