Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
tiny-inflate
Advanced tools
The tiny-inflate npm package is a minimal JavaScript implementation of the inflate algorithm, which is used for decompressing data compressed with the DEFLATE compression algorithm. It is designed to be small and efficient, suitable for use in environments where resources are limited or where only the inflate functionality is needed without the overhead of a full zlib implementation.
Decompressing a DEFLATE-compressed buffer
This feature allows you to decompress a buffer of data that has been compressed using the DEFLATE algorithm. You need to provide the compressed data as a Uint8Array and an output buffer with the expected size of the decompressed data. After calling tinyInflate with these parameters, the output buffer will contain the decompressed data.
var tinyInflate = require('tiny-inflate');
var compressed = new Uint8Array([...]); // Your compressed data here
var output = new Uint8Array(outputSize); // Output buffer with a size you expect the decompressed data to be
tinyInflate(compressed, output);
// Now 'output' contains the decompressed data
Pako is a high-speed zlib port to JavaScript that works in the browser and node.js. It offers a similar inflate functionality but also includes deflate (compression), which tiny-inflate does not. Pako is more feature-rich and supports gzip wrapping as well.
zlibjs provides zlib compression/decompression wrapped in a JavaScript interface. It is similar to tiny-inflate in that it offers decompression, but it also includes compression and advanced options for tuning performance and compression. It is larger in size compared to tiny-inflate, which is more minimalistic.
fflate is a high-performance, low-complexity deflate/inflate compression algorithm implemented in JavaScript. It is similar to tiny-inflate but claims to be faster and more efficient, and it also supports both compression and decompression, unlike tiny-inflate which only supports decompression.
This is a port of Joergen Ibsen's tiny inflate to JavaScript. Minified it is about 3KB, or 1.3KB gzipped. While being very small, it is also reasonably fast (about 30% - 50% slower than pako on average), and should be good enough for many applications. If you need the absolute best performance, however, you'll need to use a larger library such as pako that contains additional optimizations.
npm install tiny-inflate
To use tiny-inflate, you need two things: a buffer of data compressed with deflate,
and the decompressed size (often stored in a file header) to allocate your output buffer.
Input and output buffers can be either node Buffer
s, or Uint8Array
s.
var inflate = require('tiny-inflate');
var compressedBuffer = new Bufer([ ... ]);
var decompressedSize = ...;
var outputBuffer = new Buffer(decompressedSize);
inflate(compressedBuffer, outputBuffer);
MIT
FAQs
A tiny inflate implementation
The npm package tiny-inflate receives a total of 2,139,710 weekly downloads. As such, tiny-inflate popularity was classified as popular.
We found that tiny-inflate demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.