apply-delta.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. var bodec = require('bodec');
  2. module.exports = applyDelta;
  3. function applyDelta(delta, base) {
  4. var deltaOffset = 0;
  5. if (base.length !== readLength()) {
  6. throw new Error("Base length mismatch");
  7. }
  8. // Create a new output buffer with length from header.
  9. var outOffset = 0;
  10. var out = bodec.create(readLength());
  11. while (deltaOffset < delta.length) {
  12. var byte = delta[deltaOffset++];
  13. // Copy command. Tells us offset in base and length to copy.
  14. if (byte & 0x80) {
  15. var offset = 0;
  16. var length = 0;
  17. if (byte & 0x01) offset |= delta[deltaOffset++] << 0;
  18. if (byte & 0x02) offset |= delta[deltaOffset++] << 8;
  19. if (byte & 0x04) offset |= delta[deltaOffset++] << 16;
  20. if (byte & 0x08) offset |= delta[deltaOffset++] << 24;
  21. if (byte & 0x10) length |= delta[deltaOffset++] << 0;
  22. if (byte & 0x20) length |= delta[deltaOffset++] << 8;
  23. if (byte & 0x40) length |= delta[deltaOffset++] << 16;
  24. if (length === 0) length = 0x10000;
  25. // copy the data
  26. bodec.copy(bodec.slice(base, offset, offset + length), out, outOffset);
  27. outOffset += length;
  28. }
  29. // Insert command, opcode byte is length itself
  30. else if (byte) {
  31. bodec.copy(bodec.slice(delta, deltaOffset, deltaOffset + byte), out, outOffset);
  32. deltaOffset += byte;
  33. outOffset += byte;
  34. }
  35. else throw new Error('Invalid delta opcode');
  36. }
  37. if (outOffset !== out.length) {
  38. throw new Error("Size mismatch in check");
  39. }
  40. return out;
  41. // Read a variable length number our of delta and move the offset.
  42. function readLength() {
  43. var byte = delta[deltaOffset++];
  44. var length = byte & 0x7f;
  45. var shift = 7;
  46. while (byte & 0x80) {
  47. byte = delta[deltaOffset++];
  48. length |= (byte & 0x7f) << shift;
  49. shift += 7;
  50. }
  51. return length;
  52. }
  53. }