JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 1916
  • Score
    100M100P100Q114424F
  • License (MIT OR Apache-2.0)

Unsigned Varint encoding and decoding, exposed as ESModule

Package Exports

  • varintes
  • varintes/decode
  • varintes/decode-pack
  • varintes/encode
  • varintes/encode-pack
  • varintes/encoding-length

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