fallback.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. 'use strict';
  2. /*!
  3. * bufferutil: WebSocket buffer utils
  4. * Copyright(c) 2015 Einar Otto Stangvik <einaros@gmail.com>
  5. * MIT Licensed
  6. */
  7. module.exports.BufferUtil = {
  8. merge: function(mergedBuffer, buffers) {
  9. for (var i = 0, offset = 0, l = buffers.length; i < l; ++i) {
  10. var buf = buffers[i];
  11. buf.copy(mergedBuffer, offset);
  12. offset += buf.length;
  13. }
  14. },
  15. mask: function(source, mask, output, offset, length) {
  16. var maskNum = mask.readUInt32LE(0, true)
  17. , i = 0
  18. , num;
  19. for (; i < length - 3; i += 4) {
  20. num = maskNum ^ source.readUInt32LE(i, true);
  21. if (num < 0) num = 4294967296 + num;
  22. output.writeUInt32LE(num, offset + i, true);
  23. }
  24. switch (length % 4) {
  25. case 3: output[offset + i + 2] = source[i + 2] ^ mask[2];
  26. case 2: output[offset + i + 1] = source[i + 1] ^ mask[1];
  27. case 1: output[offset + i] = source[i] ^ mask[0];
  28. }
  29. },
  30. unmask: function(data, mask) {
  31. var maskNum = mask.readUInt32LE(0, true)
  32. , length = data.length
  33. , i = 0
  34. , num;
  35. for (; i < length - 3; i += 4) {
  36. num = maskNum ^ data.readUInt32LE(i, true);
  37. if (num < 0) num = 4294967296 + num;
  38. data.writeUInt32LE(num, i, true);
  39. }
  40. switch (length % 4) {
  41. case 3: data[i + 2] = data[i + 2] ^ mask[2];
  42. case 2: data[i + 1] = data[i + 1] ^ mask[1];
  43. case 1: data[i] = data[i] ^ mask[0];
  44. }
  45. }
  46. };