npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

buffer-collection

v3.0.1

Published

Treat multiple Buffers as a single contiguous Buffer.

Downloads

18

Readme

buffer-collection

Build Status Coverage Status license

Treat multiple Buffers as a single contiguous Buffer.

This library can be used to manipulate data from multiple buffers without merging the buffers. In this way, the expensive concat operation could be avoided. Internally it interates over the items from the array of Buffer objects.

The standard Buffer functions like indexOf, slice, etc. are rewritten to work with chunked data.

The API is compatible with the Node.js Buffer API, so it seamlessly integrates with your existing codebase.

Contains type definitions for TypeScript.

Install

npm i buffer-collection

Example

const BufferCollection = require('buffer-collection');
const buf = new BufferCollection();
buf.push(Buffer.from([1, 2, 3]));
buf.push([4]); // automatic conversion to Buffer
buf.push([5, 6, 7]);

// <BufferCollection 02 03 04 05>
console.log(buf.slice(1, 5));

const needle = Buffer.from([2, 3]);
// 1
console.log(buf.indexOf(needle));

// <BufferCollection 01 02 03 01 02 03 01>
console.log(buf.fill(Buffer.from([1, 2, 3])));

// 4
console.log(buf.lastIndexOf(needle));

buf.writeInt32BE(0xdeadbeef, 1)
// <BufferCollection 01 de ad be ef 03 01>
console.log(buf);

const bytes = [];
for (const b of buf) {
    bytes.push(b.toString(16));
}
// [ '1', 'de', 'ad', 'be', 'ef', '3', '1' ]
console.log(bytes);

Methods

The API is a superset of the Node.js Buffer API, so it seamlessly integrates with your existing codebase. The only Buffer feature what is missing from BufferCollection is the [] operator. But you can use .get() in place of that.

buf.push(element)

Adds a new Buffer to the end of the current collection.

buf.compact()

Merges internal array of buffers to a single buffer. It should be called when data becomes very fragmented.

buf.count

Returns the number of Buffer instances in collection.

buf.get(offset)

Gets the byte value from the specified offset. Can be used as replacement for buf[offset]. Same as buf.readUInt8(offset)

buf.set(offset, value)

Sets the byte value at the specified offset. Can be used as replacement for buf[offset]. Same as buf.writeUInt8(value, offset)

buf.shiftBuffer()

Removes the first Buffer from collection and returns it. This method changes the length of the data of BufferCollection.

buf.slice([start[, end]])

Returns a new BufferCollection that references the same memory as the original, but offset and cropped by the start and end indices. Works similarly as the slice method of Buffers.

+ Methods from Node.js Buffer API

These methods were adapted to work on multiple Buffer instances without merging them into one contiguous memory section.

Buffer.alloc(size[, fill[, encoding]])

Allocates a new Buffer of size bytes. If fill is undefined, the Buffer will be zero-filled.

See Node.js documentation regarding the usage.

Buffer.allocUnsafe(size)

Allocates a new Buffer of size bytes. The underlying memory for Buffer instances created in this way is not initialized. The contents of the newly created Buffer are unknown and may contain sensitive data.

See Node.js documentation regarding the usage.

Buffer.allocUnsafe(size)

Allocates a new Buffer of size bytes. The underlying memory for Buffer instances created in this way is not initialized. The contents of the newly created Buffer are unknown and may contain sensitive data.

See Node.js documentation regarding the usage.

Buffer.allocUnsafeSlow(size)

Allocates a new Buffer of size bytes. The underlying memory for Buffer instances created in this way is not initialized. Not using allocation pools.

See Node.js documentation regarding the usage.

buf.compare(target[, targetStart[, targetEnd[, sourceStart[, sourceEnd]]]])

Compares buf with target and returns a number indicating whether buf comes before, after, or is the same as target in sort order.

See Node.js documentation regarding the usage.

buf.copy(target[, targetStart[, sourceStart[, sourceEnd]]])

Copies data from a region of buf to a region in target even if the target memory region overlaps with buf.

See Node.js documentation regarding the usage.

Buffer.concat(list[, totalLength])

Returns a new BufferCollection, which contains all the Buffer and BufferCollection instances from the list. If the combined length of the Buffers in list exceeds totalLength, the result is truncated to totalLength.

See Node.js documentation regarding the usage.

buf.entries()

Creates and returns an iterator of [index, byte] pairs from the contents of buf.

See Node.js documentation regarding the usage.

buf.equals(otherBuffer)

Returns true if both buf and otherBuffer have exactly the same bytes, false otherwise.

See Node.js documentation regarding the usage.

buf.fill(value[, offset[, end]][, encoding])

Fills buf with the specified value.

See Node.js documentation regarding the usage.

buf.includes(value[, byteOffset][, encoding])

Equivalent to buf.indexOf() !== -1.

See Node.js documentation regarding the usage.

buf.indexOf(value[, byteOffset][, encoding])

Returns the first index at which a given element can be found in the Buffers, or -1 if it is not present.

See Node.js documentation regarding the usage.

buf.keys()

Creates and returns an iterator of buf keys (indices).

See Node.js documentation regarding the usage.

buf.lastIndexOf(value[, byteOffset][, encoding])

Identical to buf.indexOf(), except buf is searched from back to front instead of front to back.

See Node.js documentation regarding the usage.

buf.length

Returns the amount of memory allocated for buf in bytes. Note that this does not necessarily reflect the amount of "usable" data within buf.

See Node.js documentation regarding the usage.

buf.readDoubleBE(offset[, noAssert])

buf.readDoubleLE(offset[, noAssert]

Reads a 64-bit double from buf at the specified offset with the corresponding endianness.

See Node.js documentation regarding the usage.

buf.readFloatBE(offset[, noAssert])

buf.readFloatLE(offset[, noAssert])

Reads a 32-bit float from buf at the specified offset with the corresponding endianness.

See Node.js documentation regarding the usage.

buf.readInt8(offset[, noAssert])

buf.readInt16BE(offset[, noAssert])

buf.readInt16LE(offset[, noAssert])

buf.readInt24BE(offset[, noAssert])

buf.readInt24LE(offset[, noAssert])

buf.readInt32BE(offset[, noAssert])

buf.readInt32LE(offset[, noAssert])

buf.readInt40BE(offset[, noAssert])

buf.readInt40LE(offset[, noAssert])

buf.readInt48BE(offset[, noAssert])

buf.readInt48LE(offset[, noAssert])

Reads a signed integer from buf at the specified offset.

See Node.js documentation regarding the usage.

buf.readIntBE(offset, byteLength[, noAssert])

Reads byteLength number of bytes from buf at the specified offset and interprets the result as a two's complement signed value with the big endian format. Supports up to 48 bits of accuracy.

See Node.js documentation regarding the usage.

buf.readIntLE(offset, byteLength[, noAssert])

Reads byteLength number of bytes from buf at the specified offset and interprets the result as a two's complement signed value with the little endian format. Supports up to 48 bits of accuracy.

See Node.js documentation regarding the usage.

buf.readUInt8(offset[, noAssert])

buf.readUInt16BE(offset[, noAssert])

buf.readUInt16LE(offset[, noAssert])

buf.readUInt24BE(offset[, noAssert])

buf.readUInt24LE(offset[, noAssert])

buf.readUInt32BE(offset[, noAssert])

buf.readUInt32LE(offset[, noAssert])

buf.readUInt40BE(offset[, noAssert])

buf.readUInt40LE(offset[, noAssert])

buf.readUInt48BE(offset[, noAssert])

buf.readUInt48LE(offset[, noAssert])

Reads an unsigned integer from buf at the specified offset.

See Node.js documentation regarding the usage.

buf.readUIntBE(offset, byteLength[, noAssert])

Reads byteLength number of bytes from buf at the specified offset and interprets the result as an unsigned integer with the big endian format. Supports up to 48 bits of accuracy.

See Node.js documentation regarding the usage.

buf.readUIntLE(offset, byteLength[, noAssert])

Reads byteLength number of bytes from buf at the specified offset and interprets the result as an unsigned integer with the little endian format. Supports up to 48 bits of accuracy.

See Node.js documentation regarding the usage.

buf.slice([start[, end]])

Returns a new BufferCollection that references the same memory as the original, but offset and cropped by the start and end indices.

See Node.js documentation regarding the usage.

buf.swap16()

Interprets buf as an array of unsigned 16-bit integers and swaps the byte-order in-place.

See Node.js documentation regarding the usage.

buf.swap32()

Interprets buf as an array of unsigned 32-bit integers and swaps the byte-order in-place.

See Node.js documentation regarding the usage.

buf.swap64()

Interprets buf as an array of unsigned 64-bit integers and swaps the byte-order in-place.

See Node.js documentation regarding the usage.

buf.toJSON()

Returns a JSON representation of buf. JSON.stringify() implicitly calls this function when stringifying a BufferCollection instance.

See Node.js documentation regarding the usage.

buf.toString([encoding[, start[, end]]])

Decodes buf to a string according to the specified character encoding in encoding.

See Node.js documentation regarding the usage.

buf.values()

Creates and returns an iterator for buf values (bytes). This function is called automatically when a Buffer is used in a for..of statement.

See Node.js documentation regarding the usage.

buf.write()

Writes string to buf at offset according to the character encoding in encoding. The length parameter is the number of bytes to write.

See Node.js documentation regarding the usage.

buf.writeDoubleBE(value, offset[, noAssert])

buf.writeDoubleLE(value, offset[, noAssert])

Writes value to buf at the specified offset with the corresponding endianness. value should be a valid 64-bit double.

See Node.js documentation regarding the usage.

buf.writeFloatBE(value, offset[, noAssert])

buf.writeFloatLE(value, offset[, noAssert])

Writes value to buf at the specified offset with the corresponding endianness. value should be a valid 32-bit float.

See Node.js documentation regarding the usage.

buf.writeInt8(value, offset[, noAssert])

buf.writeInt16BE(value, offset[, noAssert])

buf.writeInt16LE(value, offset[, noAssert])

buf.writeInt32BE(value, offset[, noAssert])

buf.writeInt32LE(value, offset[, noAssert])

Writes value to buf at the specified offset. value should be a valid signed integer.

See Node.js documentation regarding the usage.

buf.writeIntBE(value, offset, byteLength[, noAssert])

Writes byteLength bytes of value to buf at the specified offset with big endian format. Supports up to 48 bits of accuracy. Behavior is undefined when value is anything other than a signed integer.

See Node.js documentation regarding the usage.

buf.writeIntLE(value, offset, byteLength[, noAssert])

Writes byteLength bytes of value to buf at the specified offset with little endian format. Supports up to 48 bits of accuracy. Behavior is undefined when value is anything other than a signed integer.

See Node.js documentation regarding the usage.

buf.writeUInt8(value, offset[, noAssert])

buf.writeUInt16BE(value, offset[, noAssert])

buf.writeUInt16LE(value, offset[, noAssert])

buf.writeUInt32BE(value, offset[, noAssert])

buf.writeUInt32LE(value, offset[, noAssert])

Writes value to buf at the specified offset. value should be a valid unsigned integer.

See Node.js documentation regarding the usage.

buf.writeUIntBE(value, offset, byteLength[, noAssert])

Writes byteLength bytes of value to buf at the specified offset with big endian format. Supports up to 48 bits of accuracy. Behavior is undefined when value is anything other than an unsigned integer.

See Node.js documentation regarding the usage.

buf.writeUIntLE(value, offset, byteLength[, noAssert])

Writes byteLength bytes of value to buf at the specified offset with little endian format. Supports up to 48 bits of accuracy. Behavior is undefined when value is anything other than an unsigned integer.

See Node.js documentation regarding the usage.

Unsupported Buffer methods

:x: buf[index] - please use buf.get(index) and buf.set(offset, value)

License

MIT