HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /proc/1991108/root/usr/share/nodejs/diff/lib/patch/
Upload File :
Current File : //proc/1991108/root/usr/share/nodejs/diff/lib/patch/apply.js
/*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,{"version":3,"names":["applyPatch","source","uniDiff","options","parsePatch","Array","isArray","length","Error","lines","split","delimiters","match","hunks","compareLine","lineNumber","line","operation","patchContent","errorCount","fuzzFactor","minLine","offset","removeEOFNL","addEOFNL","hunkFits","hunk","toPos","j","content","substr","i","maxLine","oldLines","localOffset","oldStart","iterator","distanceIterator","undefined","diffOffset","newLines","delimiter","linedelimiters","splice","previousOperation","pop","push","_k","join","applyPatches","currentIndex","processIndex","index","complete","loadFile","err","data","updatedContent","patched"],"sources":["../../src/patch/apply.js"],"sourcesContent":["import {parsePatch} from './parse';\nimport distanceIterator from '../util/distance-iterator';\n\nexport function applyPatch(source, uniDiff, options = {}) {\n  if (typeof uniDiff === 'string') {\n    uniDiff = parsePatch(uniDiff);\n  }\n\n  if (Array.isArray(uniDiff)) {\n    if (uniDiff.length > 1) {\n      throw new Error('applyPatch only works with a single input.');\n    }\n\n    uniDiff = uniDiff[0];\n  }\n\n  // Apply the diff to the input\n  let lines = source.split(/\\r\\n|[\\n\\v\\f\\r\\x85]/),\n      delimiters = source.match(/\\r\\n|[\\n\\v\\f\\r\\x85]/g) || [],\n      hunks = uniDiff.hunks,\n\n      compareLine = options.compareLine || ((lineNumber, line, operation, patchContent) => line === patchContent),\n      errorCount = 0,\n      fuzzFactor = options.fuzzFactor || 0,\n      minLine = 0,\n      offset = 0,\n\n      removeEOFNL,\n      addEOFNL;\n\n  /**\n   * Checks if the hunk exactly fits on the provided location\n   */\n  function hunkFits(hunk, toPos) {\n    for (let j = 0; j < hunk.lines.length; j++) {\n      let line = hunk.lines[j],\n          operation = (line.length > 0 ? line[0] : ' '),\n          content = (line.length > 0 ? line.substr(1) : line);\n\n      if (operation === ' ' || operation === '-') {\n        // Context sanity check\n        if (!compareLine(toPos + 1, lines[toPos], operation, content)) {\n          errorCount++;\n\n          if (errorCount > fuzzFactor) {\n            return false;\n          }\n        }\n        toPos++;\n      }\n    }\n\n    return true;\n  }\n\n  // Search best fit offsets for each hunk based on the previous ones\n  for (let i = 0; i < hunks.length; i++) {\n    let hunk = hunks[i],\n        maxLine = lines.length - hunk.oldLines,\n        localOffset = 0,\n        toPos = offset + hunk.oldStart - 1;\n\n    let iterator = distanceIterator(toPos, minLine, maxLine);\n\n    for (; localOffset !== undefined; localOffset = iterator()) {\n      if (hunkFits(hunk, toPos + localOffset)) {\n        hunk.offset = offset += localOffset;\n        break;\n      }\n    }\n\n    if (localOffset === undefined) {\n      return false;\n    }\n\n    // Set lower text limit to end of the current hunk, so next ones don't try\n    // to fit over already patched text\n    minLine = hunk.offset + hunk.oldStart + hunk.oldLines;\n  }\n\n  // Apply patch hunks\n  let diffOffset = 0;\n  for (let i = 0; i < hunks.length; i++) {\n    let hunk = hunks[i],\n        toPos = hunk.oldStart + hunk.offset + diffOffset - 1;\n    diffOffset += hunk.newLines - hunk.oldLines;\n\n    for (let j = 0; j < hunk.lines.length; j++) {\n      let line = hunk.lines[j],\n          operation = (line.length > 0 ? line[0] : ' '),\n          content = (line.length > 0 ? line.substr(1) : line),\n          delimiter = hunk.linedelimiters[j];\n\n      if (operation === ' ') {\n        toPos++;\n      } else if (operation === '-') {\n        lines.splice(toPos, 1);\n        delimiters.splice(toPos, 1);\n      /* istanbul ignore else */\n      } else if (operation === '+') {\n        lines.splice(toPos, 0, content);\n        delimiters.splice(toPos, 0, delimiter);\n        toPos++;\n      } else if (operation === '\\\\') {\n        let previousOperation = hunk.lines[j - 1] ? hunk.lines[j - 1][0] : null;\n        if (previousOperation === '+') {\n          removeEOFNL = true;\n        } else if (previousOperation === '-') {\n          addEOFNL = true;\n        }\n      }\n    }\n  }\n\n  // Handle EOFNL insertion/removal\n  if (removeEOFNL) {\n    while (!lines[lines.length - 1]) {\n      lines.pop();\n      delimiters.pop();\n    }\n  } else if (addEOFNL) {\n    lines.push('');\n    delimiters.push('\\n');\n  }\n  for (let _k = 0; _k < lines.length - 1; _k++) {\n    lines[_k] = lines[_k] + delimiters[_k];\n  }\n  return lines.join('');\n}\n\n// Wrapper that supports multiple file patches via callbacks.\nexport function applyPatches(uniDiff, options) {\n  if (typeof uniDiff === 'string') {\n    uniDiff = parsePatch(uniDiff);\n  }\n\n  let currentIndex = 0;\n  function processIndex() {\n    let index = uniDiff[currentIndex++];\n    if (!index) {\n      return options.complete();\n    }\n\n    options.loadFile(index, function(err, data) {\n      if (err) {\n        return options.complete(err);\n      }\n\n      let updatedContent = applyPatch(data, index, options);\n      options.patched(index, updatedContent, function(err) {\n        if (err) {\n          return options.complete(err);\n        }\n\n        processIndex();\n      });\n    });\n  }\n  processIndex();\n}\n"],"mappings":"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"}