HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /proc/1780863/root/usr/share/nodejs/diff/lib/patch/
Upload File :
Current File : //proc/1780863/root/usr/share/nodejs/diff/lib/patch/create.js
/*istanbul ignore start*/
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.createPatch = createPatch;
exports.createTwoFilesPatch = createTwoFilesPatch;
exports.formatPatch = formatPatch;
exports.structuredPatch = structuredPatch;
/*istanbul ignore end*/
var
/*istanbul ignore start*/
_line = require("../diff/line")
/*istanbul ignore end*/
;
/*istanbul ignore start*/ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
/*istanbul ignore end*/
function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {
  if (!options) {
    options = {};
  }
  if (typeof options.context === 'undefined') {
    options.context = 4;
  }
  var diff =
  /*istanbul ignore start*/
  (0,
  /*istanbul ignore end*/
  /*istanbul ignore start*/
  _line
  /*istanbul ignore end*/
  .
  /*istanbul ignore start*/
  diffLines)
  /*istanbul ignore end*/
  (oldStr, newStr, options);
  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*/
      /*istanbul ignore end*/
      /*istanbul ignore start*/
      (_curRange =
      /*istanbul ignore end*/
      curRange).push.apply(
      /*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*/
          /*istanbul ignore end*/
          /*istanbul ignore start*/
          (_curRange2 =
          /*istanbul ignore end*/
          curRange).push.apply(
          /*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*/
          /*istanbul ignore end*/
          /*istanbul ignore start*/
          (_curRange3 =
          /*istanbul ignore end*/
          curRange).push.apply(
          /*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);
            var noNlBeforeAdds = lines.length == 0 && curRange.length > hunk.oldLines;
            if (!oldEOFNewline && noNlBeforeAdds && oldStr.length > 0) {
              // special case: old has no eol and no trailing context; no-nl can end up before adds
              // however, if the old file is empty, do not output the no-nl line
              curRange.splice(hunk.oldLines, 0, '\\ No newline at end of file');
            }
            if (!oldEOFNewline && !noNlBeforeAdds || !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 formatPatch(diff) {
  var ret = [];
  if (diff.oldFileName == diff.newFileName) {
    ret.push('Index: ' + diff.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];
    // Unified Diff Format quirk: If the chunk size is 0,
    // the first number is one lower than one would expect.
    // https://www.artima.com/weblogs/viewpost.jsp?thread=164293
    if (hunk.oldLines === 0) {
      hunk.oldStart -= 1;
    }
    if (hunk.newLines === 0) {
      hunk.newStart -= 1;
    }
    ret.push('@@ -' + hunk.oldStart + ',' + hunk.oldLines + ' +' + hunk.newStart + ',' + hunk.newLines + ' @@');
    ret.push.apply(ret, hunk.lines);
  }
  return ret.join('\n') + '\n';
}
function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {
  return formatPatch(structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options));
}
function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) {
  return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["structuredPatch","oldFileName","newFileName","oldStr","newStr","oldHeader","newHeader","options","context","diff","diffLines","push","value","lines","contextLines","map","entry","hunks","oldRangeStart","newRangeStart","curRange","oldLine","newLine","i","current","replace","split","added","removed","prev","slice","length","contextSize","Math","min","hunk","oldStart","oldLines","newStart","newLines","oldEOFNewline","test","newEOFNewline","noNlBeforeAdds","splice","formatPatch","ret","apply","join","createTwoFilesPatch","createPatch","fileName"],"sources":["../../src/patch/create.js"],"sourcesContent":["import {diffLines} from '../diff/line';\n\nexport function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {\n  if (!options) {\n    options = {};\n  }\n  if (typeof options.context === 'undefined') {\n    options.context = 4;\n  }\n\n  const diff = diffLines(oldStr, newStr, options);\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            let noNlBeforeAdds = lines.length == 0 && curRange.length > hunk.oldLines;\n            if (!oldEOFNewline && noNlBeforeAdds && oldStr.length > 0) {\n              // special case: old has no eol and no trailing context; no-nl can end up before adds\n              // however, if the old file is empty, do not output the no-nl line\n              curRange.splice(hunk.oldLines, 0, '\\\\ No newline at end of file');\n            }\n            if ((!oldEOFNewline && !noNlBeforeAdds) || !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 formatPatch(diff) {\n  const ret = [];\n  if (diff.oldFileName == diff.newFileName) {\n    ret.push('Index: ' + diff.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    // Unified Diff Format quirk: If the chunk size is 0,\n    // the first number is one lower than one would expect.\n    // https://www.artima.com/weblogs/viewpost.jsp?thread=164293\n    if (hunk.oldLines === 0) {\n      hunk.oldStart -= 1;\n    }\n    if (hunk.newLines === 0) {\n      hunk.newStart -= 1;\n    }\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 createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) {\n  return formatPatch(structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options));\n}\n\nexport function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) {\n  return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options);\n}\n"],"mappings":"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"}