varintes
TypeScript icon, indicating that this package has built-in type declarations

2.0.5 • Public • Published

Varintes

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

It is fast: 1.5x - 10x times faster than original varint 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]

To Do

  • [x] Faster decode by loop unrolling

License

MIT or APACHE-2.0

Package Sidebar

Install

npm i varintes

Weekly Downloads

2,232

Version

2.0.5

License

(MIT OR Apache-2.0)

Unpacked Size

10.1 kB

Total Files

14

Last publish

Collaborators

  • ukstv