Spaces:
Configuration error
Configuration error
/** | |
* @author jdiaz5513 | |
*/ | |
/** | |
* Compute the Hamming weight (number of bits set to 1) of a number. Used to figure out how many bytes follow a tag byte | |
* while computing the size of a packed message. | |
* | |
* WARNING: Using this with floating point numbers will void your warranty. | |
* | |
* @param {number} x A real integer. | |
* @returns {number} The hamming weight (integer). | |
*/ | |
export declare function getHammingWeight(x: number): number; | |
export declare type byte = number; | |
/** | |
* Compute the tag byte from the 8 bytes of a 64-bit word. | |
* | |
* @param {byte} a The first byte. | |
* @param {byte} b The second byte. | |
* @param {byte} c The third byte. | |
* @param {byte} d The fourth byte. | |
* @param {byte} e The fifth byte. | |
* @param {byte} f The sixth byte. | |
* @param {byte} g The seventh byte. | |
* @param {byte} h The eighth byte (phew!). | |
* @returns {number} The tag byte. | |
*/ | |
export declare function getTagByte(a: byte, b: byte, c: byte, d: byte, e: byte, f: byte, g: byte, h: byte): number; | |
/** | |
* Efficiently calculate the length of a packed Cap'n Proto message. | |
* | |
* @export | |
* @param {ArrayBuffer} packed The packed message. | |
* @returns {number} The length of the unpacked message in bytes. | |
*/ | |
export declare function getUnpackedByteLength(packed: ArrayBuffer): number; | |
/** | |
* Compute the number of zero bytes that occur in a given 64-bit word, provided as eight separate bytes. | |
* | |
* @param {byte} a The first byte. | |
* @param {byte} b The second byte. | |
* @param {byte} c The third byte. | |
* @param {byte} d The fourth byte. | |
* @param {byte} e The fifth byte. | |
* @param {byte} f The sixth byte. | |
* @param {byte} g The seventh byte. | |
* @param {byte} h The eighth byte (phew!). | |
* @returns {number} The number of these bytes that are zero. | |
*/ | |
export declare function getZeroByteCount(a: byte, b: byte, c: byte, d: byte, e: byte, f: byte, g: byte, h: byte): number; | |
/** | |
* Pack a section of a Cap'n Proto message into a compressed format. This will efficiently compress zero bytes (which | |
* are common in idiomatic Cap'n Proto messages) into a compact form. | |
* | |
* For stream-framed messages this is called once for the frame header and once again for each segment in the message. | |
* | |
* The returned array buffer is trimmed to the exact size of the packed message with a single copy operation at the end. | |
* This should be decent on CPU time but does require quite a lot of memory (a normal array is filled up with each | |
* packed byte until the packing is complete). | |
* | |
* @export | |
* @param {ArrayBuffer} unpacked The message to pack. | |
* @param {number} [byteOffset] Starting byte offset to read bytes from, defaults to 0. | |
* @param {number} [byteLength] Total number of bytes to read, defaults to the remainder of the buffer contents. | |
* @returns {ArrayBuffer} A packed version of the message. | |
*/ | |
export declare function pack(unpacked: ArrayBuffer, byteOffset?: number, byteLength?: number): ArrayBuffer; | |
/** | |
* Unpack a compressed Cap'n Proto message into a new ArrayBuffer. | |
* | |
* Unlike the `pack` function, this is able to efficiently determine the exact size needed for the output buffer and | |
* runs considerably more efficiently. | |
* | |
* @export | |
* @param {ArrayBuffer} packed An array buffer containing the packed message. | |
* @returns {ArrayBuffer} The unpacked message. | |
*/ | |
export declare function unpack(packed: ArrayBuffer): ArrayBuffer; | |