dotfiles/.vscode/extensions/saviorisdead.RustyCode-0.18.0/node_modules/diff/lib/patch/create.js
Cyryl Płotnicki 2f946d6200 Add .vscode
2016-09-11 10:29:13 +02:00

153 lines
17 KiB
JavaScript

/*istanbul ignore start*/'use strict';
exports.__esModule = true;
exports. /*istanbul ignore end*/structuredPatch = structuredPatch;
/*istanbul ignore start*/exports. /*istanbul ignore end*/createTwoFilesPatch = createTwoFilesPatch;
/*istanbul ignore start*/exports. /*istanbul ignore end*/createPatch = createPatch;
var /*istanbul ignore start*/_line = require('../diff/line') /*istanbul ignore end*/;
/*istanbul ignore start*/
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
/*istanbul ignore end*/function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {
if (!options) {
options = { context: 4 };
}
var diff = /*istanbul ignore start*/(0, _line.diffLines) /*istanbul ignore end*/(oldStr, newStr);
diff.push({ value: '', lines: [] }); // Append an empty value to make cleanup easier
function contextLines(lines) {
return lines.map(function (entry) {
return ' ' + entry;
});
}
var hunks = [];
var oldRangeStart = 0,
newRangeStart = 0,
curRange = [],
oldLine = 1,
newLine = 1;
/*istanbul ignore start*/
var _loop = function _loop( /*istanbul ignore end*/i) {
var current = diff[i],
lines = current.lines || current.value.replace(/\n$/, '').split('\n');
current.lines = lines;
if (current.added || current.removed) {
/*istanbul ignore start*/
var _curRange;
/*istanbul ignore end*/
// If we have previous context, start with that
if (!oldRangeStart) {
var prev = diff[i - 1];
oldRangeStart = oldLine;
newRangeStart = newLine;
if (prev) {
curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : [];
oldRangeStart -= curRange.length;
newRangeStart -= curRange.length;
}
}
// Output our changes
/*istanbul ignore start*/(_curRange = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/lines.map(function (entry) {
return (current.added ? '+' : '-') + entry;
})));
// Track the updated file position
if (current.added) {
newLine += lines.length;
} else {
oldLine += lines.length;
}
} else {
// Identical context lines. Track line changes
if (oldRangeStart) {
// Close out any changes that have been output (or join overlapping)
if (lines.length <= options.context * 2 && i < diff.length - 2) {
/*istanbul ignore start*/
var _curRange2;
/*istanbul ignore end*/
// Overlapping
/*istanbul ignore start*/(_curRange2 = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange2 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/contextLines(lines)));
} else {
/*istanbul ignore start*/
var _curRange3;
/*istanbul ignore end*/
// end the range and output
var contextSize = Math.min(lines.length, options.context);
/*istanbul ignore start*/(_curRange3 = /*istanbul ignore end*/curRange).push. /*istanbul ignore start*/apply /*istanbul ignore end*/( /*istanbul ignore start*/_curRange3 /*istanbul ignore end*/, /*istanbul ignore start*/_toConsumableArray( /*istanbul ignore end*/contextLines(lines.slice(0, contextSize))));
var hunk = {
oldStart: oldRangeStart,
oldLines: oldLine - oldRangeStart + contextSize,
newStart: newRangeStart,
newLines: newLine - newRangeStart + contextSize,
lines: curRange
};
if (i >= diff.length - 2 && lines.length <= options.context) {
// EOF is inside this hunk
var oldEOFNewline = /\n$/.test(oldStr);
var newEOFNewline = /\n$/.test(newStr);
if (lines.length == 0 && !oldEOFNewline) {
// special case: old has no eol and no trailing context; no-nl can end up before adds
curRange.splice(hunk.oldLines, 0, '\\ No newline at end of file');
} else if (!oldEOFNewline || !newEOFNewline) {
curRange.push('\\ No newline at end of file');
}
}
hunks.push(hunk);
oldRangeStart = 0;
newRangeStart = 0;
curRange = [];
}
}
oldLine += lines.length;
newLine += lines.length;
}
};
for (var i = 0; i < diff.length; i++) {
/*istanbul ignore start*/
_loop( /*istanbul ignore end*/i);
}
return {
oldFileName: oldFileName, newFileName: newFileName,
oldHeader: oldHeader, newHeader: newHeader,
hunks: hunks
};
}
function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {
var diff = structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options);
var ret = [];
if (oldFileName == newFileName) {
ret.push('Index: ' + oldFileName);
}
ret.push('===================================================================');
ret.push('--- ' + diff.oldFileName + (typeof diff.oldHeader === 'undefined' ? '' : '\t' + diff.oldHeader));
ret.push('+++ ' + diff.newFileName + (typeof diff.newHeader === 'undefined' ? '' : '\t' + diff.newHeader));
for (var i = 0; i < diff.hunks.length; i++) {
var hunk = diff.hunks[i];
ret.push('@@ -' + hunk.oldStart + ',' + hunk.oldLines + ' +' + hunk.newStart + ',' + hunk.newLines + ' @@');
ret.push.apply(ret, hunk.lines);
}
return ret.join('\n') + '\n';
}
function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) {
return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/patch/create.js"],"names":[],"mappings":"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","file":"create.js","sourcesContent":["import {diffLines} from '../diff/line';\n\nexport function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {\n  if (!options) {\n    options = { context: 4 };\n  }\n\n  const diff = diffLines(oldStr, newStr);\n  diff.push({value: '', lines: []});   // Append an empty value to make cleanup easier\n\n  function contextLines(lines) {\n    return lines.map(function(entry) { return ' ' + entry; });\n  }\n\n  let hunks = [];\n  let oldRangeStart = 0, newRangeStart = 0, curRange = [],\n      oldLine = 1, newLine = 1;\n  for (let i = 0; i < diff.length; i++) {\n    const current = diff[i],\n          lines = current.lines || current.value.replace(/\\n$/, '').split('\\n');\n    current.lines = lines;\n\n    if (current.added || current.removed) {\n      // If we have previous context, start with that\n      if (!oldRangeStart) {\n        const prev = diff[i - 1];\n        oldRangeStart = oldLine;\n        newRangeStart = newLine;\n\n        if (prev) {\n          curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : [];\n          oldRangeStart -= curRange.length;\n          newRangeStart -= curRange.length;\n        }\n      }\n\n      // Output our changes\n      curRange.push(... lines.map(function(entry) {\n        return (current.added ? '+' : '-') + entry;\n      }));\n\n      // Track the updated file position\n      if (current.added) {\n        newLine += lines.length;\n      } else {\n        oldLine += lines.length;\n      }\n    } else {\n      // Identical context lines. Track line changes\n      if (oldRangeStart) {\n        // Close out any changes that have been output (or join overlapping)\n        if (lines.length <= options.context * 2 && i < diff.length - 2) {\n          // Overlapping\n          curRange.push(... contextLines(lines));\n        } else {\n          // end the range and output\n          let contextSize = Math.min(lines.length, options.context);\n          curRange.push(... contextLines(lines.slice(0, contextSize)));\n\n          let hunk = {\n            oldStart: oldRangeStart,\n            oldLines: (oldLine - oldRangeStart + contextSize),\n            newStart: newRangeStart,\n            newLines: (newLine - newRangeStart + contextSize),\n            lines: curRange\n          };\n          if (i >= diff.length - 2 && lines.length <= options.context) {\n            // EOF is inside this hunk\n            let oldEOFNewline = (/\\n$/.test(oldStr));\n            let newEOFNewline = (/\\n$/.test(newStr));\n            if (lines.length == 0 && !oldEOFNewline) {\n              // special case: old has no eol and no trailing context; no-nl can end up before adds\n              curRange.splice(hunk.oldLines, 0, '\\\\ No newline at end of file');\n            } else if (!oldEOFNewline || !newEOFNewline) {\n              curRange.push('\\\\ No newline at end of file');\n            }\n          }\n          hunks.push(hunk);\n\n          oldRangeStart = 0;\n          newRangeStart = 0;\n          curRange = [];\n        }\n      }\n      oldLine += lines.length;\n      newLine += lines.length;\n    }\n  }\n\n  return {\n    oldFileName: oldFileName, newFileName: newFileName,\n    oldHeader: oldHeader, newHeader: newHeader,\n    hunks: hunks\n  };\n}\n\nexport function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {\n  const diff = structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options);\n\n  const ret = [];\n  if (oldFileName == newFileName) {\n    ret.push('Index: ' + oldFileName);\n  }\n  ret.push('===================================================================');\n  ret.push('--- ' + diff.oldFileName + (typeof diff.oldHeader === 'undefined' ? '' : '\\t' + diff.oldHeader));\n  ret.push('+++ ' + diff.newFileName + (typeof diff.newHeader === 'undefined' ? '' : '\\t' + diff.newHeader));\n\n  for (let i = 0; i < diff.hunks.length; i++) {\n    const hunk = diff.hunks[i];\n    ret.push(\n      '@@ -' + hunk.oldStart + ',' + hunk.oldLines\n      + ' +' + hunk.newStart + ',' + hunk.newLines\n      + ' @@'\n    );\n    ret.push.apply(ret, hunk.lines);\n  }\n\n  return ret.join('\\n') + '\\n';\n}\n\nexport function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) {\n  return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options);\n}\n"]}