Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 1 | /*istanbul ignore start*/ |
| 2 | "use strict"; |
| 3 | |
| 4 | Object.defineProperty(exports, "__esModule", { |
| 5 | value: true |
| 6 | }); |
| 7 | exports.calcLineCount = calcLineCount; |
| 8 | exports.merge = merge; |
| 9 | |
| 10 | /*istanbul ignore end*/ |
| 11 | var |
| 12 | /*istanbul ignore start*/ |
| 13 | _create = require("./create") |
| 14 | /*istanbul ignore end*/ |
| 15 | ; |
| 16 | |
| 17 | var |
| 18 | /*istanbul ignore start*/ |
| 19 | _parse = require("./parse") |
| 20 | /*istanbul ignore end*/ |
| 21 | ; |
| 22 | |
| 23 | var |
| 24 | /*istanbul ignore start*/ |
| 25 | _array = require("../util/array") |
| 26 | /*istanbul ignore end*/ |
| 27 | ; |
| 28 | |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 29 | /*istanbul ignore start*/ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 30 | |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 31 | 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."); } |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 32 | |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 33 | 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); } |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 34 | |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 35 | function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } |
| 36 | |
| 37 | function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } |
| 38 | |
| 39 | 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; } |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 40 | |
| 41 | /*istanbul ignore end*/ |
| 42 | function calcLineCount(hunk) { |
| 43 | /*istanbul ignore start*/ |
| 44 | var _calcOldNewLineCount = |
| 45 | /*istanbul ignore end*/ |
| 46 | calcOldNewLineCount(hunk.lines), |
| 47 | oldLines = _calcOldNewLineCount.oldLines, |
| 48 | newLines = _calcOldNewLineCount.newLines; |
| 49 | |
| 50 | if (oldLines !== undefined) { |
| 51 | hunk.oldLines = oldLines; |
| 52 | } else { |
| 53 | delete hunk.oldLines; |
| 54 | } |
| 55 | |
| 56 | if (newLines !== undefined) { |
| 57 | hunk.newLines = newLines; |
| 58 | } else { |
| 59 | delete hunk.newLines; |
| 60 | } |
| 61 | } |
| 62 | |
| 63 | function merge(mine, theirs, base) { |
| 64 | mine = loadPatch(mine, base); |
| 65 | theirs = loadPatch(theirs, base); |
| 66 | var ret = {}; // For index we just let it pass through as it doesn't have any necessary meaning. |
| 67 | // Leaving sanity checks on this to the API consumer that may know more about the |
| 68 | // meaning in their own context. |
| 69 | |
| 70 | if (mine.index || theirs.index) { |
| 71 | ret.index = mine.index || theirs.index; |
| 72 | } |
| 73 | |
| 74 | if (mine.newFileName || theirs.newFileName) { |
| 75 | if (!fileNameChanged(mine)) { |
| 76 | // No header or no change in ours, use theirs (and ours if theirs does not exist) |
| 77 | ret.oldFileName = theirs.oldFileName || mine.oldFileName; |
| 78 | ret.newFileName = theirs.newFileName || mine.newFileName; |
| 79 | ret.oldHeader = theirs.oldHeader || mine.oldHeader; |
| 80 | ret.newHeader = theirs.newHeader || mine.newHeader; |
| 81 | } else if (!fileNameChanged(theirs)) { |
| 82 | // No header or no change in theirs, use ours |
| 83 | ret.oldFileName = mine.oldFileName; |
| 84 | ret.newFileName = mine.newFileName; |
| 85 | ret.oldHeader = mine.oldHeader; |
| 86 | ret.newHeader = mine.newHeader; |
| 87 | } else { |
| 88 | // Both changed... figure it out |
| 89 | ret.oldFileName = selectField(ret, mine.oldFileName, theirs.oldFileName); |
| 90 | ret.newFileName = selectField(ret, mine.newFileName, theirs.newFileName); |
| 91 | ret.oldHeader = selectField(ret, mine.oldHeader, theirs.oldHeader); |
| 92 | ret.newHeader = selectField(ret, mine.newHeader, theirs.newHeader); |
| 93 | } |
| 94 | } |
| 95 | |
| 96 | ret.hunks = []; |
| 97 | var mineIndex = 0, |
| 98 | theirsIndex = 0, |
| 99 | mineOffset = 0, |
| 100 | theirsOffset = 0; |
| 101 | |
| 102 | while (mineIndex < mine.hunks.length || theirsIndex < theirs.hunks.length) { |
| 103 | var mineCurrent = mine.hunks[mineIndex] || { |
| 104 | oldStart: Infinity |
| 105 | }, |
| 106 | theirsCurrent = theirs.hunks[theirsIndex] || { |
| 107 | oldStart: Infinity |
| 108 | }; |
| 109 | |
| 110 | if (hunkBefore(mineCurrent, theirsCurrent)) { |
| 111 | // This patch does not overlap with any of the others, yay. |
| 112 | ret.hunks.push(cloneHunk(mineCurrent, mineOffset)); |
| 113 | mineIndex++; |
| 114 | theirsOffset += mineCurrent.newLines - mineCurrent.oldLines; |
| 115 | } else if (hunkBefore(theirsCurrent, mineCurrent)) { |
| 116 | // This patch does not overlap with any of the others, yay. |
| 117 | ret.hunks.push(cloneHunk(theirsCurrent, theirsOffset)); |
| 118 | theirsIndex++; |
| 119 | mineOffset += theirsCurrent.newLines - theirsCurrent.oldLines; |
| 120 | } else { |
| 121 | // Overlap, merge as best we can |
| 122 | var mergedHunk = { |
| 123 | oldStart: Math.min(mineCurrent.oldStart, theirsCurrent.oldStart), |
| 124 | oldLines: 0, |
| 125 | newStart: Math.min(mineCurrent.newStart + mineOffset, theirsCurrent.oldStart + theirsOffset), |
| 126 | newLines: 0, |
| 127 | lines: [] |
| 128 | }; |
| 129 | mergeLines(mergedHunk, mineCurrent.oldStart, mineCurrent.lines, theirsCurrent.oldStart, theirsCurrent.lines); |
| 130 | theirsIndex++; |
| 131 | mineIndex++; |
| 132 | ret.hunks.push(mergedHunk); |
| 133 | } |
| 134 | } |
| 135 | |
| 136 | return ret; |
| 137 | } |
| 138 | |
| 139 | function loadPatch(param, base) { |
| 140 | if (typeof param === 'string') { |
| 141 | if (/^@@/m.test(param) || /^Index:/m.test(param)) { |
| 142 | return ( |
| 143 | /*istanbul ignore start*/ |
| 144 | (0, |
| 145 | /*istanbul ignore end*/ |
| 146 | |
| 147 | /*istanbul ignore start*/ |
| 148 | _parse |
| 149 | /*istanbul ignore end*/ |
| 150 | . |
| 151 | /*istanbul ignore start*/ |
| 152 | parsePatch) |
| 153 | /*istanbul ignore end*/ |
| 154 | (param)[0] |
| 155 | ); |
| 156 | } |
| 157 | |
| 158 | if (!base) { |
| 159 | throw new Error('Must provide a base reference or pass in a patch'); |
| 160 | } |
| 161 | |
| 162 | return ( |
| 163 | /*istanbul ignore start*/ |
| 164 | (0, |
| 165 | /*istanbul ignore end*/ |
| 166 | |
| 167 | /*istanbul ignore start*/ |
| 168 | _create |
| 169 | /*istanbul ignore end*/ |
| 170 | . |
| 171 | /*istanbul ignore start*/ |
| 172 | structuredPatch) |
| 173 | /*istanbul ignore end*/ |
| 174 | (undefined, undefined, base, param) |
| 175 | ); |
| 176 | } |
| 177 | |
| 178 | return param; |
| 179 | } |
| 180 | |
| 181 | function fileNameChanged(patch) { |
| 182 | return patch.newFileName && patch.newFileName !== patch.oldFileName; |
| 183 | } |
| 184 | |
| 185 | function selectField(index, mine, theirs) { |
| 186 | if (mine === theirs) { |
| 187 | return mine; |
| 188 | } else { |
| 189 | index.conflict = true; |
| 190 | return { |
| 191 | mine: mine, |
| 192 | theirs: theirs |
| 193 | }; |
| 194 | } |
| 195 | } |
| 196 | |
| 197 | function hunkBefore(test, check) { |
| 198 | return test.oldStart < check.oldStart && test.oldStart + test.oldLines < check.oldStart; |
| 199 | } |
| 200 | |
| 201 | function cloneHunk(hunk, offset) { |
| 202 | return { |
| 203 | oldStart: hunk.oldStart, |
| 204 | oldLines: hunk.oldLines, |
| 205 | newStart: hunk.newStart + offset, |
| 206 | newLines: hunk.newLines, |
| 207 | lines: hunk.lines |
| 208 | }; |
| 209 | } |
| 210 | |
| 211 | function mergeLines(hunk, mineOffset, mineLines, theirOffset, theirLines) { |
| 212 | // This will generally result in a conflicted hunk, but there are cases where the context |
| 213 | // is the only overlap where we can successfully merge the content here. |
| 214 | var mine = { |
| 215 | offset: mineOffset, |
| 216 | lines: mineLines, |
| 217 | index: 0 |
| 218 | }, |
| 219 | their = { |
| 220 | offset: theirOffset, |
| 221 | lines: theirLines, |
| 222 | index: 0 |
| 223 | }; // Handle any leading content |
| 224 | |
| 225 | insertLeading(hunk, mine, their); |
| 226 | insertLeading(hunk, their, mine); // Now in the overlap content. Scan through and select the best changes from each. |
| 227 | |
| 228 | while (mine.index < mine.lines.length && their.index < their.lines.length) { |
| 229 | var mineCurrent = mine.lines[mine.index], |
| 230 | theirCurrent = their.lines[their.index]; |
| 231 | |
| 232 | if ((mineCurrent[0] === '-' || mineCurrent[0] === '+') && (theirCurrent[0] === '-' || theirCurrent[0] === '+')) { |
| 233 | // Both modified ... |
| 234 | mutualChange(hunk, mine, their); |
| 235 | } else if (mineCurrent[0] === '+' && theirCurrent[0] === ' ') { |
| 236 | /*istanbul ignore start*/ |
| 237 | var _hunk$lines; |
| 238 | |
| 239 | /*istanbul ignore end*/ |
| 240 | // Mine inserted |
| 241 | |
| 242 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 243 | |
| 244 | /*istanbul ignore end*/ |
| 245 | |
| 246 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 247 | (_hunk$lines = |
| 248 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 249 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 250 | /*istanbul ignore start*/ |
| 251 | _hunk$lines |
| 252 | /*istanbul ignore end*/ |
| 253 | , |
| 254 | /*istanbul ignore start*/ |
| 255 | _toConsumableArray( |
| 256 | /*istanbul ignore end*/ |
| 257 | collectChange(mine))); |
| 258 | } else if (theirCurrent[0] === '+' && mineCurrent[0] === ' ') { |
| 259 | /*istanbul ignore start*/ |
| 260 | var _hunk$lines2; |
| 261 | |
| 262 | /*istanbul ignore end*/ |
| 263 | // Theirs inserted |
| 264 | |
| 265 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 266 | |
| 267 | /*istanbul ignore end*/ |
| 268 | |
| 269 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 270 | (_hunk$lines2 = |
| 271 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 272 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 273 | /*istanbul ignore start*/ |
| 274 | _hunk$lines2 |
| 275 | /*istanbul ignore end*/ |
| 276 | , |
| 277 | /*istanbul ignore start*/ |
| 278 | _toConsumableArray( |
| 279 | /*istanbul ignore end*/ |
| 280 | collectChange(their))); |
| 281 | } else if (mineCurrent[0] === '-' && theirCurrent[0] === ' ') { |
| 282 | // Mine removed or edited |
| 283 | removal(hunk, mine, their); |
| 284 | } else if (theirCurrent[0] === '-' && mineCurrent[0] === ' ') { |
| 285 | // Their removed or edited |
| 286 | removal(hunk, their, mine, true); |
| 287 | } else if (mineCurrent === theirCurrent) { |
| 288 | // Context identity |
| 289 | hunk.lines.push(mineCurrent); |
| 290 | mine.index++; |
| 291 | their.index++; |
| 292 | } else { |
| 293 | // Context mismatch |
| 294 | conflict(hunk, collectChange(mine), collectChange(their)); |
| 295 | } |
| 296 | } // Now push anything that may be remaining |
| 297 | |
| 298 | |
| 299 | insertTrailing(hunk, mine); |
| 300 | insertTrailing(hunk, their); |
| 301 | calcLineCount(hunk); |
| 302 | } |
| 303 | |
| 304 | function mutualChange(hunk, mine, their) { |
| 305 | var myChanges = collectChange(mine), |
| 306 | theirChanges = collectChange(their); |
| 307 | |
| 308 | if (allRemoves(myChanges) && allRemoves(theirChanges)) { |
| 309 | // Special case for remove changes that are supersets of one another |
| 310 | if ( |
| 311 | /*istanbul ignore start*/ |
| 312 | (0, |
| 313 | /*istanbul ignore end*/ |
| 314 | |
| 315 | /*istanbul ignore start*/ |
| 316 | _array |
| 317 | /*istanbul ignore end*/ |
| 318 | . |
| 319 | /*istanbul ignore start*/ |
| 320 | arrayStartsWith) |
| 321 | /*istanbul ignore end*/ |
| 322 | (myChanges, theirChanges) && skipRemoveSuperset(their, myChanges, myChanges.length - theirChanges.length)) { |
| 323 | /*istanbul ignore start*/ |
| 324 | var _hunk$lines3; |
| 325 | |
| 326 | /*istanbul ignore end*/ |
| 327 | |
| 328 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 329 | |
| 330 | /*istanbul ignore end*/ |
| 331 | |
| 332 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 333 | (_hunk$lines3 = |
| 334 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 335 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 336 | /*istanbul ignore start*/ |
| 337 | _hunk$lines3 |
| 338 | /*istanbul ignore end*/ |
| 339 | , |
| 340 | /*istanbul ignore start*/ |
| 341 | _toConsumableArray( |
| 342 | /*istanbul ignore end*/ |
| 343 | myChanges)); |
| 344 | |
| 345 | return; |
| 346 | } else if ( |
| 347 | /*istanbul ignore start*/ |
| 348 | (0, |
| 349 | /*istanbul ignore end*/ |
| 350 | |
| 351 | /*istanbul ignore start*/ |
| 352 | _array |
| 353 | /*istanbul ignore end*/ |
| 354 | . |
| 355 | /*istanbul ignore start*/ |
| 356 | arrayStartsWith) |
| 357 | /*istanbul ignore end*/ |
| 358 | (theirChanges, myChanges) && skipRemoveSuperset(mine, theirChanges, theirChanges.length - myChanges.length)) { |
| 359 | /*istanbul ignore start*/ |
| 360 | var _hunk$lines4; |
| 361 | |
| 362 | /*istanbul ignore end*/ |
| 363 | |
| 364 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 365 | |
| 366 | /*istanbul ignore end*/ |
| 367 | |
| 368 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 369 | (_hunk$lines4 = |
| 370 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 371 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 372 | /*istanbul ignore start*/ |
| 373 | _hunk$lines4 |
| 374 | /*istanbul ignore end*/ |
| 375 | , |
| 376 | /*istanbul ignore start*/ |
| 377 | _toConsumableArray( |
| 378 | /*istanbul ignore end*/ |
| 379 | theirChanges)); |
| 380 | |
| 381 | return; |
| 382 | } |
| 383 | } else if ( |
| 384 | /*istanbul ignore start*/ |
| 385 | (0, |
| 386 | /*istanbul ignore end*/ |
| 387 | |
| 388 | /*istanbul ignore start*/ |
| 389 | _array |
| 390 | /*istanbul ignore end*/ |
| 391 | . |
| 392 | /*istanbul ignore start*/ |
| 393 | arrayEqual) |
| 394 | /*istanbul ignore end*/ |
| 395 | (myChanges, theirChanges)) { |
| 396 | /*istanbul ignore start*/ |
| 397 | var _hunk$lines5; |
| 398 | |
| 399 | /*istanbul ignore end*/ |
| 400 | |
| 401 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 402 | |
| 403 | /*istanbul ignore end*/ |
| 404 | |
| 405 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 406 | (_hunk$lines5 = |
| 407 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 408 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 409 | /*istanbul ignore start*/ |
| 410 | _hunk$lines5 |
| 411 | /*istanbul ignore end*/ |
| 412 | , |
| 413 | /*istanbul ignore start*/ |
| 414 | _toConsumableArray( |
| 415 | /*istanbul ignore end*/ |
| 416 | myChanges)); |
| 417 | |
| 418 | return; |
| 419 | } |
| 420 | |
| 421 | conflict(hunk, myChanges, theirChanges); |
| 422 | } |
| 423 | |
| 424 | function removal(hunk, mine, their, swap) { |
| 425 | var myChanges = collectChange(mine), |
| 426 | theirChanges = collectContext(their, myChanges); |
| 427 | |
| 428 | if (theirChanges.merged) { |
| 429 | /*istanbul ignore start*/ |
| 430 | var _hunk$lines6; |
| 431 | |
| 432 | /*istanbul ignore end*/ |
| 433 | |
| 434 | /*istanbul ignore start*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 435 | |
| 436 | /*istanbul ignore end*/ |
| 437 | |
| 438 | /*istanbul ignore start*/ |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 439 | (_hunk$lines6 = |
| 440 | /*istanbul ignore end*/ |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 441 | hunk.lines).push.apply( |
Peter Marshall | 0b95ea1 | 2020-07-02 18:50:04 +0200 | [diff] [blame] | 442 | /*istanbul ignore start*/ |
| 443 | _hunk$lines6 |
| 444 | /*istanbul ignore end*/ |
| 445 | , |
| 446 | /*istanbul ignore start*/ |
| 447 | _toConsumableArray( |
| 448 | /*istanbul ignore end*/ |
| 449 | theirChanges.merged)); |
| 450 | } else { |
| 451 | conflict(hunk, swap ? theirChanges : myChanges, swap ? myChanges : theirChanges); |
| 452 | } |
| 453 | } |
| 454 | |
| 455 | function conflict(hunk, mine, their) { |
| 456 | hunk.conflict = true; |
| 457 | hunk.lines.push({ |
| 458 | conflict: true, |
| 459 | mine: mine, |
| 460 | theirs: their |
| 461 | }); |
| 462 | } |
| 463 | |
| 464 | function insertLeading(hunk, insert, their) { |
| 465 | while (insert.offset < their.offset && insert.index < insert.lines.length) { |
| 466 | var line = insert.lines[insert.index++]; |
| 467 | hunk.lines.push(line); |
| 468 | insert.offset++; |
| 469 | } |
| 470 | } |
| 471 | |
| 472 | function insertTrailing(hunk, insert) { |
| 473 | while (insert.index < insert.lines.length) { |
| 474 | var line = insert.lines[insert.index++]; |
| 475 | hunk.lines.push(line); |
| 476 | } |
| 477 | } |
| 478 | |
| 479 | function collectChange(state) { |
| 480 | var ret = [], |
| 481 | operation = state.lines[state.index][0]; |
| 482 | |
| 483 | while (state.index < state.lines.length) { |
| 484 | var line = state.lines[state.index]; // Group additions that are immediately after subtractions and treat them as one "atomic" modify change. |
| 485 | |
| 486 | if (operation === '-' && line[0] === '+') { |
| 487 | operation = '+'; |
| 488 | } |
| 489 | |
| 490 | if (operation === line[0]) { |
| 491 | ret.push(line); |
| 492 | state.index++; |
| 493 | } else { |
| 494 | break; |
| 495 | } |
| 496 | } |
| 497 | |
| 498 | return ret; |
| 499 | } |
| 500 | |
| 501 | function collectContext(state, matchChanges) { |
| 502 | var changes = [], |
| 503 | merged = [], |
| 504 | matchIndex = 0, |
| 505 | contextChanges = false, |
| 506 | conflicted = false; |
| 507 | |
| 508 | while (matchIndex < matchChanges.length && state.index < state.lines.length) { |
| 509 | var change = state.lines[state.index], |
| 510 | match = matchChanges[matchIndex]; // Once we've hit our add, then we are done |
| 511 | |
| 512 | if (match[0] === '+') { |
| 513 | break; |
| 514 | } |
| 515 | |
| 516 | contextChanges = contextChanges || change[0] !== ' '; |
| 517 | merged.push(match); |
| 518 | matchIndex++; // Consume any additions in the other block as a conflict to attempt |
| 519 | // to pull in the remaining context after this |
| 520 | |
| 521 | if (change[0] === '+') { |
| 522 | conflicted = true; |
| 523 | |
| 524 | while (change[0] === '+') { |
| 525 | changes.push(change); |
| 526 | change = state.lines[++state.index]; |
| 527 | } |
| 528 | } |
| 529 | |
| 530 | if (match.substr(1) === change.substr(1)) { |
| 531 | changes.push(change); |
| 532 | state.index++; |
| 533 | } else { |
| 534 | conflicted = true; |
| 535 | } |
| 536 | } |
| 537 | |
| 538 | if ((matchChanges[matchIndex] || '')[0] === '+' && contextChanges) { |
| 539 | conflicted = true; |
| 540 | } |
| 541 | |
| 542 | if (conflicted) { |
| 543 | return changes; |
| 544 | } |
| 545 | |
| 546 | while (matchIndex < matchChanges.length) { |
| 547 | merged.push(matchChanges[matchIndex++]); |
| 548 | } |
| 549 | |
| 550 | return { |
| 551 | merged: merged, |
| 552 | changes: changes |
| 553 | }; |
| 554 | } |
| 555 | |
| 556 | function allRemoves(changes) { |
| 557 | return changes.reduce(function (prev, change) { |
| 558 | return prev && change[0] === '-'; |
| 559 | }, true); |
| 560 | } |
| 561 | |
| 562 | function skipRemoveSuperset(state, removeChanges, delta) { |
| 563 | for (var i = 0; i < delta; i++) { |
| 564 | var changeContent = removeChanges[removeChanges.length - delta + i].substr(1); |
| 565 | |
| 566 | if (state.lines[state.index + i] !== ' ' + changeContent) { |
| 567 | return false; |
| 568 | } |
| 569 | } |
| 570 | |
| 571 | state.index += delta; |
| 572 | return true; |
| 573 | } |
| 574 | |
| 575 | function calcOldNewLineCount(lines) { |
| 576 | var oldLines = 0; |
| 577 | var newLines = 0; |
| 578 | lines.forEach(function (line) { |
| 579 | if (typeof line !== 'string') { |
| 580 | var myCount = calcOldNewLineCount(line.mine); |
| 581 | var theirCount = calcOldNewLineCount(line.theirs); |
| 582 | |
| 583 | if (oldLines !== undefined) { |
| 584 | if (myCount.oldLines === theirCount.oldLines) { |
| 585 | oldLines += myCount.oldLines; |
| 586 | } else { |
| 587 | oldLines = undefined; |
| 588 | } |
| 589 | } |
| 590 | |
| 591 | if (newLines !== undefined) { |
| 592 | if (myCount.newLines === theirCount.newLines) { |
| 593 | newLines += myCount.newLines; |
| 594 | } else { |
| 595 | newLines = undefined; |
| 596 | } |
| 597 | } |
| 598 | } else { |
| 599 | if (newLines !== undefined && (line[0] === '+' || line[0] === ' ')) { |
| 600 | newLines++; |
| 601 | } |
| 602 | |
| 603 | if (oldLines !== undefined && (line[0] === '-' || line[0] === ' ')) { |
| 604 | oldLines++; |
| 605 | } |
| 606 | } |
| 607 | }); |
| 608 | return { |
| 609 | oldLines: oldLines, |
| 610 | newLines: newLines |
| 611 | }; |
| 612 | } |
Tim van der Lippe | 6d109a9 | 2021-02-16 16:00:32 +0000 | [diff] [blame] | 613 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/patch/merge.js"],"names":["calcLineCount","hunk","calcOldNewLineCount","lines","oldLines","newLines","undefined","merge","mine","theirs","base","loadPatch","ret","index","newFileName","fileNameChanged","oldFileName","oldHeader","newHeader","selectField","hunks","mineIndex","theirsIndex","mineOffset","theirsOffset","length","mineCurrent","oldStart","Infinity","theirsCurrent","hunkBefore","push","cloneHunk","mergedHunk","Math","min","newStart","mergeLines","param","test","parsePatch","Error","structuredPatch","patch","conflict","check","offset","mineLines","theirOffset","theirLines","their","insertLeading","theirCurrent","mutualChange","collectChange","removal","insertTrailing","myChanges","theirChanges","allRemoves","arrayStartsWith","skipRemoveSuperset","arrayEqual","swap","collectContext","merged","insert","line","state","operation","matchChanges","changes","matchIndex","contextChanges","conflicted","change","match","substr","reduce","prev","removeChanges","delta","i","changeContent","forEach","myCount","theirCount"],"mappings":"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","sourcesContent":["import {structuredPatch} from './create';\nimport {parsePatch} from './parse';\n\nimport {arrayEqual, arrayStartsWith} from '../util/array';\n\nexport function calcLineCount(hunk) {\n  const {oldLines, newLines} = calcOldNewLineCount(hunk.lines);\n\n  if (oldLines !== undefined) {\n    hunk.oldLines = oldLines;\n  } else {\n    delete hunk.oldLines;\n  }\n\n  if (newLines !== undefined) {\n    hunk.newLines = newLines;\n  } else {\n    delete hunk.newLines;\n  }\n}\n\nexport function merge(mine, theirs, base) {\n  mine = loadPatch(mine, base);\n  theirs = loadPatch(theirs, base);\n\n  let ret = {};\n\n  // For index we just let it pass through as it doesn't have any necessary meaning.\n  // Leaving sanity checks on this to the API consumer that may know more about the\n  // meaning in their own context.\n  if (mine.index || theirs.index) {\n    ret.index = mine.index || theirs.index;\n  }\n\n  if (mine.newFileName || theirs.newFileName) {\n    if (!fileNameChanged(mine)) {\n      // No header or no change in ours, use theirs (and ours if theirs does not exist)\n      ret.oldFileName = theirs.oldFileName || mine.oldFileName;\n      ret.newFileName = theirs.newFileName || mine.newFileName;\n      ret.oldHeader = theirs.oldHeader || mine.oldHeader;\n      ret.newHeader = theirs.newHeader || mine.newHeader;\n    } else if (!fileNameChanged(theirs)) {\n      // No header or no change in theirs, use ours\n      ret.oldFileName = mine.oldFileName;\n      ret.newFileName = mine.newFileName;\n      ret.oldHeader = mine.oldHeader;\n      ret.newHeader = mine.newHeader;\n    } else {\n      // Both changed... figure it out\n      ret.oldFileName = selectField(ret, mine.oldFileName, theirs.oldFileName);\n      ret.newFileName = selectField(ret, mine.newFileName, theirs.newFileName);\n      ret.oldHeader = selectField(ret, mine.oldHeader, theirs.oldHeader);\n      ret.newHeader = selectField(ret, mine.newHeader, theirs.newHeader);\n    }\n  }\n\n  ret.hunks = [];\n\n  let mineIndex = 0,\n      theirsIndex = 0,\n      mineOffset = 0,\n      theirsOffset = 0;\n\n  while (mineIndex < mine.hunks.length || theirsIndex < theirs.hunks.length) {\n    let mineCurrent = mine.hunks[mineIndex] || {oldStart: Infinity},\n        theirsCurrent = theirs.hunks[theirsIndex] || {oldStart: Infinity};\n\n    if (hunkBefore(mineCurrent, theirsCurrent)) {\n      // This patch does not overlap with any of the others, yay.\n      ret.hunks.push(cloneHunk(mineCurrent, mineOffset));\n      mineIndex++;\n      theirsOffset += mineCurrent.newLines - mineCurrent.oldLines;\n    } else if (hunkBefore(theirsCurrent, mineCurrent)) {\n      // This patch does not overlap with any of the others, yay.\n      ret.hunks.push(cloneHunk(theirsCurrent, theirsOffset));\n      theirsIndex++;\n      mineOffset += theirsCurrent.newLines - theirsCurrent.oldLines;\n    } else {\n      // Overlap, merge as best we can\n      let mergedHunk = {\n        oldStart: Math.min(mineCurrent.oldStart, theirsCurrent.oldStart),\n        oldLines: 0,\n        newStart: Math.min(mineCurrent.newStart + mineOffset, theirsCurrent.oldStart + theirsOffset),\n        newLines: 0,\n        lines: []\n      };\n      mergeLines(mergedHunk, mineCurrent.oldStart, mineCurrent.lines, theirsCurrent.oldStart, theirsCurrent.lines);\n      theirsIndex++;\n      mineIndex++;\n\n      ret.hunks.push(mergedHunk);\n    }\n  }\n\n  return ret;\n}\n\nfunction loadPatch(param, base) {\n  if (typeof param === 'string') {\n    if ((/^@@/m).test(param) || ((/^Index:/m).test(param))) {\n      return parsePatch(param)[0];\n    }\n\n    if (!base) {\n      throw new Error('Must provide a base reference or pass in a patch');\n    }\n    return structuredPatch(undefined, undefined, base, param);\n  }\n\n  return param;\n}\n\nfunction fileNameChanged(patch) {\n  return patch.newFileName && patch.newFileName !== patch.oldFileName;\n}\n\nfunction selectField(index, mine, theirs) {\n  if (mine === theirs) {\n    return mine;\n  } else {\n    index.conflict = true;\n    return {mine, theirs};\n  }\n}\n\nfunction hunkBefore(test, check) {\n  return test.oldStart < check.oldStart\n    && (test.oldStart + test.oldLines) < check.oldStart;\n}\n\nfunction cloneHunk(hunk, offset) {\n  return {\n    oldStart: hunk.oldStart, oldLines: hunk.oldLines,\n    newStart: hunk.newStart + offset, newLines: hunk.newLines,\n    lines: hunk.lines\n  };\n}\n\nfunction mergeLines(hunk, mineOffset, mineLines, theirOffset, theirLines) {\n  // This will generally result in a conflicted hunk, but there are cases where the context\n  // is the only overlap where we can successfully merge the content here.\n  let mine = {offset: mineOffset, lines: mineLines, index: 0},\n      their = {offset: theirOffset, lines: theirLines, index: 0};\n\n  // Handle any leading content\n  insertLeading(hunk, mine, their);\n  insertLeading(hunk, their, mine);\n\n  // Now in the overlap content. Scan through and select the best changes from each.\n  while (mine.index < mine.lines.length && their.index < their.lines.length) {\n    let mineCurrent = mine.lines[mine.index],\n        theirCurrent = their.lines[their.index];\n\n    if ((mineCurrent[0] === '-' || mineCurrent[0] === '+')\n        && (theirCurrent[0] === '-' || theirCurrent[0] === '+')) {\n      // Both modified ...\n      mutualChange(hunk, mine, their);\n    } else if (mineCurrent[0] === '+' && theirCurrent[0] === ' ') {\n      // Mine inserted\n      hunk.lines.push(... collectChange(mine));\n    } else if (theirCurrent[0] === '+' && mineCurrent[0] === ' ') {\n      // Theirs inserted\n      hunk.lines.push(... collectChange(their));\n    } else if (mineCurrent[0] === '-' && theirCurrent[0] === ' ') {\n      // Mine removed or edited\n      removal(hunk, mine, their);\n    } else if (theirCurrent[0] === '-' && mineCurrent[0] === ' ') {\n      // Their removed or edited\n      removal(hunk, their, mine, true);\n    } else if (mineCurrent === theirCurrent) {\n      // Context identity\n      hunk.lines.push(mineCurrent);\n      mine.index++;\n      their.index++;\n    } else {\n      // Context mismatch\n      conflict(hunk, collectChange(mine), collectChange(their));\n    }\n  }\n\n  // Now push anything that may be remaining\n  insertTrailing(hunk, mine);\n  insertTrailing(hunk, their);\n\n  calcLineCount(hunk);\n}\n\nfunction mutualChange(hunk, mine, their) {\n  let myChanges = collectChange(mine),\n      theirChanges = collectChange(their);\n\n  if (allRemoves(myChanges) && allRemoves(theirChanges)) {\n    // Special case for remove changes that are supersets of one another\n    if (arrayStartsWith(myChanges, theirChanges)\n        && skipRemoveSuperset(their, myChanges, myChanges.length - theirChanges.length)) {\n      hunk.lines.push(... myChanges);\n      return;\n    } else if (arrayStartsWith(theirChanges, myChanges)\n        && skipRemoveSuperset(mine, theirChanges, theirChanges.length - myChanges.length)) {\n      hunk.lines.push(... theirChanges);\n      return;\n    }\n  } else if (arrayEqual(myChanges, theirChanges)) {\n    hunk.lines.push(... myChanges);\n    return;\n  }\n\n  conflict(hunk, myChanges, theirChanges);\n}\n\nfunction removal(hunk, mine, their, swap) {\n  let myChanges = collectChange(mine),\n      theirChanges = collectContext(their, myChanges);\n  if (theirChanges.merged) {\n    hunk.lines.push(... theirChanges.merged);\n  } else {\n    conflict(hunk, swap ? theirChanges : myChanges, swap ? myChanges : theirChanges);\n  }\n}\n\nfunction conflict(hunk, mine, their) {\n  hunk.conflict = true;\n  hunk.lines.push({\n    conflict: true,\n    mine: mine,\n    theirs: their\n  });\n}\n\nfunction insertLeading(hunk, insert, their) {\n  while (insert.offset < their.offset && insert.index < insert.lines.length) {\n    let line = insert.lines[insert.index++];\n    hunk.lines.push(line);\n    insert.offset++;\n  }\n}\nfunction insertTrailing(hunk, insert) {\n  while (insert.index < insert.lines.length) {\n    let line = insert.lines[insert.index++];\n    hunk.lines.push(line);\n  }\n}\n\nfunction collectChange(state) {\n  let ret = [],\n      operation = state.lines[state.index][0];\n  while (state.index < state.lines.length) {\n    let line = state.lines[state.index];\n\n    // Group additions that are immediately after subtractions and treat them as one \"atomic\" modify change.\n    if (operation === '-' && line[0] === '+') {\n      operation = '+';\n    }\n\n    if (operation === line[0]) {\n      ret.push(line);\n      state.index++;\n    } else {\n      break;\n    }\n  }\n\n  return ret;\n}\nfunction collectContext(state, matchChanges) {\n  let changes = [],\n      merged = [],\n      matchIndex = 0,\n      contextChanges = false,\n      conflicted = false;\n  while (matchIndex < matchChanges.length\n        && state.index < state.lines.length) {\n    let change = state.lines[state.index],\n        match = matchChanges[matchIndex];\n\n    // Once we've hit our add, then we are done\n    if (match[0] === '+') {\n      break;\n    }\n\n    contextChanges = contextChanges || change[0] !== ' ';\n\n    merged.push(match);\n    matchIndex++;\n\n    // Consume any additions in the other block as a conflict to attempt\n    // to pull in the remaining context after this\n    if (change[0] === '+') {\n      conflicted = true;\n\n      while (change[0] === '+') {\n        changes.push(change);\n        change = state.lines[++state.index];\n      }\n    }\n\n    if (match.substr(1) === change.substr(1)) {\n      changes.push(change);\n      state.index++;\n    } else {\n      conflicted = true;\n    }\n  }\n\n  if ((matchChanges[matchIndex] || '')[0] === '+'\n      && contextChanges) {\n    conflicted = true;\n  }\n\n  if (conflicted) {\n    return changes;\n  }\n\n  while (matchIndex < matchChanges.length) {\n    merged.push(matchChanges[matchIndex++]);\n  }\n\n  return {\n    merged,\n    changes\n  };\n}\n\nfunction allRemoves(changes) {\n  return changes.reduce(function(prev, change) {\n    return prev && change[0] === '-';\n  }, true);\n}\nfunction skipRemoveSuperset(state, removeChanges, delta) {\n  for (let i = 0; i < delta; i++) {\n    let changeContent = removeChanges[removeChanges.length - delta + i].substr(1);\n    if (state.lines[state.index + i] !== ' ' + changeContent) {\n      return false;\n    }\n  }\n\n  state.index += delta;\n  return true;\n}\n\nfunction calcOldNewLineCount(lines) {\n  let oldLines = 0;\n  let newLines = 0;\n\n  lines.forEach(function(line) {\n    if (typeof line !== 'string') {\n      let myCount = calcOldNewLineCount(line.mine);\n      let theirCount = calcOldNewLineCount(line.theirs);\n\n      if (oldLines !== undefined) {\n        if (myCount.oldLines === theirCount.oldLines) {\n          oldLines += myCount.oldLines;\n        } else {\n          oldLines = undefined;\n        }\n      }\n\n      if (newLines !== undefined) {\n        if (myCount.newLines === theirCount.newLines) {\n          newLines += myCount.newLines;\n        } else {\n          newLines = undefined;\n        }\n      }\n    } else {\n      if (newLines !== undefined && (line[0] === '+' || line[0] === ' ')) {\n        newLines++;\n      }\n      if (oldLines !== undefined && (line[0] === '-' || line[0] === ' ')) {\n        oldLines++;\n      }\n    }\n  });\n\n  return {oldLines, newLines};\n}\n"]} |