239 lines
20 KiB
JavaScript
239 lines
20 KiB
JavaScript
|
/*istanbul ignore start*/
|
||
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.applyPatch = applyPatch;
|
||
|
exports.applyPatches = applyPatches;
|
||
|
|
||
|
/*istanbul ignore end*/
|
||
|
var
|
||
|
/*istanbul ignore start*/
|
||
|
_parse = require("./parse")
|
||
|
/*istanbul ignore end*/
|
||
|
;
|
||
|
|
||
|
var
|
||
|
/*istanbul ignore start*/
|
||
|
_distanceIterator = _interopRequireDefault(require("../util/distance-iterator"))
|
||
|
/*istanbul ignore end*/
|
||
|
;
|
||
|
|
||
|
/*istanbul ignore start*/ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
||
|
|
||
|
/*istanbul ignore end*/
|
||
|
function applyPatch(source, uniDiff) {
|
||
|
/*istanbul ignore start*/
|
||
|
var
|
||
|
/*istanbul ignore end*/
|
||
|
options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
||
|
|
||
|
if (typeof uniDiff === 'string') {
|
||
|
uniDiff =
|
||
|
/*istanbul ignore start*/
|
||
|
(0,
|
||
|
/*istanbul ignore end*/
|
||
|
|
||
|
/*istanbul ignore start*/
|
||
|
_parse
|
||
|
/*istanbul ignore end*/
|
||
|
.
|
||
|
/*istanbul ignore start*/
|
||
|
parsePatch)
|
||
|
/*istanbul ignore end*/
|
||
|
(uniDiff);
|
||
|
}
|
||
|
|
||
|
if (Array.isArray(uniDiff)) {
|
||
|
if (uniDiff.length > 1) {
|
||
|
throw new Error('applyPatch only works with a single input.');
|
||
|
}
|
||
|
|
||
|
uniDiff = uniDiff[0];
|
||
|
} // Apply the diff to the input
|
||
|
|
||
|
|
||
|
var lines = source.split(/\r\n|[\n\v\f\r\x85]/),
|
||
|
delimiters = source.match(/\r\n|[\n\v\f\r\x85]/g) || [],
|
||
|
hunks = uniDiff.hunks,
|
||
|
compareLine = options.compareLine || function (lineNumber, line, operation, patchContent)
|
||
|
/*istanbul ignore start*/
|
||
|
{
|
||
|
return (
|
||
|
/*istanbul ignore end*/
|
||
|
line === patchContent
|
||
|
);
|
||
|
},
|
||
|
errorCount = 0,
|
||
|
fuzzFactor = options.fuzzFactor || 0,
|
||
|
minLine = 0,
|
||
|
offset = 0,
|
||
|
removeEOFNL,
|
||
|
addEOFNL;
|
||
|
/**
|
||
|
* Checks if the hunk exactly fits on the provided location
|
||
|
*/
|
||
|
|
||
|
|
||
|
function hunkFits(hunk, toPos) {
|
||
|
for (var j = 0; j < hunk.lines.length; j++) {
|
||
|
var line = hunk.lines[j],
|
||
|
operation = line.length > 0 ? line[0] : ' ',
|
||
|
content = line.length > 0 ? line.substr(1) : line;
|
||
|
|
||
|
if (operation === ' ' || operation === '-') {
|
||
|
// Context sanity check
|
||
|
if (!compareLine(toPos + 1, lines[toPos], operation, content)) {
|
||
|
errorCount++;
|
||
|
|
||
|
if (errorCount > fuzzFactor) {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
toPos++;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
} // Search best fit offsets for each hunk based on the previous ones
|
||
|
|
||
|
|
||
|
for (var i = 0; i < hunks.length; i++) {
|
||
|
var hunk = hunks[i],
|
||
|
maxLine = lines.length - hunk.oldLines,
|
||
|
localOffset = 0,
|
||
|
toPos = offset + hunk.oldStart - 1;
|
||
|
var iterator =
|
||
|
/*istanbul ignore start*/
|
||
|
(0,
|
||
|
/*istanbul ignore end*/
|
||
|
|
||
|
/*istanbul ignore start*/
|
||
|
_distanceIterator
|
||
|
/*istanbul ignore end*/
|
||
|
[
|
||
|
/*istanbul ignore start*/
|
||
|
"default"
|
||
|
/*istanbul ignore end*/
|
||
|
])(toPos, minLine, maxLine);
|
||
|
|
||
|
for (; localOffset !== undefined; localOffset = iterator()) {
|
||
|
if (hunkFits(hunk, toPos + localOffset)) {
|
||
|
hunk.offset = offset += localOffset;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (localOffset === undefined) {
|
||
|
return false;
|
||
|
} // Set lower text limit to end of the current hunk, so next ones don't try
|
||
|
// to fit over already patched text
|
||
|
|
||
|
|
||
|
minLine = hunk.offset + hunk.oldStart + hunk.oldLines;
|
||
|
} // Apply patch hunks
|
||
|
|
||
|
|
||
|
var diffOffset = 0;
|
||
|
|
||
|
for (var _i = 0; _i < hunks.length; _i++) {
|
||
|
var _hunk = hunks[_i],
|
||
|
_toPos = _hunk.oldStart + _hunk.offset + diffOffset - 1;
|
||
|
|
||
|
diffOffset += _hunk.newLines - _hunk.oldLines;
|
||
|
|
||
|
for (var j = 0; j < _hunk.lines.length; j++) {
|
||
|
var line = _hunk.lines[j],
|
||
|
operation = line.length > 0 ? line[0] : ' ',
|
||
|
content = line.length > 0 ? line.substr(1) : line,
|
||
|
delimiter = _hunk.linedelimiters[j];
|
||
|
|
||
|
if (operation === ' ') {
|
||
|
_toPos++;
|
||
|
} else if (operation === '-') {
|
||
|
lines.splice(_toPos, 1);
|
||
|
delimiters.splice(_toPos, 1);
|
||
|
/* istanbul ignore else */
|
||
|
} else if (operation === '+') {
|
||
|
lines.splice(_toPos, 0, content);
|
||
|
delimiters.splice(_toPos, 0, delimiter);
|
||
|
_toPos++;
|
||
|
} else if (operation === '\\') {
|
||
|
var previousOperation = _hunk.lines[j - 1] ? _hunk.lines[j - 1][0] : null;
|
||
|
|
||
|
if (previousOperation === '+') {
|
||
|
removeEOFNL = true;
|
||
|
} else if (previousOperation === '-') {
|
||
|
addEOFNL = true;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
} // Handle EOFNL insertion/removal
|
||
|
|
||
|
|
||
|
if (removeEOFNL) {
|
||
|
while (!lines[lines.length - 1]) {
|
||
|
lines.pop();
|
||
|
delimiters.pop();
|
||
|
}
|
||
|
} else if (addEOFNL) {
|
||
|
lines.push('');
|
||
|
delimiters.push('\n');
|
||
|
}
|
||
|
|
||
|
for (var _k = 0; _k < lines.length - 1; _k++) {
|
||
|
lines[_k] = lines[_k] + delimiters[_k];
|
||
|
}
|
||
|
|
||
|
return lines.join('');
|
||
|
} // Wrapper that supports multiple file patches via callbacks.
|
||
|
|
||
|
|
||
|
function applyPatches(uniDiff, options) {
|
||
|
if (typeof uniDiff === 'string') {
|
||
|
uniDiff =
|
||
|
/*istanbul ignore start*/
|
||
|
(0,
|
||
|
/*istanbul ignore end*/
|
||
|
|
||
|
/*istanbul ignore start*/
|
||
|
_parse
|
||
|
/*istanbul ignore end*/
|
||
|
.
|
||
|
/*istanbul ignore start*/
|
||
|
parsePatch)
|
||
|
/*istanbul ignore end*/
|
||
|
(uniDiff);
|
||
|
}
|
||
|
|
||
|
var currentIndex = 0;
|
||
|
|
||
|
function processIndex() {
|
||
|
var index = uniDiff[currentIndex++];
|
||
|
|
||
|
if (!index) {
|
||
|
return options.complete();
|
||
|
}
|
||
|
|
||
|
options.loadFile(index, function (err, data) {
|
||
|
if (err) {
|
||
|
return options.complete(err);
|
||
|
}
|
||
|
|
||
|
var updatedContent = applyPatch(data, index, options);
|
||
|
options.patched(index, updatedContent, function (err) {
|
||
|
if (err) {
|
||
|
return options.complete(err);
|
||
|
}
|
||
|
|
||
|
processIndex();
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
|
||
|
processIndex();
|
||
|
}
|
||
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wYXRjaC9hcHBseS5qcyJdLCJuYW1lcyI6WyJhcHBseVBhdGNoIiwic291cmNlIiwidW5pRGlmZiIsIm9wdGlvbnMiLCJwYXJzZVBhdGNoIiwiQXJyYXkiLCJpc0FycmF5IiwibGVuZ3RoIiwiRXJyb3IiLCJsaW5lcyIsInNwbGl0IiwiZGVsaW1pdGVycyIsIm1hdGNoIiwiaHVua3MiLCJjb21wYXJlTGluZSIsImxpbmVOdW1iZXIiLCJsaW5lIiwib3BlcmF0aW9uIiwicGF0Y2hDb250ZW50IiwiZXJyb3JDb3VudCIsImZ1enpGYWN0b3IiLCJtaW5MaW5lIiwib2Zmc2V0IiwicmVtb3ZlRU9GTkwiLCJhZGRFT0ZOTCIsImh1bmtGaXRzIiwiaHVuayIsInRvUG9zIiwiaiIsImNvbnRlbnQiLCJzdWJzdHIiLCJpIiwibWF4TGluZSIsIm9sZExpbmVzIiwibG9jYWxPZmZzZXQiLCJvbGRTdGFydCIsIml0ZXJhdG9yIiwiZGlzdGFuY2VJdGVyYXRvciIsInVuZGVmaW5lZCIsImRpZmZPZmZzZXQiLCJuZXdMaW5lcyIsImRlbGltaXRlciIsImxpbmVkZWxpbWl0ZXJzIiwic3BsaWNlIiwicHJldmlvdXNPcGVyYXRpb24iLCJwb3AiLCJwdXNoIiwiX2siLCJqb2luIiwiYXBwbHlQYXRjaGVzIiwiY3VycmVudEluZGV4IiwicHJvY2Vzc0luZGV4IiwiaW5kZXgiLCJjb21wbGV0ZSIsImxvYWRGaWxlIiwiZXJyIiwiZGF0YSIsInVwZGF0ZWRDb250ZW50IiwicGF0Y2hlZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFBQTs7Ozs7QUFFTyxTQUFTQSxVQUFULENBQW9CQyxNQUFwQixFQUE0QkMsT0FBNUIsRUFBbUQ7QUFBQTtBQUFBO0FBQUE7QUFBZEMsRUFBQUEsT0FBYyx1RUFBSixFQUFJOztBQUN4RCxNQUFJLE9BQU9ELE9BQVAsS0FBbUIsUUFBdkIsRUFBaUM7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
|