| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 | 
							- 'use strict';
 
- const { EMPTY_BUFFER } = require('./constants');
 
- /**
 
-  * Merges an array of buffers into a new buffer.
 
-  *
 
-  * @param {Buffer[]} list The array of buffers to concat
 
-  * @param {Number} totalLength The total length of buffers in the list
 
-  * @return {Buffer} The resulting buffer
 
-  * @public
 
-  */
 
- function concat(list, totalLength) {
 
-   if (list.length === 0) return EMPTY_BUFFER;
 
-   if (list.length === 1) return list[0];
 
-   const target = Buffer.allocUnsafe(totalLength);
 
-   var offset = 0;
 
-   for (var i = 0; i < list.length; i++) {
 
-     const buf = list[i];
 
-     buf.copy(target, offset);
 
-     offset += buf.length;
 
-   }
 
-   return target;
 
- }
 
- /**
 
-  * Masks a buffer using the given mask.
 
-  *
 
-  * @param {Buffer} source The buffer to mask
 
-  * @param {Buffer} mask The mask to use
 
-  * @param {Buffer} output The buffer where to store the result
 
-  * @param {Number} offset The offset at which to start writing
 
-  * @param {Number} length The number of bytes to mask.
 
-  * @public
 
-  */
 
- function _mask(source, mask, output, offset, length) {
 
-   for (var i = 0; i < length; i++) {
 
-     output[offset + i] = source[i] ^ mask[i & 3];
 
-   }
 
- }
 
- /**
 
-  * Unmasks a buffer using the given mask.
 
-  *
 
-  * @param {Buffer} buffer The buffer to unmask
 
-  * @param {Buffer} mask The mask to use
 
-  * @public
 
-  */
 
- function _unmask(buffer, mask) {
 
-   // Required until https://github.com/nodejs/node/issues/9006 is resolved.
 
-   const length = buffer.length;
 
-   for (var i = 0; i < length; i++) {
 
-     buffer[i] ^= mask[i & 3];
 
-   }
 
- }
 
- /**
 
-  * Converts a buffer to an `ArrayBuffer`.
 
-  *
 
-  * @param {Buffer} buf The buffer to convert
 
-  * @return {ArrayBuffer} Converted buffer
 
-  * @public
 
-  */
 
- function toArrayBuffer(buf) {
 
-   if (buf.byteLength === buf.buffer.byteLength) {
 
-     return buf.buffer;
 
-   }
 
-   return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength);
 
- }
 
- /**
 
-  * Converts `data` to a `Buffer`.
 
-  *
 
-  * @param {*} data The data to convert
 
-  * @return {Buffer} The buffer
 
-  * @throws {TypeError}
 
-  * @public
 
-  */
 
- function toBuffer(data) {
 
-   toBuffer.readOnly = true;
 
-   if (Buffer.isBuffer(data)) return data;
 
-   var buf;
 
-   if (data instanceof ArrayBuffer) {
 
-     buf = Buffer.from(data);
 
-   } else if (ArrayBuffer.isView(data)) {
 
-     buf = viewToBuffer(data);
 
-   } else {
 
-     buf = Buffer.from(data);
 
-     toBuffer.readOnly = false;
 
-   }
 
-   return buf;
 
- }
 
- /**
 
-  * Converts an `ArrayBuffer` view into a buffer.
 
-  *
 
-  * @param {(DataView|TypedArray)} view The view to convert
 
-  * @return {Buffer} Converted view
 
-  * @private
 
-  */
 
- function viewToBuffer(view) {
 
-   const buf = Buffer.from(view.buffer);
 
-   if (view.byteLength !== view.buffer.byteLength) {
 
-     return buf.slice(view.byteOffset, view.byteOffset + view.byteLength);
 
-   }
 
-   return buf;
 
- }
 
- try {
 
-   const bufferUtil = require('bufferutil');
 
-   const bu = bufferUtil.BufferUtil || bufferUtil;
 
-   module.exports = {
 
-     concat,
 
-     mask(source, mask, output, offset, length) {
 
-       if (length < 48) _mask(source, mask, output, offset, length);
 
-       else bu.mask(source, mask, output, offset, length);
 
-     },
 
-     toArrayBuffer,
 
-     toBuffer,
 
-     unmask(buffer, mask) {
 
-       if (buffer.length < 32) _unmask(buffer, mask);
 
-       else bu.unmask(buffer, mask);
 
-     }
 
-   };
 
- } catch (e) /* istanbul ignore next */ {
 
-   module.exports = {
 
-     concat,
 
-     mask: _mask,
 
-     toArrayBuffer,
 
-     toBuffer,
 
-     unmask: _unmask
 
-   };
 
- }
 
 
  |