@angular/compiler-cli 9.0.3 → 9.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/ngcc/index.d.ts +2 -2
  2. package/ngcc/index.js +4 -3
  3. package/ngcc/main-ngcc.js +4 -3
  4. package/ngcc/src/dependencies/dependency_resolver.d.ts +7 -1
  5. package/ngcc/src/dependencies/dependency_resolver.js +20 -6
  6. package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.d.ts +3 -2
  7. package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.js +36 -21
  8. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +15 -10
  9. package/ngcc/src/execution/api.d.ts +2 -4
  10. package/ngcc/src/execution/api.js +1 -1
  11. package/ngcc/src/execution/cluster/executor.d.ts +2 -2
  12. package/ngcc/src/execution/cluster/executor.js +1 -1
  13. package/ngcc/src/execution/cluster/master.js +15 -8
  14. package/ngcc/src/execution/single_process_executor.d.ts +13 -7
  15. package/ngcc/src/execution/single_process_executor.js +55 -38
  16. package/ngcc/src/execution/utils.js +1 -1
  17. package/ngcc/src/host/commonjs_host.js +2 -7
  18. package/ngcc/src/host/delegating_host.d.ts +44 -0
  19. package/ngcc/src/host/delegating_host.js +146 -0
  20. package/ngcc/src/host/esm5_host.js +1 -7
  21. package/ngcc/src/host/umd_host.js +2 -7
  22. package/ngcc/src/locking/lock_file.d.ts +29 -0
  23. package/ngcc/src/locking/lock_file.js +17 -0
  24. package/ngcc/src/locking/lock_file_with_child_process/index.d.ts +41 -0
  25. package/ngcc/src/locking/lock_file_with_child_process/index.js +91 -0
  26. package/ngcc/src/locking/lock_file_with_child_process/unlocker.d.ts +2 -0
  27. package/ngcc/src/locking/lock_file_with_child_process/unlocker.js +44 -0
  28. package/ngcc/src/locking/lock_file_with_child_process/util.d.ts +17 -0
  29. package/ngcc/src/locking/lock_file_with_child_process/util.js +42 -0
  30. package/ngcc/src/locking/sync_locker.d.ts +36 -0
  31. package/ngcc/src/locking/sync_locker.js +67 -0
  32. package/ngcc/src/logging/console_logger.d.ts +3 -9
  33. package/ngcc/src/logging/console_logger.js +16 -15
  34. package/ngcc/src/logging/logger.d.ts +7 -0
  35. package/ngcc/src/logging/logger.js +8 -1
  36. package/ngcc/src/main.js +32 -24
  37. package/ngcc/src/packages/build_marker.d.ts +1 -1
  38. package/ngcc/src/packages/build_marker.js +1 -1
  39. package/ngcc/src/packages/configuration.d.ts +8 -0
  40. package/ngcc/src/packages/configuration.js +2 -2
  41. package/ngcc/src/packages/entry_point.d.ts +26 -2
  42. package/ngcc/src/packages/entry_point.js +34 -24
  43. package/ngcc/src/packages/transformer.js +8 -4
  44. package/ngcc/src/rendering/dts_renderer.js +2 -2
  45. package/ngcc/src/rendering/renderer.js +2 -2
  46. package/ngcc/src/rendering/source_maps.d.ts +2 -1
  47. package/ngcc/src/rendering/source_maps.js +24 -13
  48. package/ngcc/src/sourcemaps/segment_marker.d.ts +7 -15
  49. package/ngcc/src/sourcemaps/segment_marker.js +12 -41
  50. package/ngcc/src/sourcemaps/source_file.d.ts +31 -4
  51. package/ngcc/src/sourcemaps/source_file.js +130 -37
  52. package/package.json +2 -2
  53. package/src/ngtsc/annotations/src/directive.js +3 -2
  54. package/src/ngtsc/core/api/index.d.ts +11 -0
  55. package/src/ngtsc/core/api/index.js +20 -0
  56. package/src/ngtsc/core/api/src/interfaces.d.ts +65 -0
  57. package/src/ngtsc/core/api/src/interfaces.js +20 -0
  58. package/src/ngtsc/core/api/src/options.d.ts +32 -0
  59. package/src/ngtsc/core/api/src/options.js +20 -0
  60. package/src/ngtsc/core/{api.d.ts → api/src/public_options.d.ts} +14 -81
  61. package/src/ngtsc/core/api/src/public_options.js +20 -0
  62. package/src/ngtsc/diagnostics/src/error_code.d.ts +9 -0
  63. package/src/ngtsc/diagnostics/src/error_code.js +10 -1
  64. package/src/ngtsc/scope/src/local.js +50 -47
  65. package/src/ngtsc/typecheck/src/oob.d.ts +10 -0
  66. package/src/ngtsc/typecheck/src/oob.js +14 -1
  67. package/src/ngtsc/typecheck/src/type_check_block.js +11 -2
  68. package/src/version.js +1 -1
  69. package/ngcc/src/execution/lock_file.d.ts +0 -43
  70. package/ngcc/src/execution/lock_file.js +0 -129
  71. package/src/ngtsc/core/api.js +0 -20
@@ -15,6 +15,8 @@
15
15
  export interface SegmentMarker {
16
16
  readonly line: number;
17
17
  readonly column: number;
18
+ readonly position: number;
19
+ next: SegmentMarker | undefined;
18
20
  }
19
21
  /**
20
22
  * Compare two segment-markers, for use in a search or sorting algorithm.
@@ -23,22 +25,12 @@ export interface SegmentMarker {
23
25
  * and zero if they are at the same position.
24
26
  */
25
27
  export declare function compareSegments(a: SegmentMarker, b: SegmentMarker): number;
26
- /**
27
- * Compute the difference between two segment markers in a source file.
28
- *
29
- * @param lineLengths the lengths of each line of content of the source file where we are computing
30
- * the difference
31
- * @param a the start marker
32
- * @param b the end marker
33
- * @returns the number of characters between the two segments `a` and `b`
34
- */
35
- export declare function segmentDiff(lineLengths: number[], a: SegmentMarker, b: SegmentMarker): number;
36
28
  /**
37
29
  * Return a new segment-marker that is offset by the given number of characters.
38
30
  *
39
- * @param lineLengths The length of each line in the source file whose segment-marker we are
40
- * offsetting.
41
- * @param marker The segment to offset.
42
- * @param offset The number of character to offset by.
31
+ * @param startOfLinePositions the position of the start of each line of content of the source file
32
+ * whose segment-marker we are offsetting.
33
+ * @param marker the segment to offset.
34
+ * @param offset the number of character to offset by.
43
35
  */
44
- export declare function offsetSegment(lineLengths: number[], marker: SegmentMarker, offset: number): SegmentMarker;
36
+ export declare function offsetSegment(startOfLinePositions: number[], marker: SegmentMarker, offset: number): SegmentMarker;
@@ -23,61 +23,32 @@
23
23
  * and zero if they are at the same position.
24
24
  */
25
25
  function compareSegments(a, b) {
26
- return a.line === b.line ? a.column - b.column : a.line - b.line;
26
+ return a.position - b.position;
27
27
  }
28
28
  exports.compareSegments = compareSegments;
29
- // The `1` is to indicate a newline character between the lines.
30
- // Note that in the actual contents there could be more than one character that indicates a newline
31
- // - e.g. \r\n - but that is not important here since segment-markers are in line/column pairs and
32
- // so differences in length due to extra `\r` characters do not affect the algorithms.
33
- var NEWLINE_MARKER_OFFSET = 1;
34
- /**
35
- * Compute the difference between two segment markers in a source file.
36
- *
37
- * @param lineLengths the lengths of each line of content of the source file where we are computing
38
- * the difference
39
- * @param a the start marker
40
- * @param b the end marker
41
- * @returns the number of characters between the two segments `a` and `b`
42
- */
43
- function segmentDiff(lineLengths, a, b) {
44
- var diff = b.column - a.column;
45
- // Deal with `a` being before `b`
46
- for (var lineIndex = a.line; lineIndex < b.line; lineIndex++) {
47
- diff += lineLengths[lineIndex] + NEWLINE_MARKER_OFFSET;
48
- }
49
- // Deal with `a` being after `b`
50
- for (var lineIndex = a.line - 1; lineIndex >= b.line; lineIndex--) {
51
- // The `+ 1` is the newline character between the lines
52
- diff -= lineLengths[lineIndex] + NEWLINE_MARKER_OFFSET;
53
- }
54
- return diff;
55
- }
56
- exports.segmentDiff = segmentDiff;
57
29
  /**
58
30
  * Return a new segment-marker that is offset by the given number of characters.
59
31
  *
60
- * @param lineLengths The length of each line in the source file whose segment-marker we are
61
- * offsetting.
62
- * @param marker The segment to offset.
63
- * @param offset The number of character to offset by.
32
+ * @param startOfLinePositions the position of the start of each line of content of the source file
33
+ * whose segment-marker we are offsetting.
34
+ * @param marker the segment to offset.
35
+ * @param offset the number of character to offset by.
64
36
  */
65
- function offsetSegment(lineLengths, marker, offset) {
37
+ function offsetSegment(startOfLinePositions, marker, offset) {
66
38
  if (offset === 0) {
67
39
  return marker;
68
40
  }
69
41
  var line = marker.line;
70
- var column = marker.column + offset;
71
- while (line < lineLengths.length - 1 && column > lineLengths[line]) {
72
- column -= lineLengths[line] + NEWLINE_MARKER_OFFSET;
42
+ var position = marker.position + offset;
43
+ while (line < startOfLinePositions.length - 1 && startOfLinePositions[line + 1] <= position) {
73
44
  line++;
74
45
  }
75
- while (line > 0 && column < 0) {
46
+ while (line > 0 && startOfLinePositions[line] > position) {
76
47
  line--;
77
- column += lineLengths[line] + NEWLINE_MARKER_OFFSET;
78
48
  }
79
- return { line: line, column: column };
49
+ var column = position - startOfLinePositions[line];
50
+ return { line: line, column: column, position: position, next: undefined };
80
51
  }
81
52
  exports.offsetSegment = offsetSegment;
82
53
  });
83
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudF9tYXJrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvc291cmNlbWFwcy9zZWdtZW50X21hcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7OztJQWNIOzs7OztPQUtHO0lBQ0gsU0FBZ0IsZUFBZSxDQUFDLENBQWdCLEVBQUUsQ0FBZ0I7UUFDaEUsT0FBTyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ25FLENBQUM7SUFGRCwwQ0FFQztJQUVELGdFQUFnRTtJQUNoRSxtR0FBbUc7SUFDbkcsa0dBQWtHO0lBQ2xHLHNGQUFzRjtJQUN0RixJQUFNLHFCQUFxQixHQUFHLENBQUMsQ0FBQztJQUVoQzs7Ozs7Ozs7T0FRRztJQUNILFNBQWdCLFdBQVcsQ0FBQyxXQUFxQixFQUFFLENBQWdCLEVBQUUsQ0FBZ0I7UUFDbkYsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO1FBRS9CLGlDQUFpQztRQUNqQyxLQUFLLElBQUksU0FBUyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLEVBQUU7WUFDNUQsSUFBSSxJQUFJLFdBQVcsQ0FBQyxTQUFTLENBQUMsR0FBRyxxQkFBcUIsQ0FBQztTQUN4RDtRQUVELGdDQUFnQztRQUNoQyxLQUFLLElBQUksU0FBUyxHQUFHLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxFQUFFLFNBQVMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxFQUFFO1lBQ2pFLHVEQUF1RDtZQUN2RCxJQUFJLElBQUksV0FBVyxDQUFDLFNBQVMsQ0FBQyxHQUFHLHFCQUFxQixDQUFDO1NBQ3hEO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBZEQsa0NBY0M7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsU0FBZ0IsYUFBYSxDQUFDLFdBQXFCLEVBQUUsTUFBcUIsRUFBRSxNQUFjO1FBQ3hGLElBQUksTUFBTSxLQUFLLENBQUMsRUFBRTtZQUNoQixPQUFPLE1BQU0sQ0FBQztTQUNmO1FBRUQsSUFBSSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUN2QixJQUFJLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUVwQyxPQUFPLElBQUksR0FBRyxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxNQUFNLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2xFLE1BQU0sSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLEdBQUcscUJBQXFCLENBQUM7WUFDcEQsSUFBSSxFQUFFLENBQUM7U0FDUjtRQUNELE9BQU8sSUFBSSxHQUFHLENBQUMsSUFBSSxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQzdCLElBQUksRUFBRSxDQUFDO1lBQ1AsTUFBTSxJQUFJLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxxQkFBcUIsQ0FBQztTQUNyRDtRQUVELE9BQU8sRUFBQyxJQUFJLE1BQUEsRUFBRSxNQUFNLFFBQUEsRUFBQyxDQUFDO0lBQ3hCLENBQUM7SUFsQkQsc0NBa0JDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5cbi8qKlxuKiBBIG1hcmtlciB0aGF0IGluZGljYXRlcyB0aGUgc3RhcnQgb2YgYSBzZWdtZW50IGluIGEgbWFwcGluZy5cbipcbiogVGhlIGVuZCBvZiBhIHNlZ21lbnQgaXMgaW5kaWNhdGVkIGJ5IHRoZSB0aGUgZmlyc3Qgc2VnbWVudC1tYXJrZXIgb2YgYW5vdGhlciBtYXBwaW5nIHdob3NlIHN0YXJ0XG4qIGlzIGdyZWF0ZXIgb3IgZXF1YWwgdG8gdGhpcyBvbmUuXG4qL1xuZXhwb3J0IGludGVyZmFjZSBTZWdtZW50TWFya2VyIHtcbiAgcmVhZG9ubHkgbGluZTogbnVtYmVyO1xuICByZWFkb25seSBjb2x1bW46IG51bWJlcjtcbn1cblxuLyoqXG4gKiBDb21wYXJlIHR3byBzZWdtZW50LW1hcmtlcnMsIGZvciB1c2UgaW4gYSBzZWFyY2ggb3Igc29ydGluZyBhbGdvcml0aG0uXG4gKlxuICogQHJldHVybnMgYSBwb3NpdGl2ZSBudW1iZXIgaWYgYGFgIGlzIGFmdGVyIGBiYCwgYSBuZWdhdGl2ZSBudW1iZXIgaWYgYGJgIGlzIGFmdGVyIGBhYFxuICogYW5kIHplcm8gaWYgdGhleSBhcmUgYXQgdGhlIHNhbWUgcG9zaXRpb24uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb21wYXJlU2VnbWVudHMoYTogU2VnbWVudE1hcmtlciwgYjogU2VnbWVudE1hcmtlcik6IG51bWJlciB7XG4gIHJldHVybiBhLmxpbmUgPT09IGIubGluZSA/IGEuY29sdW1uIC0gYi5jb2x1bW4gOiBhLmxpbmUgLSBiLmxpbmU7XG59XG5cbi8vIFRoZSBgMWAgaXMgdG8gaW5kaWNhdGUgYSBuZXdsaW5lIGNoYXJhY3RlciBiZXR3ZWVuIHRoZSBsaW5lcy5cbi8vIE5vdGUgdGhhdCBpbiB0aGUgYWN0dWFsIGNvbnRlbnRzIHRoZXJlIGNvdWxkIGJlIG1vcmUgdGhhbiBvbmUgY2hhcmFjdGVyIHRoYXQgaW5kaWNhdGVzIGEgbmV3bGluZVxuLy8gLSBlLmcuIFxcclxcbiAtIGJ1dCB0aGF0IGlzIG5vdCBpbXBvcnRhbnQgaGVyZSBzaW5jZSBzZWdtZW50LW1hcmtlcnMgYXJlIGluIGxpbmUvY29sdW1uIHBhaXJzIGFuZFxuLy8gc28gZGlmZmVyZW5jZXMgaW4gbGVuZ3RoIGR1ZSB0byBleHRyYSBgXFxyYCBjaGFyYWN0ZXJzIGRvIG5vdCBhZmZlY3QgdGhlIGFsZ29yaXRobXMuXG5jb25zdCBORVdMSU5FX01BUktFUl9PRkZTRVQgPSAxO1xuXG4vKipcbiAqIENvbXB1dGUgdGhlIGRpZmZlcmVuY2UgYmV0d2VlbiB0d28gc2VnbWVudCBtYXJrZXJzIGluIGEgc291cmNlIGZpbGUuXG4gKlxuICogQHBhcmFtIGxpbmVMZW5ndGhzIHRoZSBsZW5ndGhzIG9mIGVhY2ggbGluZSBvZiBjb250ZW50IG9mIHRoZSBzb3VyY2UgZmlsZSB3aGVyZSB3ZSBhcmUgY29tcHV0aW5nXG4gKiB0aGUgZGlmZmVyZW5jZVxuICogQHBhcmFtIGEgdGhlIHN0YXJ0IG1hcmtlclxuICogQHBhcmFtIGIgdGhlIGVuZCBtYXJrZXJcbiAqIEByZXR1cm5zIHRoZSBudW1iZXIgb2YgY2hhcmFjdGVycyBiZXR3ZWVuIHRoZSB0d28gc2VnbWVudHMgYGFgIGFuZCBgYmBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHNlZ21lbnREaWZmKGxpbmVMZW5ndGhzOiBudW1iZXJbXSwgYTogU2VnbWVudE1hcmtlciwgYjogU2VnbWVudE1hcmtlcikge1xuICBsZXQgZGlmZiA9IGIuY29sdW1uIC0gYS5jb2x1bW47XG5cbiAgLy8gRGVhbCB3aXRoIGBhYCBiZWluZyBiZWZvcmUgYGJgXG4gIGZvciAobGV0IGxpbmVJbmRleCA9IGEubGluZTsgbGluZUluZGV4IDwgYi5saW5lOyBsaW5lSW5kZXgrKykge1xuICAgIGRpZmYgKz0gbGluZUxlbmd0aHNbbGluZUluZGV4XSArIE5FV0xJTkVfTUFSS0VSX09GRlNFVDtcbiAgfVxuXG4gIC8vIERlYWwgd2l0aCBgYWAgYmVpbmcgYWZ0ZXIgYGJgXG4gIGZvciAobGV0IGxpbmVJbmRleCA9IGEubGluZSAtIDE7IGxpbmVJbmRleCA+PSBiLmxpbmU7IGxpbmVJbmRleC0tKSB7XG4gICAgLy8gVGhlIGArIDFgIGlzIHRoZSBuZXdsaW5lIGNoYXJhY3RlciBiZXR3ZWVuIHRoZSBsaW5lc1xuICAgIGRpZmYgLT0gbGluZUxlbmd0aHNbbGluZUluZGV4XSArIE5FV0xJTkVfTUFSS0VSX09GRlNFVDtcbiAgfVxuICByZXR1cm4gZGlmZjtcbn1cblxuLyoqXG4gKiBSZXR1cm4gYSBuZXcgc2VnbWVudC1tYXJrZXIgdGhhdCBpcyBvZmZzZXQgYnkgdGhlIGdpdmVuIG51bWJlciBvZiBjaGFyYWN0ZXJzLlxuICpcbiAqIEBwYXJhbSBsaW5lTGVuZ3RocyBUaGUgbGVuZ3RoIG9mIGVhY2ggbGluZSBpbiB0aGUgc291cmNlIGZpbGUgd2hvc2Ugc2VnbWVudC1tYXJrZXIgd2UgYXJlXG4gKiBvZmZzZXR0aW5nLlxuICogQHBhcmFtIG1hcmtlciBUaGUgc2VnbWVudCB0byBvZmZzZXQuXG4gKiBAcGFyYW0gb2Zmc2V0IFRoZSBudW1iZXIgb2YgY2hhcmFjdGVyIHRvIG9mZnNldCBieS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG9mZnNldFNlZ21lbnQobGluZUxlbmd0aHM6IG51bWJlcltdLCBtYXJrZXI6IFNlZ21lbnRNYXJrZXIsIG9mZnNldDogbnVtYmVyKSB7XG4gIGlmIChvZmZzZXQgPT09IDApIHtcbiAgICByZXR1cm4gbWFya2VyO1xuICB9XG5cbiAgbGV0IGxpbmUgPSBtYXJrZXIubGluZTtcbiAgbGV0IGNvbHVtbiA9IG1hcmtlci5jb2x1bW4gKyBvZmZzZXQ7XG5cbiAgd2hpbGUgKGxpbmUgPCBsaW5lTGVuZ3Rocy5sZW5ndGggLSAxICYmIGNvbHVtbiA+IGxpbmVMZW5ndGhzW2xpbmVdKSB7XG4gICAgY29sdW1uIC09IGxpbmVMZW5ndGhzW2xpbmVdICsgTkVXTElORV9NQVJLRVJfT0ZGU0VUO1xuICAgIGxpbmUrKztcbiAgfVxuICB3aGlsZSAobGluZSA+IDAgJiYgY29sdW1uIDwgMCkge1xuICAgIGxpbmUtLTtcbiAgICBjb2x1bW4gKz0gbGluZUxlbmd0aHNbbGluZV0gKyBORVdMSU5FX01BUktFUl9PRkZTRVQ7XG4gIH1cblxuICByZXR1cm4ge2xpbmUsIGNvbHVtbn07XG59XG4iXX0=
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VnbWVudF9tYXJrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvc291cmNlbWFwcy9zZWdtZW50X21hcmtlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7OztJQWdCSDs7Ozs7T0FLRztJQUNILFNBQWdCLGVBQWUsQ0FBQyxDQUFnQixFQUFFLENBQWdCO1FBQ2hFLE9BQU8sQ0FBQyxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFGRCwwQ0FFQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxTQUFnQixhQUFhLENBQ3pCLG9CQUE4QixFQUFFLE1BQXFCLEVBQUUsTUFBYztRQUN2RSxJQUFJLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDaEIsT0FBTyxNQUFNLENBQUM7U0FDZjtRQUVELElBQUksSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDdkIsSUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUM7UUFDMUMsT0FBTyxJQUFJLEdBQUcsb0JBQW9CLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxvQkFBb0IsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksUUFBUSxFQUFFO1lBQzNGLElBQUksRUFBRSxDQUFDO1NBQ1I7UUFDRCxPQUFPLElBQUksR0FBRyxDQUFDLElBQUksb0JBQW9CLENBQUMsSUFBSSxDQUFDLEdBQUcsUUFBUSxFQUFFO1lBQ3hELElBQUksRUFBRSxDQUFDO1NBQ1I7UUFDRCxJQUFNLE1BQU0sR0FBRyxRQUFRLEdBQUcsb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckQsT0FBTyxFQUFDLElBQUksTUFBQSxFQUFFLE1BQU0sUUFBQSxFQUFFLFFBQVEsVUFBQSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUMsQ0FBQztJQUNuRCxDQUFDO0lBaEJELHNDQWdCQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuXG4vKipcbiogQSBtYXJrZXIgdGhhdCBpbmRpY2F0ZXMgdGhlIHN0YXJ0IG9mIGEgc2VnbWVudCBpbiBhIG1hcHBpbmcuXG4qXG4qIFRoZSBlbmQgb2YgYSBzZWdtZW50IGlzIGluZGljYXRlZCBieSB0aGUgdGhlIGZpcnN0IHNlZ21lbnQtbWFya2VyIG9mIGFub3RoZXIgbWFwcGluZyB3aG9zZSBzdGFydFxuKiBpcyBncmVhdGVyIG9yIGVxdWFsIHRvIHRoaXMgb25lLlxuKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2VnbWVudE1hcmtlciB7XG4gIHJlYWRvbmx5IGxpbmU6IG51bWJlcjtcbiAgcmVhZG9ubHkgY29sdW1uOiBudW1iZXI7XG4gIHJlYWRvbmx5IHBvc2l0aW9uOiBudW1iZXI7XG4gIG5leHQ6IFNlZ21lbnRNYXJrZXJ8dW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIENvbXBhcmUgdHdvIHNlZ21lbnQtbWFya2VycywgZm9yIHVzZSBpbiBhIHNlYXJjaCBvciBzb3J0aW5nIGFsZ29yaXRobS5cbiAqXG4gKiBAcmV0dXJucyBhIHBvc2l0aXZlIG51bWJlciBpZiBgYWAgaXMgYWZ0ZXIgYGJgLCBhIG5lZ2F0aXZlIG51bWJlciBpZiBgYmAgaXMgYWZ0ZXIgYGFgXG4gKiBhbmQgemVybyBpZiB0aGV5IGFyZSBhdCB0aGUgc2FtZSBwb3NpdGlvbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbXBhcmVTZWdtZW50cyhhOiBTZWdtZW50TWFya2VyLCBiOiBTZWdtZW50TWFya2VyKTogbnVtYmVyIHtcbiAgcmV0dXJuIGEucG9zaXRpb24gLSBiLnBvc2l0aW9uO1xufVxuXG4vKipcbiAqIFJldHVybiBhIG5ldyBzZWdtZW50LW1hcmtlciB0aGF0IGlzIG9mZnNldCBieSB0aGUgZ2l2ZW4gbnVtYmVyIG9mIGNoYXJhY3RlcnMuXG4gKlxuICogQHBhcmFtIHN0YXJ0T2ZMaW5lUG9zaXRpb25zIHRoZSBwb3NpdGlvbiBvZiB0aGUgc3RhcnQgb2YgZWFjaCBsaW5lIG9mIGNvbnRlbnQgb2YgdGhlIHNvdXJjZSBmaWxlXG4gKiB3aG9zZSBzZWdtZW50LW1hcmtlciB3ZSBhcmUgb2Zmc2V0dGluZy5cbiAqIEBwYXJhbSBtYXJrZXIgdGhlIHNlZ21lbnQgdG8gb2Zmc2V0LlxuICogQHBhcmFtIG9mZnNldCB0aGUgbnVtYmVyIG9mIGNoYXJhY3RlciB0byBvZmZzZXQgYnkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBvZmZzZXRTZWdtZW50KFxuICAgIHN0YXJ0T2ZMaW5lUG9zaXRpb25zOiBudW1iZXJbXSwgbWFya2VyOiBTZWdtZW50TWFya2VyLCBvZmZzZXQ6IG51bWJlcik6IFNlZ21lbnRNYXJrZXIge1xuICBpZiAob2Zmc2V0ID09PSAwKSB7XG4gICAgcmV0dXJuIG1hcmtlcjtcbiAgfVxuXG4gIGxldCBsaW5lID0gbWFya2VyLmxpbmU7XG4gIGNvbnN0IHBvc2l0aW9uID0gbWFya2VyLnBvc2l0aW9uICsgb2Zmc2V0O1xuICB3aGlsZSAobGluZSA8IHN0YXJ0T2ZMaW5lUG9zaXRpb25zLmxlbmd0aCAtIDEgJiYgc3RhcnRPZkxpbmVQb3NpdGlvbnNbbGluZSArIDFdIDw9IHBvc2l0aW9uKSB7XG4gICAgbGluZSsrO1xuICB9XG4gIHdoaWxlIChsaW5lID4gMCAmJiBzdGFydE9mTGluZVBvc2l0aW9uc1tsaW5lXSA+IHBvc2l0aW9uKSB7XG4gICAgbGluZS0tO1xuICB9XG4gIGNvbnN0IGNvbHVtbiA9IHBvc2l0aW9uIC0gc3RhcnRPZkxpbmVQb3NpdGlvbnNbbGluZV07XG4gIHJldHVybiB7bGluZSwgY29sdW1uLCBwb3NpdGlvbiwgbmV4dDogdW5kZWZpbmVkfTtcbn1cbiJdfQ==
@@ -22,7 +22,7 @@ export declare class SourceFile {
22
22
  * pure original source files).
23
23
  */
24
24
  readonly flattenedMappings: Mapping[];
25
- readonly lineLengths: number[];
25
+ readonly startOfLinePositions: number[];
26
26
  constructor(
27
27
  /** The path to this source file. */
28
28
  sourcePath: AbsoluteFsPath,
@@ -44,6 +44,18 @@ export declare class SourceFile {
44
44
  */
45
45
  private flattenMappings;
46
46
  }
47
+ /**
48
+ *
49
+ * @param mappings The collection of mappings whose segment-markers we are searching.
50
+ * @param marker The segment-marker to match against those of the given `mappings`.
51
+ * @param exclusive If exclusive then we must find a mapping with a segment-marker that is
52
+ * exclusively earlier than the given `marker`.
53
+ * If not exclusive then we can return the highest mappings with an equivalent segment-marker to the
54
+ * given `marker`.
55
+ * @param lowerIndex If provided, this is used as a hint that the marker we are searching for has an
56
+ * index that is no lower than this.
57
+ */
58
+ export declare function findLastMappingIndexBefore(mappings: Mapping[], marker: SegmentMarker, exclusive: boolean, lowerIndex: number): number;
47
59
  /**
48
60
  * A Mapping consists of two segment markers: one in the generated source and one in the original
49
61
  * source, which indicate the start of each segment. The end of a segment is indicated by the first
@@ -65,6 +77,21 @@ export declare function mergeMappings(generatedSource: SourceFile, ab: Mapping,
65
77
  * Parse the `rawMappings` into an array of parsed mappings, which reference source-files provided
66
78
  * in the `sources` parameter.
67
79
  */
68
- export declare function parseMappings(rawMap: RawSourceMap | null, sources: (SourceFile | null)[]): Mapping[];
69
- export declare function extractOriginalSegments(mappings: Mapping[]): SegmentMarker[];
70
- export declare function computeLineLengths(str: string): number[];
80
+ export declare function parseMappings(rawMap: RawSourceMap | null, sources: (SourceFile | null)[], generatedSourceStartOfLinePositions: number[]): Mapping[];
81
+ /**
82
+ * Extract the segment markers from the original source files in each mapping of an array of
83
+ * `mappings`.
84
+ *
85
+ * @param mappings The mappings whose original segments we want to extract
86
+ * @returns Return a map from original source-files (referenced in the `mappings`) to arrays of
87
+ * segment-markers sorted by their order in their source file.
88
+ */
89
+ export declare function extractOriginalSegments(mappings: Mapping[]): Map<SourceFile, SegmentMarker[]>;
90
+ /**
91
+ * Update the original segments of each of the given `mappings` to include a link to the next
92
+ * segment in the source file.
93
+ *
94
+ * @param mappings the mappings whose segments should be updated
95
+ */
96
+ export declare function ensureOriginalSegmentLinks(mappings: Mapping[]): void;
97
+ export declare function computeStartOfLinePositions(str: string): number[];
@@ -43,7 +43,7 @@
43
43
  this.inline = inline;
44
44
  this.sources = sources;
45
45
  this.contents = removeSourceMapComments(contents);
46
- this.lineLengths = computeLineLengths(this.contents);
46
+ this.startOfLinePositions = computeStartOfLinePositions(this.contents);
47
47
  this.flattenedMappings = this.flattenMappings();
48
48
  }
49
49
  /**
@@ -53,12 +53,10 @@
53
53
  var e_1, _a;
54
54
  var sources = [];
55
55
  var names = [];
56
- // Ensure a mapping line array for each line in the generated source.
57
- var mappings = this.lineLengths.map(function () { return []; });
56
+ var mappings = [];
58
57
  try {
59
58
  for (var _b = tslib_1.__values(this.flattenedMappings), _c = _b.next(); !_c.done; _c = _b.next()) {
60
59
  var mapping = _c.value;
61
- var mappingLine = mappings[mapping.generatedSegment.line];
62
60
  var sourceIndex = findIndexOrAdd(sources, mapping.originalSource);
63
61
  var mappingArray = [
64
62
  mapping.generatedSegment.column,
@@ -70,7 +68,13 @@
70
68
  var nameIndex = findIndexOrAdd(names, mapping.name);
71
69
  mappingArray.push(nameIndex);
72
70
  }
73
- mappingLine.push(mappingArray);
71
+ // Ensure a mapping line array for this mapping.
72
+ var line = mapping.generatedSegment.line;
73
+ while (line >= mappings.length) {
74
+ mappings.push([]);
75
+ }
76
+ // Add this mapping to the line
77
+ mappings[line].push(mappingArray);
74
78
  }
75
79
  }
76
80
  catch (e_1_1) { e_1 = { error: e_1_1 }; }
@@ -95,17 +99,17 @@
95
99
  * source files with no transitive source maps.
96
100
  */
97
101
  SourceFile.prototype.flattenMappings = function () {
98
- var mappings = parseMappings(this.rawMap, this.sources);
99
- var originalSegments = extractOriginalSegments(mappings);
102
+ var mappings = parseMappings(this.rawMap, this.sources, this.startOfLinePositions);
103
+ ensureOriginalSegmentLinks(mappings);
100
104
  var flattenedMappings = [];
101
- var _loop_1 = function (mappingIndex) {
105
+ for (var mappingIndex = 0; mappingIndex < mappings.length; mappingIndex++) {
102
106
  var aToBmapping = mappings[mappingIndex];
103
107
  var bSource = aToBmapping.originalSource;
104
108
  if (bSource.flattenedMappings.length === 0) {
105
109
  // The b source file has no mappings of its own (i.e. it is a pure original file)
106
110
  // so just use the mapping as-is.
107
111
  flattenedMappings.push(aToBmapping);
108
- return "continue";
112
+ continue;
109
113
  }
110
114
  // The `incomingStart` and `incomingEnd` are the `SegmentMarker`s in `B` that represent the
111
115
  // section of `B` source file that is being mapped to by the current `aToBmapping`.
@@ -126,10 +130,7 @@
126
130
  // For mapping [4,2] the incoming start and end are 2 and 5 (i.e. the range c, d, e, f)
127
131
  //
128
132
  var incomingStart = aToBmapping.originalSegment;
129
- var incomingEndIndex = originalSegments.indexOf(incomingStart) + 1;
130
- var incomingEnd = incomingEndIndex < originalSegments.length ?
131
- originalSegments[incomingEndIndex] :
132
- undefined;
133
+ var incomingEnd = incomingStart.next;
133
134
  // The `outgoingStartIndex` and `outgoingEndIndex` are the indices of the range of mappings
134
135
  // that leave `b` that we are interested in merging with the aToBmapping.
135
136
  // We actually care about all the markers from the last bToCmapping directly before the
@@ -151,35 +152,55 @@
151
152
  // The range with `incomingStart` at 2 and `incomingEnd` at 5 has outgoing start mapping of
152
153
  // [1,0] and outgoing end mapping of [4, 6], which also includes [4, 3].
153
154
  //
154
- var outgoingStartIndex = findLastIndex(bSource.flattenedMappings, function (mapping) { return segment_marker_1.compareSegments(mapping.generatedSegment, incomingStart) <= 0; });
155
+ var outgoingStartIndex = findLastMappingIndexBefore(bSource.flattenedMappings, incomingStart, false, 0);
155
156
  if (outgoingStartIndex < 0) {
156
157
  outgoingStartIndex = 0;
157
158
  }
158
159
  var outgoingEndIndex = incomingEnd !== undefined ?
159
- findLastIndex(bSource.flattenedMappings, function (mapping) { return segment_marker_1.compareSegments(mapping.generatedSegment, incomingEnd) < 0; }) :
160
+ findLastMappingIndexBefore(bSource.flattenedMappings, incomingEnd, true, outgoingStartIndex) :
160
161
  bSource.flattenedMappings.length - 1;
161
162
  for (var bToCmappingIndex = outgoingStartIndex; bToCmappingIndex <= outgoingEndIndex; bToCmappingIndex++) {
162
163
  var bToCmapping = bSource.flattenedMappings[bToCmappingIndex];
163
- flattenedMappings.push(mergeMappings(this_1, aToBmapping, bToCmapping));
164
+ flattenedMappings.push(mergeMappings(this, aToBmapping, bToCmapping));
164
165
  }
165
- };
166
- var this_1 = this;
167
- for (var mappingIndex = 0; mappingIndex < mappings.length; mappingIndex++) {
168
- _loop_1(mappingIndex);
169
166
  }
170
167
  return flattenedMappings;
171
168
  };
172
169
  return SourceFile;
173
170
  }());
174
171
  exports.SourceFile = SourceFile;
175
- function findLastIndex(items, predicate) {
176
- for (var index = items.length - 1; index >= 0; index--) {
177
- if (predicate(items[index])) {
178
- return index;
172
+ /**
173
+ *
174
+ * @param mappings The collection of mappings whose segment-markers we are searching.
175
+ * @param marker The segment-marker to match against those of the given `mappings`.
176
+ * @param exclusive If exclusive then we must find a mapping with a segment-marker that is
177
+ * exclusively earlier than the given `marker`.
178
+ * If not exclusive then we can return the highest mappings with an equivalent segment-marker to the
179
+ * given `marker`.
180
+ * @param lowerIndex If provided, this is used as a hint that the marker we are searching for has an
181
+ * index that is no lower than this.
182
+ */
183
+ function findLastMappingIndexBefore(mappings, marker, exclusive, lowerIndex) {
184
+ var upperIndex = mappings.length - 1;
185
+ var test = exclusive ? -1 : 0;
186
+ if (segment_marker_1.compareSegments(mappings[lowerIndex].generatedSegment, marker) > test) {
187
+ // Exit early since the marker is outside the allowed range of mappings.
188
+ return -1;
189
+ }
190
+ var matchingIndex = -1;
191
+ while (lowerIndex <= upperIndex) {
192
+ var index = (upperIndex + lowerIndex) >> 1;
193
+ if (segment_marker_1.compareSegments(mappings[index].generatedSegment, marker) <= test) {
194
+ matchingIndex = index;
195
+ lowerIndex = index + 1;
196
+ }
197
+ else {
198
+ upperIndex = index - 1;
179
199
  }
180
200
  }
181
- return -1;
201
+ return matchingIndex;
182
202
  }
203
+ exports.findLastMappingIndexBefore = findLastMappingIndexBefore;
183
204
  /**
184
205
  * Find the index of `item` in the `items` array.
185
206
  * If it is not found, then push `item` to the end of the array and return its new index.
@@ -240,11 +261,11 @@
240
261
  // The difference between the "original segment-marker" of A->B (1*) and the "generated
241
262
  // segment-marker" of B->C (4*): `1 - 4 = -3`.
242
263
  // Since it is negative we must increment the "generated segment-marker" with `3` to give [3,2].
243
- var diff = segment_marker_1.segmentDiff(ab.originalSource.lineLengths, ab.originalSegment, bc.generatedSegment);
264
+ var diff = segment_marker_1.compareSegments(bc.generatedSegment, ab.originalSegment);
244
265
  if (diff > 0) {
245
266
  return {
246
267
  name: name,
247
- generatedSegment: segment_marker_1.offsetSegment(generatedSource.lineLengths, ab.generatedSegment, diff),
268
+ generatedSegment: segment_marker_1.offsetSegment(generatedSource.startOfLinePositions, ab.generatedSegment, diff),
248
269
  originalSource: bc.originalSource,
249
270
  originalSegment: bc.originalSegment,
250
271
  };
@@ -254,7 +275,7 @@
254
275
  name: name,
255
276
  generatedSegment: ab.generatedSegment,
256
277
  originalSource: bc.originalSource,
257
- originalSegment: segment_marker_1.offsetSegment(bc.originalSource.lineLengths, bc.originalSegment, -diff),
278
+ originalSegment: segment_marker_1.offsetSegment(bc.originalSource.startOfLinePositions, bc.originalSegment, -diff),
258
279
  };
259
280
  }
260
281
  }
@@ -263,7 +284,7 @@
263
284
  * Parse the `rawMappings` into an array of parsed mappings, which reference source-files provided
264
285
  * in the `sources` parameter.
265
286
  */
266
- function parseMappings(rawMap, sources) {
287
+ function parseMappings(rawMap, sources, generatedSourceStartOfLinePositions) {
267
288
  var e_2, _a;
268
289
  if (rawMap === null) {
269
290
  return [];
@@ -279,14 +300,28 @@
279
300
  for (var generatedLineMappings_1 = (e_2 = void 0, tslib_1.__values(generatedLineMappings)), generatedLineMappings_1_1 = generatedLineMappings_1.next(); !generatedLineMappings_1_1.done; generatedLineMappings_1_1 = generatedLineMappings_1.next()) {
280
301
  var rawMapping = generatedLineMappings_1_1.value;
281
302
  if (rawMapping.length >= 4) {
303
+ var originalSource = sources[rawMapping[1]];
304
+ if (originalSource === null || originalSource === undefined) {
305
+ // the original source is missing so ignore this mapping
306
+ continue;
307
+ }
282
308
  var generatedColumn = rawMapping[0];
283
309
  var name = rawMapping.length === 5 ? rawMap.names[rawMapping[4]] : undefined;
284
- var mapping = {
285
- generatedSegment: { line: generatedLine, column: generatedColumn },
286
- originalSource: sources[rawMapping[1]],
287
- originalSegment: { line: rawMapping[2], column: rawMapping[3] }, name: name
310
+ var line = rawMapping[2];
311
+ var column = rawMapping[3];
312
+ var generatedSegment = {
313
+ line: generatedLine,
314
+ column: generatedColumn,
315
+ position: generatedSourceStartOfLinePositions[generatedLine] + generatedColumn,
316
+ next: undefined,
317
+ };
318
+ var originalSegment = {
319
+ line: line,
320
+ column: column,
321
+ position: originalSource.startOfLinePositions[line] + column,
322
+ next: undefined,
288
323
  };
289
- mappings.push(mapping);
324
+ mappings.push({ name: name, generatedSegment: generatedSegment, originalSegment: originalSegment, originalSource: originalSource });
290
325
  }
291
326
  }
292
327
  }
@@ -301,13 +336,71 @@
301
336
  return mappings;
302
337
  }
303
338
  exports.parseMappings = parseMappings;
339
+ /**
340
+ * Extract the segment markers from the original source files in each mapping of an array of
341
+ * `mappings`.
342
+ *
343
+ * @param mappings The mappings whose original segments we want to extract
344
+ * @returns Return a map from original source-files (referenced in the `mappings`) to arrays of
345
+ * segment-markers sorted by their order in their source file.
346
+ */
304
347
  function extractOriginalSegments(mappings) {
305
- return mappings.map(function (mapping) { return mapping.originalSegment; }).sort(segment_marker_1.compareSegments);
348
+ var e_3, _a;
349
+ var originalSegments = new Map();
350
+ try {
351
+ for (var mappings_1 = tslib_1.__values(mappings), mappings_1_1 = mappings_1.next(); !mappings_1_1.done; mappings_1_1 = mappings_1.next()) {
352
+ var mapping = mappings_1_1.value;
353
+ var originalSource = mapping.originalSource;
354
+ if (!originalSegments.has(originalSource)) {
355
+ originalSegments.set(originalSource, []);
356
+ }
357
+ var segments = originalSegments.get(originalSource);
358
+ segments.push(mapping.originalSegment);
359
+ }
360
+ }
361
+ catch (e_3_1) { e_3 = { error: e_3_1 }; }
362
+ finally {
363
+ try {
364
+ if (mappings_1_1 && !mappings_1_1.done && (_a = mappings_1.return)) _a.call(mappings_1);
365
+ }
366
+ finally { if (e_3) throw e_3.error; }
367
+ }
368
+ originalSegments.forEach(function (segmentMarkers) { return segmentMarkers.sort(segment_marker_1.compareSegments); });
369
+ return originalSegments;
306
370
  }
307
371
  exports.extractOriginalSegments = extractOriginalSegments;
372
+ /**
373
+ * Update the original segments of each of the given `mappings` to include a link to the next
374
+ * segment in the source file.
375
+ *
376
+ * @param mappings the mappings whose segments should be updated
377
+ */
378
+ function ensureOriginalSegmentLinks(mappings) {
379
+ var segmentsBySource = extractOriginalSegments(mappings);
380
+ segmentsBySource.forEach(function (markers) {
381
+ for (var i = 0; i < markers.length - 1; i++) {
382
+ markers[i].next = markers[i + 1];
383
+ }
384
+ });
385
+ }
386
+ exports.ensureOriginalSegmentLinks = ensureOriginalSegmentLinks;
387
+ function computeStartOfLinePositions(str) {
388
+ // The `1` is to indicate a newline character between the lines.
389
+ // Note that in the actual contents there could be more than one character that indicates a
390
+ // newline
391
+ // - e.g. \r\n - but that is not important here since segment-markers are in line/column pairs and
392
+ // so differences in length due to extra `\r` characters do not affect the algorithms.
393
+ var NEWLINE_MARKER_OFFSET = 1;
394
+ var lineLengths = computeLineLengths(str);
395
+ var startPositions = [0]; // First line starts at position 0
396
+ for (var i = 0; i < lineLengths.length - 1; i++) {
397
+ startPositions.push(startPositions[i] + lineLengths[i] + NEWLINE_MARKER_OFFSET);
398
+ }
399
+ return startPositions;
400
+ }
401
+ exports.computeStartOfLinePositions = computeStartOfLinePositions;
308
402
  function computeLineLengths(str) {
309
403
  return (str.split(/\r?\n/)).map(function (s) { return s.length; });
310
404
  }
311
- exports.computeLineLengths = computeLineLengths;
312
405
  });
313
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/sourcemaps/source_file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {removeComments, removeMapFileComments} from 'convert-source-map';\nimport {SourceMapMappings, SourceMapSegment, decode, encode} from 'sourcemap-codec';\nimport {AbsoluteFsPath, dirname, relative} from '../../../src/ngtsc/file_system';\nimport {RawSourceMap} from './raw_source_map';\nimport {SegmentMarker, compareSegments, offsetSegment, segmentDiff} from './segment_marker';\n\nexport function removeSourceMapComments(contents: string): string {\n  return removeMapFileComments(removeComments(contents)).replace(/\\n\\n$/, '\\n');\n}\n\nexport class SourceFile {\n  /**\n   * The parsed mappings that have been flattened so that any intermediate source mappings have been\n   * flattened.\n   *\n   * The result is that any source file mentioned in the flattened mappings have no source map (are\n   * pure original source files).\n   */\n  readonly flattenedMappings: Mapping[];\n  readonly lineLengths: number[];\n\n  constructor(\n      /** The path to this source file. */\n      readonly sourcePath: AbsoluteFsPath,\n      /** The contents of this source file. */\n      readonly contents: string,\n      /** The raw source map (if any) associated with this source file. */\n      readonly rawMap: RawSourceMap|null,\n      /** Whether this source file's source map was inline or external. */\n      readonly inline: boolean,\n      /** Any source files referenced by the raw source map associated with this source file. */\n      readonly sources: (SourceFile|null)[]) {\n    this.contents = removeSourceMapComments(contents);\n    this.lineLengths = computeLineLengths(this.contents);\n    this.flattenedMappings = this.flattenMappings();\n  }\n\n  /**\n   * Render the raw source map generated from the flattened mappings.\n   */\n  renderFlattenedSourceMap(): RawSourceMap {\n    const sources: SourceFile[] = [];\n    const names: string[] = [];\n\n    // Ensure a mapping line array for each line in the generated source.\n    const mappings: SourceMapMappings = this.lineLengths.map(() => []);\n\n    for (const mapping of this.flattenedMappings) {\n      const mappingLine = mappings[mapping.generatedSegment.line];\n      const sourceIndex = findIndexOrAdd(sources, mapping.originalSource);\n      const mappingArray: SourceMapSegment = [\n        mapping.generatedSegment.column,\n        sourceIndex,\n        mapping.originalSegment.line,\n        mapping.originalSegment.column,\n      ];\n      if (mapping.name !== undefined) {\n        const nameIndex = findIndexOrAdd(names, mapping.name);\n        mappingArray.push(nameIndex);\n      }\n      mappingLine.push(mappingArray);\n    }\n\n    const sourcePathDir = dirname(this.sourcePath);\n    const sourceMap: RawSourceMap = {\n      version: 3,\n      file: relative(sourcePathDir, this.sourcePath),\n      sources: sources.map(sf => relative(sourcePathDir, sf.sourcePath)), names,\n      mappings: encode(mappings),\n      sourcesContent: sources.map(sf => sf.contents),\n    };\n    return sourceMap;\n  }\n\n  /**\n   * Flatten the parsed mappings for this source file, so that all the mappings are to pure original\n   * source files with no transitive source maps.\n   */\n  private flattenMappings(): Mapping[] {\n    const mappings = parseMappings(this.rawMap, this.sources);\n    const originalSegments = extractOriginalSegments(mappings);\n    const flattenedMappings: Mapping[] = [];\n    for (let mappingIndex = 0; mappingIndex < mappings.length; mappingIndex++) {\n      const aToBmapping = mappings[mappingIndex];\n      const bSource = aToBmapping.originalSource;\n      if (bSource.flattenedMappings.length === 0) {\n        // The b source file has no mappings of its own (i.e. it is a pure original file)\n        // so just use the mapping as-is.\n        flattenedMappings.push(aToBmapping);\n        continue;\n      }\n\n      // The `incomingStart` and `incomingEnd` are the `SegmentMarker`s in `B` that represent the\n      // section of `B` source file that is being mapped to by the current `aToBmapping`.\n      //\n      // For example, consider the mappings from A to B:\n      //\n      // src A   src B     mapping\n      //\n      //   a ----- a       [0, 0]\n      //   b       b\n      //   f -  /- c       [4, 2]\n      //   g  \\ /  d\n      //   c -/\\   e\n      //   d    \\- f       [2, 5]\n      //   e\n      //\n      // For mapping [0,0] the incoming start and end are 0 and 2 (i.e. the range a, b, c)\n      // For mapping [4,2] the incoming start and end are 2 and 5 (i.e. the range c, d, e, f)\n      //\n      const incomingStart = aToBmapping.originalSegment;\n      const incomingEndIndex = originalSegments.indexOf(incomingStart) + 1;\n      const incomingEnd = incomingEndIndex < originalSegments.length ?\n          originalSegments[incomingEndIndex] :\n          undefined;\n\n      // The `outgoingStartIndex` and `outgoingEndIndex` are the indices of the range of mappings\n      // that leave `b` that we are interested in merging with the aToBmapping.\n      // We actually care about all the markers from the last bToCmapping directly before the\n      // `incomingStart` to the last bToCmaping directly before the `incomingEnd`, inclusive.\n      //\n      // For example, if we consider the range 2 to 5 from above (i.e. c, d, e, f) with the\n      // following mappings from B to C:\n      //\n      //   src B   src C     mapping\n      //     a\n      //     b ----- b       [1, 0]\n      //   - c       c\n      //  |  d       d\n      //  |  e ----- 1       [4, 3]\n      //   - f  \\    2\n      //         \\   3\n      //          \\- e       [4, 6]\n      //\n      // The range with `incomingStart` at 2 and `incomingEnd` at 5 has outgoing start mapping of\n      // [1,0] and outgoing end mapping of [4, 6], which also includes [4, 3].\n      //\n      let outgoingStartIndex = findLastIndex(\n          bSource.flattenedMappings,\n          mapping => compareSegments(mapping.generatedSegment, incomingStart) <= 0);\n      if (outgoingStartIndex < 0) {\n        outgoingStartIndex = 0;\n      }\n      const outgoingEndIndex = incomingEnd !== undefined ?\n          findLastIndex(\n              bSource.flattenedMappings,\n              mapping => compareSegments(mapping.generatedSegment, incomingEnd) < 0) :\n          bSource.flattenedMappings.length - 1;\n\n      for (let bToCmappingIndex = outgoingStartIndex; bToCmappingIndex <= outgoingEndIndex;\n           bToCmappingIndex++) {\n        const bToCmapping: Mapping = bSource.flattenedMappings[bToCmappingIndex];\n        flattenedMappings.push(mergeMappings(this, aToBmapping, bToCmapping));\n      }\n    }\n    return flattenedMappings;\n  }\n}\n\nfunction findLastIndex<T>(items: T[], predicate: (item: T) => boolean): number {\n  for (let index = items.length - 1; index >= 0; index--) {\n    if (predicate(items[index])) {\n      return index;\n    }\n  }\n  return -1;\n}\n\n/**\n * A Mapping consists of two segment markers: one in the generated source and one in the original\n * source, which indicate the start of each segment. The end of a segment is indicated by the first\n * segment marker of another mapping whose start is greater or equal to this one.\n *\n * It may also include a name associated with the segment being mapped.\n */\nexport interface Mapping {\n  readonly generatedSegment: SegmentMarker;\n  readonly originalSource: SourceFile;\n  readonly originalSegment: SegmentMarker;\n  readonly name?: string;\n}\n\n/**\n * Find the index of `item` in the `items` array.\n * If it is not found, then push `item` to the end of the array and return its new index.\n *\n * @param items the collection in which to look for `item`.\n * @param item the item to look for.\n * @returns the index of the `item` in the `items` array.\n */\nfunction findIndexOrAdd<T>(items: T[], item: T): number {\n  const itemIndex = items.indexOf(item);\n  if (itemIndex > -1) {\n    return itemIndex;\n  } else {\n    items.push(item);\n    return items.length - 1;\n  }\n}\n\n\n/**\n * Merge two mappings that go from A to B and B to C, to result in a mapping that goes from A to C.\n */\nexport function mergeMappings(generatedSource: SourceFile, ab: Mapping, bc: Mapping): Mapping {\n  const name = bc.name || ab.name;\n\n  // We need to modify the segment-markers of the new mapping to take into account the shifts that\n  // occur due to the combination of the two mappings.\n  // For example:\n\n  // * Simple map where the B->C starts at the same place the A->B ends:\n  //\n  // ```\n  // A: 1 2 b c d\n  //        |        A->B [2,0]\n  //        |              |\n  // B:     b c d    A->C [2,1]\n  //        |                |\n  //        |        B->C [0,1]\n  // C:   a b c d e\n  // ```\n\n  // * More complicated case where diffs of segment-markers is needed:\n  //\n  // ```\n  // A: b 1 2 c d\n  //     \\\n  //      |            A->B  [0,1*]    [0,1*]\n  //      |                   |         |+3\n  // B: a b 1 2 c d    A->C  [0,1]     [3,2]\n  //    |      /                |+1       |\n  //    |     /        B->C [0*,0]    [4*,2]\n  //    |    /\n  // C: a b c d e\n  // ```\n  //\n  // `[0,1]` mapping from A->C:\n  // The difference between the \"original segment-marker\" of A->B (1*) and the \"generated\n  // segment-marker of B->C (0*): `1 - 0 = +1`.\n  // Since it is positive we must increment the \"original segment-marker\" with `1` to give [0,1].\n  //\n  // `[3,2]` mapping from A->C:\n  // The difference between the \"original segment-marker\" of A->B (1*) and the \"generated\n  // segment-marker\" of B->C (4*): `1 - 4 = -3`.\n  // Since it is negative we must increment the \"generated segment-marker\" with `3` to give [3,2].\n\n  const diff = segmentDiff(ab.originalSource.lineLengths, ab.originalSegment, bc.generatedSegment);\n  if (diff > 0) {\n    return {\n      name,\n      generatedSegment: offsetSegment(generatedSource.lineLengths, ab.generatedSegment, diff),\n      originalSource: bc.originalSource,\n      originalSegment: bc.originalSegment,\n    };\n  } else {\n    return {\n      name,\n      generatedSegment: ab.generatedSegment,\n      originalSource: bc.originalSource,\n      originalSegment: offsetSegment(bc.originalSource.lineLengths, bc.originalSegment, -diff),\n    };\n  }\n}\n\n/**\n * Parse the `rawMappings` into an array of parsed mappings, which reference source-files provided\n * in the `sources` parameter.\n */\nexport function parseMappings(\n    rawMap: RawSourceMap | null, sources: (SourceFile | null)[]): Mapping[] {\n  if (rawMap === null) {\n    return [];\n  }\n\n  const rawMappings = decode(rawMap.mappings);\n  if (rawMappings === null) {\n    return [];\n  }\n\n  const mappings: Mapping[] = [];\n  for (let generatedLine = 0; generatedLine < rawMappings.length; generatedLine++) {\n    const generatedLineMappings = rawMappings[generatedLine];\n    for (const rawMapping of generatedLineMappings) {\n      if (rawMapping.length >= 4) {\n        const generatedColumn = rawMapping[0];\n        const name = rawMapping.length === 5 ? rawMap.names[rawMapping[4]] : undefined;\n        const mapping: Mapping = {\n          generatedSegment: {line: generatedLine, column: generatedColumn},\n          originalSource: sources[rawMapping[1] !] !,\n          originalSegment: {line: rawMapping[2] !, column: rawMapping[3] !}, name\n        };\n        mappings.push(mapping);\n      }\n    }\n  }\n  return mappings;\n}\n\nexport function extractOriginalSegments(mappings: Mapping[]): SegmentMarker[] {\n  return mappings.map(mapping => mapping.originalSegment).sort(compareSegments);\n}\n\nexport function computeLineLengths(str: string): number[] {\n  return (str.split(/\\r?\\n/)).map(s => s.length);\n}\n"]}
406
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/sourcemaps/source_file.ts"],"names":[],"mappings":";;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,yDAAyE;IACzE,mDAAoF;IACpF,2EAAiF;IAEjF,2FAA+E;IAE/E,SAAgB,uBAAuB,CAAC,QAAgB;QACtD,OAAO,0CAAqB,CAAC,mCAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAChF,CAAC;IAFD,0DAEC;IAED;QAWE;QACI,oCAAoC;QAC3B,UAA0B;QACnC,wCAAwC;QAC/B,QAAgB;QACzB,oEAAoE;QAC3D,MAAyB;QAClC,oEAAoE;QAC3D,MAAe;QACxB,0FAA0F;QACjF,OAA4B;YAR5B,eAAU,GAAV,UAAU,CAAgB;YAE1B,aAAQ,GAAR,QAAQ,CAAQ;YAEhB,WAAM,GAAN,MAAM,CAAmB;YAEzB,WAAM,GAAN,MAAM,CAAS;YAEf,YAAO,GAAP,OAAO,CAAqB;YACvC,IAAI,CAAC,QAAQ,GAAG,uBAAuB,CAAC,QAAQ,CAAC,CAAC;YAClD,IAAI,CAAC,oBAAoB,GAAG,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACvE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAClD,CAAC;QAED;;WAEG;QACH,6CAAwB,GAAxB;;YACE,IAAM,OAAO,GAAiB,EAAE,CAAC;YACjC,IAAM,KAAK,GAAa,EAAE,CAAC;YAE3B,IAAM,QAAQ,GAAsB,EAAE,CAAC;;gBAEvC,KAAsB,IAAA,KAAA,iBAAA,IAAI,CAAC,iBAAiB,CAAA,gBAAA,4BAAE;oBAAzC,IAAM,OAAO,WAAA;oBAChB,IAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;oBACpE,IAAM,YAAY,GAAqB;wBACrC,OAAO,CAAC,gBAAgB,CAAC,MAAM;wBAC/B,WAAW;wBACX,OAAO,CAAC,eAAe,CAAC,IAAI;wBAC5B,OAAO,CAAC,eAAe,CAAC,MAAM;qBAC/B,CAAC;oBACF,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE;wBAC9B,IAAM,SAAS,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;wBACtD,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;qBAC9B;oBAED,gDAAgD;oBAChD,IAAM,IAAI,GAAG,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC;oBAC3C,OAAO,IAAI,IAAI,QAAQ,CAAC,MAAM,EAAE;wBAC9B,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;qBACnB;oBACD,+BAA+B;oBAC/B,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBACnC;;;;;;;;;YAED,IAAM,aAAa,GAAG,qBAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/C,IAAM,SAAS,GAAiB;gBAC9B,OAAO,EAAE,CAAC;gBACV,IAAI,EAAE,sBAAQ,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC;gBAC9C,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,UAAA,EAAE,IAAI,OAAA,sBAAQ,CAAC,aAAa,EAAE,EAAE,CAAC,UAAU,CAAC,EAAtC,CAAsC,CAAC,EAAE,KAAK,OAAA;gBACzE,QAAQ,EAAE,wBAAM,CAAC,QAAQ,CAAC;gBAC1B,cAAc,EAAE,OAAO,CAAC,GAAG,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,CAAC,QAAQ,EAAX,CAAW,CAAC;aAC/C,CAAC;YACF,OAAO,SAAS,CAAC;QACnB,CAAC;QAED;;;WAGG;QACK,oCAAe,GAAvB;YACE,IAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;YACrF,0BAA0B,CAAC,QAAQ,CAAC,CAAC;YACrC,IAAM,iBAAiB,GAAc,EAAE,CAAC;YACxC,KAAK,IAAI,YAAY,GAAG,CAAC,EAAE,YAAY,GAAG,QAAQ,CAAC,MAAM,EAAE,YAAY,EAAE,EAAE;gBACzE,IAAM,WAAW,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;gBAC3C,IAAM,OAAO,GAAG,WAAW,CAAC,cAAc,CAAC;gBAC3C,IAAI,OAAO,CAAC,iBAAiB,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC1C,iFAAiF;oBACjF,iCAAiC;oBACjC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBACpC,SAAS;iBACV;gBAED,2FAA2F;gBAC3F,mFAAmF;gBACnF,EAAE;gBACF,kDAAkD;gBAClD,EAAE;gBACF,4BAA4B;gBAC5B,EAAE;gBACF,2BAA2B;gBAC3B,cAAc;gBACd,2BAA2B;gBAC3B,cAAc;gBACd,cAAc;gBACd,2BAA2B;gBAC3B,MAAM;gBACN,EAAE;gBACF,oFAAoF;gBACpF,uFAAuF;gBACvF,EAAE;gBACF,IAAM,aAAa,GAAG,WAAW,CAAC,eAAe,CAAC;gBAClD,IAAM,WAAW,GAAG,aAAa,CAAC,IAAI,CAAC;gBAEvC,2FAA2F;gBAC3F,yEAAyE;gBACzE,uFAAuF;gBACvF,uFAAuF;gBACvF,EAAE;gBACF,qFAAqF;gBACrF,kCAAkC;gBAClC,EAAE;gBACF,8BAA8B;gBAC9B,QAAQ;gBACR,6BAA6B;gBAC7B,gBAAgB;gBAChB,gBAAgB;gBAChB,6BAA6B;gBAC7B,gBAAgB;gBAChB,gBAAgB;gBAChB,6BAA6B;gBAC7B,EAAE;gBACF,2FAA2F;gBAC3F,wEAAwE;gBACxE,EAAE;gBACF,IAAI,kBAAkB,GAClB,0BAA0B,CAAC,OAAO,CAAC,iBAAiB,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;gBACnF,IAAI,kBAAkB,GAAG,CAAC,EAAE;oBAC1B,kBAAkB,GAAG,CAAC,CAAC;iBACxB;gBACD,IAAM,gBAAgB,GAAG,WAAW,KAAK,SAAS,CAAC,CAAC;oBAChD,0BAA0B,CACtB,OAAO,CAAC,iBAAiB,EAAE,WAAW,EAAE,IAAI,EAAE,kBAAkB,CAAC,CAAC,CAAC;oBACvE,OAAO,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC;gBAEzC,KAAK,IAAI,gBAAgB,GAAG,kBAAkB,EAAE,gBAAgB,IAAI,gBAAgB,EAC/E,gBAAgB,EAAE,EAAE;oBACvB,IAAM,WAAW,GAAY,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;oBACzE,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC;iBACvE;aACF;YACD,OAAO,iBAAiB,CAAC;QAC3B,CAAC;QACH,iBAAC;IAAD,CAAC,AAnJD,IAmJC;IAnJY,gCAAU;IAqJvB;;;;;;;;;;OAUG;IACH,SAAgB,0BAA0B,CACtC,QAAmB,EAAE,MAAqB,EAAE,SAAkB,EAAE,UAAkB;QACpF,IAAI,UAAU,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;QACrC,IAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhC,IAAI,gCAAe,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,gBAAgB,EAAE,MAAM,CAAC,GAAG,IAAI,EAAE;YACzE,wEAAwE;YACxE,OAAO,CAAC,CAAC,CAAC;SACX;QAED,IAAI,aAAa,GAAG,CAAC,CAAC,CAAC;QACvB,OAAO,UAAU,IAAI,UAAU,EAAE;YAC/B,IAAM,KAAK,GAAG,CAAC,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;YAC7C,IAAI,gCAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,gBAAgB,EAAE,MAAM,CAAC,IAAI,IAAI,EAAE;gBACrE,aAAa,GAAG,KAAK,CAAC;gBACtB,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;aACxB;iBAAM;gBACL,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;aACxB;SACF;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IArBD,gEAqBC;IAgBD;;;;;;;OAOG;IACH,SAAS,cAAc,CAAI,KAAU,EAAE,IAAO;QAC5C,IAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,SAAS,GAAG,CAAC,CAAC,EAAE;YAClB,OAAO,SAAS,CAAC;SAClB;aAAM;YACL,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACjB,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;SACzB;IACH,CAAC;IAGD;;OAEG;IACH,SAAgB,aAAa,CAAC,eAA2B,EAAE,EAAW,EAAE,EAAW;QACjF,IAAM,IAAI,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI,CAAC;QAEhC,gGAAgG;QAChG,oDAAoD;QACpD,eAAe;QAEf,sEAAsE;QACtE,EAAE;QACF,MAAM;QACN,eAAe;QACf,6BAA6B;QAC7B,0BAA0B;QAC1B,6BAA6B;QAC7B,4BAA4B;QAC5B,6BAA6B;QAC7B,iBAAiB;QACjB,MAAM;QAEN,oEAAoE;QACpE,EAAE;QACF,MAAM;QACN,eAAe;QACf,QAAQ;QACR,2CAA2C;QAC3C,yCAAyC;QACzC,0CAA0C;QAC1C,yCAAyC;QACzC,0CAA0C;QAC1C,YAAY;QACZ,eAAe;QACf,MAAM;QACN,EAAE;QACF,6BAA6B;QAC7B,uFAAuF;QACvF,6CAA6C;QAC7C,+FAA+F;QAC/F,EAAE;QACF,6BAA6B;QAC7B,uFAAuF;QACvF,8CAA8C;QAC9C,gGAAgG;QAEhG,IAAM,IAAI,GAAG,gCAAe,CAAC,EAAE,CAAC,gBAAgB,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC;QACtE,IAAI,IAAI,GAAG,CAAC,EAAE;YACZ,OAAO;gBACL,IAAI,MAAA;gBACJ,gBAAgB,EACZ,8BAAa,CAAC,eAAe,CAAC,oBAAoB,EAAE,EAAE,CAAC,gBAAgB,EAAE,IAAI,CAAC;gBAClF,cAAc,EAAE,EAAE,CAAC,cAAc;gBACjC,eAAe,EAAE,EAAE,CAAC,eAAe;aACpC,CAAC;SACH;aAAM;YACL,OAAO;gBACL,IAAI,MAAA;gBACJ,gBAAgB,EAAE,EAAE,CAAC,gBAAgB;gBACrC,cAAc,EAAE,EAAE,CAAC,cAAc;gBACjC,eAAe,EACX,8BAAa,CAAC,EAAE,CAAC,cAAc,CAAC,oBAAoB,EAAE,EAAE,CAAC,eAAe,EAAE,CAAC,IAAI,CAAC;aACrF,CAAC;SACH;IACH,CAAC;IA7DD,sCA6DC;IAED;;;OAGG;IACH,SAAgB,aAAa,CACzB,MAA2B,EAAE,OAA8B,EAC3D,mCAA6C;;QAC/C,IAAI,MAAM,KAAK,IAAI,EAAE;YACnB,OAAO,EAAE,CAAC;SACX;QAED,IAAM,WAAW,GAAG,wBAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5C,IAAI,WAAW,KAAK,IAAI,EAAE;YACxB,OAAO,EAAE,CAAC;SACX;QAED,IAAM,QAAQ,GAAc,EAAE,CAAC;QAC/B,KAAK,IAAI,aAAa,GAAG,CAAC,EAAE,aAAa,GAAG,WAAW,CAAC,MAAM,EAAE,aAAa,EAAE,EAAE;YAC/E,IAAM,qBAAqB,GAAG,WAAW,CAAC,aAAa,CAAC,CAAC;;gBACzD,KAAyB,IAAA,yCAAA,iBAAA,qBAAqB,CAAA,CAAA,4DAAA,+FAAE;oBAA3C,IAAM,UAAU,kCAAA;oBACnB,IAAI,UAAU,CAAC,MAAM,IAAI,CAAC,EAAE;wBAC1B,IAAM,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAG,CAAC,CAAC;wBAChD,IAAI,cAAc,KAAK,IAAI,IAAI,cAAc,KAAK,SAAS,EAAE;4BAC3D,wDAAwD;4BACxD,SAAS;yBACV;wBACD,IAAM,eAAe,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;wBACtC,IAAM,IAAI,GAAG,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;wBAC/E,IAAM,IAAI,GAAG,UAAU,CAAC,CAAC,CAAG,CAAC;wBAC7B,IAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAG,CAAC;wBAC/B,IAAM,gBAAgB,GAAkB;4BACtC,IAAI,EAAE,aAAa;4BACnB,MAAM,EAAE,eAAe;4BACvB,QAAQ,EAAE,mCAAmC,CAAC,aAAa,CAAC,GAAG,eAAe;4BAC9E,IAAI,EAAE,SAAS;yBAChB,CAAC;wBACF,IAAM,eAAe,GAAkB;4BACrC,IAAI,MAAA;4BACJ,MAAM,QAAA;4BACN,QAAQ,EAAE,cAAc,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,MAAM;4BAC5D,IAAI,EAAE,SAAS;yBAChB,CAAC;wBACF,QAAQ,CAAC,IAAI,CAAC,EAAC,IAAI,MAAA,EAAE,gBAAgB,kBAAA,EAAE,eAAe,iBAAA,EAAE,cAAc,gBAAA,EAAC,CAAC,CAAC;qBAC1E;iBACF;;;;;;;;;SACF;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IA3CD,sCA2CC;IAED;;;;;;;OAOG;IACH,SAAgB,uBAAuB,CAAC,QAAmB;;QACzD,IAAM,gBAAgB,GAAG,IAAI,GAAG,EAA+B,CAAC;;YAChE,KAAsB,IAAA,aAAA,iBAAA,QAAQ,CAAA,kCAAA,wDAAE;gBAA3B,IAAM,OAAO,qBAAA;gBAChB,IAAM,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;gBAC9C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE;oBACzC,gBAAgB,CAAC,GAAG,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;iBAC1C;gBACD,IAAM,QAAQ,GAAG,gBAAgB,CAAC,GAAG,CAAC,cAAc,CAAG,CAAC;gBACxD,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;aACxC;;;;;;;;;QACD,gBAAgB,CAAC,OAAO,CAAC,UAAA,cAAc,IAAI,OAAA,cAAc,CAAC,IAAI,CAAC,gCAAe,CAAC,EAApC,CAAoC,CAAC,CAAC;QACjF,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAZD,0DAYC;IAED;;;;;OAKG;IACH,SAAgB,0BAA0B,CAAC,QAAmB;QAC5D,IAAM,gBAAgB,GAAG,uBAAuB,CAAC,QAAQ,CAAC,CAAC;QAC3D,gBAAgB,CAAC,OAAO,CAAC,UAAA,OAAO;YAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC3C,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aAClC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAPD,gEAOC;IAED,SAAgB,2BAA2B,CAAC,GAAW;QACrD,gEAAgE;QAChE,2FAA2F;QAC3F,UAAU;QACV,kGAAkG;QAClG,sFAAsF;QACtF,IAAM,qBAAqB,GAAG,CAAC,CAAC;QAChC,IAAM,WAAW,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAM,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,CAAE,kCAAkC;QAC/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC/C,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC;SACjF;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAbD,kEAaC;IAED,SAAS,kBAAkB,CAAC,GAAW;QACrC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,MAAM,EAAR,CAAQ,CAAC,CAAC;IACjD,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {removeComments, removeMapFileComments} from 'convert-source-map';\nimport {SourceMapMappings, SourceMapSegment, decode, encode} from 'sourcemap-codec';\nimport {AbsoluteFsPath, dirname, relative} from '../../../src/ngtsc/file_system';\nimport {RawSourceMap} from './raw_source_map';\nimport {SegmentMarker, compareSegments, offsetSegment} from './segment_marker';\n\nexport function removeSourceMapComments(contents: string): string {\n  return removeMapFileComments(removeComments(contents)).replace(/\\n\\n$/, '\\n');\n}\n\nexport class SourceFile {\n  /**\n   * The parsed mappings that have been flattened so that any intermediate source mappings have been\n   * flattened.\n   *\n   * The result is that any source file mentioned in the flattened mappings have no source map (are\n   * pure original source files).\n   */\n  readonly flattenedMappings: Mapping[];\n  readonly startOfLinePositions: number[];\n\n  constructor(\n      /** The path to this source file. */\n      readonly sourcePath: AbsoluteFsPath,\n      /** The contents of this source file. */\n      readonly contents: string,\n      /** The raw source map (if any) associated with this source file. */\n      readonly rawMap: RawSourceMap|null,\n      /** Whether this source file's source map was inline or external. */\n      readonly inline: boolean,\n      /** Any source files referenced by the raw source map associated with this source file. */\n      readonly sources: (SourceFile|null)[]) {\n    this.contents = removeSourceMapComments(contents);\n    this.startOfLinePositions = computeStartOfLinePositions(this.contents);\n    this.flattenedMappings = this.flattenMappings();\n  }\n\n  /**\n   * Render the raw source map generated from the flattened mappings.\n   */\n  renderFlattenedSourceMap(): RawSourceMap {\n    const sources: SourceFile[] = [];\n    const names: string[] = [];\n\n    const mappings: SourceMapMappings = [];\n\n    for (const mapping of this.flattenedMappings) {\n      const sourceIndex = findIndexOrAdd(sources, mapping.originalSource);\n      const mappingArray: SourceMapSegment = [\n        mapping.generatedSegment.column,\n        sourceIndex,\n        mapping.originalSegment.line,\n        mapping.originalSegment.column,\n      ];\n      if (mapping.name !== undefined) {\n        const nameIndex = findIndexOrAdd(names, mapping.name);\n        mappingArray.push(nameIndex);\n      }\n\n      // Ensure a mapping line array for this mapping.\n      const line = mapping.generatedSegment.line;\n      while (line >= mappings.length) {\n        mappings.push([]);\n      }\n      // Add this mapping to the line\n      mappings[line].push(mappingArray);\n    }\n\n    const sourcePathDir = dirname(this.sourcePath);\n    const sourceMap: RawSourceMap = {\n      version: 3,\n      file: relative(sourcePathDir, this.sourcePath),\n      sources: sources.map(sf => relative(sourcePathDir, sf.sourcePath)), names,\n      mappings: encode(mappings),\n      sourcesContent: sources.map(sf => sf.contents),\n    };\n    return sourceMap;\n  }\n\n  /**\n   * Flatten the parsed mappings for this source file, so that all the mappings are to pure original\n   * source files with no transitive source maps.\n   */\n  private flattenMappings(): Mapping[] {\n    const mappings = parseMappings(this.rawMap, this.sources, this.startOfLinePositions);\n    ensureOriginalSegmentLinks(mappings);\n    const flattenedMappings: Mapping[] = [];\n    for (let mappingIndex = 0; mappingIndex < mappings.length; mappingIndex++) {\n      const aToBmapping = mappings[mappingIndex];\n      const bSource = aToBmapping.originalSource;\n      if (bSource.flattenedMappings.length === 0) {\n        // The b source file has no mappings of its own (i.e. it is a pure original file)\n        // so just use the mapping as-is.\n        flattenedMappings.push(aToBmapping);\n        continue;\n      }\n\n      // The `incomingStart` and `incomingEnd` are the `SegmentMarker`s in `B` that represent the\n      // section of `B` source file that is being mapped to by the current `aToBmapping`.\n      //\n      // For example, consider the mappings from A to B:\n      //\n      // src A   src B     mapping\n      //\n      //   a ----- a       [0, 0]\n      //   b       b\n      //   f -  /- c       [4, 2]\n      //   g  \\ /  d\n      //   c -/\\   e\n      //   d    \\- f       [2, 5]\n      //   e\n      //\n      // For mapping [0,0] the incoming start and end are 0 and 2 (i.e. the range a, b, c)\n      // For mapping [4,2] the incoming start and end are 2 and 5 (i.e. the range c, d, e, f)\n      //\n      const incomingStart = aToBmapping.originalSegment;\n      const incomingEnd = incomingStart.next;\n\n      // The `outgoingStartIndex` and `outgoingEndIndex` are the indices of the range of mappings\n      // that leave `b` that we are interested in merging with the aToBmapping.\n      // We actually care about all the markers from the last bToCmapping directly before the\n      // `incomingStart` to the last bToCmaping directly before the `incomingEnd`, inclusive.\n      //\n      // For example, if we consider the range 2 to 5 from above (i.e. c, d, e, f) with the\n      // following mappings from B to C:\n      //\n      //   src B   src C     mapping\n      //     a\n      //     b ----- b       [1, 0]\n      //   - c       c\n      //  |  d       d\n      //  |  e ----- 1       [4, 3]\n      //   - f  \\    2\n      //         \\   3\n      //          \\- e       [4, 6]\n      //\n      // The range with `incomingStart` at 2 and `incomingEnd` at 5 has outgoing start mapping of\n      // [1,0] and outgoing end mapping of [4, 6], which also includes [4, 3].\n      //\n      let outgoingStartIndex =\n          findLastMappingIndexBefore(bSource.flattenedMappings, incomingStart, false, 0);\n      if (outgoingStartIndex < 0) {\n        outgoingStartIndex = 0;\n      }\n      const outgoingEndIndex = incomingEnd !== undefined ?\n          findLastMappingIndexBefore(\n              bSource.flattenedMappings, incomingEnd, true, outgoingStartIndex) :\n          bSource.flattenedMappings.length - 1;\n\n      for (let bToCmappingIndex = outgoingStartIndex; bToCmappingIndex <= outgoingEndIndex;\n           bToCmappingIndex++) {\n        const bToCmapping: Mapping = bSource.flattenedMappings[bToCmappingIndex];\n        flattenedMappings.push(mergeMappings(this, aToBmapping, bToCmapping));\n      }\n    }\n    return flattenedMappings;\n  }\n}\n\n/**\n *\n * @param mappings The collection of mappings whose segment-markers we are searching.\n * @param marker The segment-marker to match against those of the given `mappings`.\n * @param exclusive If exclusive then we must find a mapping with a segment-marker that is\n * exclusively earlier than the given `marker`.\n * If not exclusive then we can return the highest mappings with an equivalent segment-marker to the\n * given `marker`.\n * @param lowerIndex If provided, this is used as a hint that the marker we are searching for has an\n * index that is no lower than this.\n */\nexport function findLastMappingIndexBefore(\n    mappings: Mapping[], marker: SegmentMarker, exclusive: boolean, lowerIndex: number): number {\n  let upperIndex = mappings.length - 1;\n  const test = exclusive ? -1 : 0;\n\n  if (compareSegments(mappings[lowerIndex].generatedSegment, marker) > test) {\n    // Exit early since the marker is outside the allowed range of mappings.\n    return -1;\n  }\n\n  let matchingIndex = -1;\n  while (lowerIndex <= upperIndex) {\n    const index = (upperIndex + lowerIndex) >> 1;\n    if (compareSegments(mappings[index].generatedSegment, marker) <= test) {\n      matchingIndex = index;\n      lowerIndex = index + 1;\n    } else {\n      upperIndex = index - 1;\n    }\n  }\n  return matchingIndex;\n}\n\n/**\n * A Mapping consists of two segment markers: one in the generated source and one in the original\n * source, which indicate the start of each segment. The end of a segment is indicated by the first\n * segment marker of another mapping whose start is greater or equal to this one.\n *\n * It may also include a name associated with the segment being mapped.\n */\nexport interface Mapping {\n  readonly generatedSegment: SegmentMarker;\n  readonly originalSource: SourceFile;\n  readonly originalSegment: SegmentMarker;\n  readonly name?: string;\n}\n\n/**\n * Find the index of `item` in the `items` array.\n * If it is not found, then push `item` to the end of the array and return its new index.\n *\n * @param items the collection in which to look for `item`.\n * @param item the item to look for.\n * @returns the index of the `item` in the `items` array.\n */\nfunction findIndexOrAdd<T>(items: T[], item: T): number {\n  const itemIndex = items.indexOf(item);\n  if (itemIndex > -1) {\n    return itemIndex;\n  } else {\n    items.push(item);\n    return items.length - 1;\n  }\n}\n\n\n/**\n * Merge two mappings that go from A to B and B to C, to result in a mapping that goes from A to C.\n */\nexport function mergeMappings(generatedSource: SourceFile, ab: Mapping, bc: Mapping): Mapping {\n  const name = bc.name || ab.name;\n\n  // We need to modify the segment-markers of the new mapping to take into account the shifts that\n  // occur due to the combination of the two mappings.\n  // For example:\n\n  // * Simple map where the B->C starts at the same place the A->B ends:\n  //\n  // ```\n  // A: 1 2 b c d\n  //        |        A->B [2,0]\n  //        |              |\n  // B:     b c d    A->C [2,1]\n  //        |                |\n  //        |        B->C [0,1]\n  // C:   a b c d e\n  // ```\n\n  // * More complicated case where diffs of segment-markers is needed:\n  //\n  // ```\n  // A: b 1 2 c d\n  //     \\\n  //      |            A->B  [0,1*]    [0,1*]\n  //      |                   |         |+3\n  // B: a b 1 2 c d    A->C  [0,1]     [3,2]\n  //    |      /                |+1       |\n  //    |     /        B->C [0*,0]    [4*,2]\n  //    |    /\n  // C: a b c d e\n  // ```\n  //\n  // `[0,1]` mapping from A->C:\n  // The difference between the \"original segment-marker\" of A->B (1*) and the \"generated\n  // segment-marker of B->C (0*): `1 - 0 = +1`.\n  // Since it is positive we must increment the \"original segment-marker\" with `1` to give [0,1].\n  //\n  // `[3,2]` mapping from A->C:\n  // The difference between the \"original segment-marker\" of A->B (1*) and the \"generated\n  // segment-marker\" of B->C (4*): `1 - 4 = -3`.\n  // Since it is negative we must increment the \"generated segment-marker\" with `3` to give [3,2].\n\n  const diff = compareSegments(bc.generatedSegment, ab.originalSegment);\n  if (diff > 0) {\n    return {\n      name,\n      generatedSegment:\n          offsetSegment(generatedSource.startOfLinePositions, ab.generatedSegment, diff),\n      originalSource: bc.originalSource,\n      originalSegment: bc.originalSegment,\n    };\n  } else {\n    return {\n      name,\n      generatedSegment: ab.generatedSegment,\n      originalSource: bc.originalSource,\n      originalSegment:\n          offsetSegment(bc.originalSource.startOfLinePositions, bc.originalSegment, -diff),\n    };\n  }\n}\n\n/**\n * Parse the `rawMappings` into an array of parsed mappings, which reference source-files provided\n * in the `sources` parameter.\n */\nexport function parseMappings(\n    rawMap: RawSourceMap | null, sources: (SourceFile | null)[],\n    generatedSourceStartOfLinePositions: number[]): Mapping[] {\n  if (rawMap === null) {\n    return [];\n  }\n\n  const rawMappings = decode(rawMap.mappings);\n  if (rawMappings === null) {\n    return [];\n  }\n\n  const mappings: Mapping[] = [];\n  for (let generatedLine = 0; generatedLine < rawMappings.length; generatedLine++) {\n    const generatedLineMappings = rawMappings[generatedLine];\n    for (const rawMapping of generatedLineMappings) {\n      if (rawMapping.length >= 4) {\n        const originalSource = sources[rawMapping[1] !];\n        if (originalSource === null || originalSource === undefined) {\n          // the original source is missing so ignore this mapping\n          continue;\n        }\n        const generatedColumn = rawMapping[0];\n        const name = rawMapping.length === 5 ? rawMap.names[rawMapping[4]] : undefined;\n        const line = rawMapping[2] !;\n        const column = rawMapping[3] !;\n        const generatedSegment: SegmentMarker = {\n          line: generatedLine,\n          column: generatedColumn,\n          position: generatedSourceStartOfLinePositions[generatedLine] + generatedColumn,\n          next: undefined,\n        };\n        const originalSegment: SegmentMarker = {\n          line,\n          column,\n          position: originalSource.startOfLinePositions[line] + column,\n          next: undefined,\n        };\n        mappings.push({name, generatedSegment, originalSegment, originalSource});\n      }\n    }\n  }\n  return mappings;\n}\n\n/**\n * Extract the segment markers from the original source files in each mapping of an array of\n * `mappings`.\n *\n * @param mappings The mappings whose original segments we want to extract\n * @returns Return a map from original source-files (referenced in the `mappings`) to arrays of\n * segment-markers sorted by their order in their source file.\n */\nexport function extractOriginalSegments(mappings: Mapping[]): Map<SourceFile, SegmentMarker[]> {\n  const originalSegments = new Map<SourceFile, SegmentMarker[]>();\n  for (const mapping of mappings) {\n    const originalSource = mapping.originalSource;\n    if (!originalSegments.has(originalSource)) {\n      originalSegments.set(originalSource, []);\n    }\n    const segments = originalSegments.get(originalSource) !;\n    segments.push(mapping.originalSegment);\n  }\n  originalSegments.forEach(segmentMarkers => segmentMarkers.sort(compareSegments));\n  return originalSegments;\n}\n\n/**\n * Update the original segments of each of the given `mappings` to include a link to the next\n * segment in the source file.\n *\n * @param mappings the mappings whose segments should be updated\n */\nexport function ensureOriginalSegmentLinks(mappings: Mapping[]): void {\n  const segmentsBySource = extractOriginalSegments(mappings);\n  segmentsBySource.forEach(markers => {\n    for (let i = 0; i < markers.length - 1; i++) {\n      markers[i].next = markers[i + 1];\n    }\n  });\n}\n\nexport function computeStartOfLinePositions(str: string) {\n  // The `1` is to indicate a newline character between the lines.\n  // Note that in the actual contents there could be more than one character that indicates a\n  // newline\n  // - e.g. \\r\\n - but that is not important here since segment-markers are in line/column pairs and\n  // so differences in length due to extra `\\r` characters do not affect the algorithms.\n  const NEWLINE_MARKER_OFFSET = 1;\n  const lineLengths = computeLineLengths(str);\n  const startPositions = [0];  // First line starts at position 0\n  for (let i = 0; i < lineLengths.length - 1; i++) {\n    startPositions.push(startPositions[i] + lineLengths[i] + NEWLINE_MARKER_OFFSET);\n  }\n  return startPositions;\n}\n\nfunction computeLineLengths(str: string): number[] {\n  return (str.split(/\\r?\\n/)).map(s => s.length);\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/compiler-cli",
3
- "version": "9.0.3",
3
+ "version": "9.0.7",
4
4
  "description": "Angular - the compiler CLI for Node.js",
5
5
  "main": "index.js",
6
6
  "typings": "index.d.ts",
@@ -25,7 +25,7 @@
25
25
  "yargs": "13.1.0"
26
26
  },
27
27
  "peerDependencies": {
28
- "@angular/compiler": "9.0.3",
28
+ "@angular/compiler": "9.0.7",
29
29
  "tslib": "^1.10.0",
30
30
  "typescript": ">=3.6 <3.8"
31
31
  },