@angular/compiler-cli 11.0.8 → 11.0.9

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 (83) hide show
  1. package/ngcc/src/analysis/decoration_analyzer.d.ts +3 -3
  2. package/ngcc/src/analysis/decoration_analyzer.js +3 -3
  3. package/ngcc/src/command_line_options.js +4 -3
  4. package/ngcc/src/dependencies/dependency_host.d.ts +3 -3
  5. package/ngcc/src/dependencies/dependency_host.js +1 -1
  6. package/ngcc/src/dependencies/dependency_resolver.d.ts +2 -2
  7. package/ngcc/src/dependencies/dependency_resolver.js +3 -4
  8. package/ngcc/src/dependencies/dts_dependency_host.d.ts +2 -2
  9. package/ngcc/src/dependencies/dts_dependency_host.js +1 -1
  10. package/ngcc/src/dependencies/esm_dependency_host.d.ts +2 -2
  11. package/ngcc/src/dependencies/esm_dependency_host.js +1 -1
  12. package/ngcc/src/dependencies/module_resolver.d.ts +2 -2
  13. package/ngcc/src/dependencies/module_resolver.js +15 -24
  14. package/ngcc/src/entry_point_finder/entry_point_collector.d.ts +2 -2
  15. package/ngcc/src/entry_point_finder/entry_point_collector.js +1 -1
  16. package/ngcc/src/entry_point_finder/program_based_entry_point_finder.d.ts +2 -2
  17. package/ngcc/src/entry_point_finder/program_based_entry_point_finder.js +2 -2
  18. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.d.ts +11 -2
  19. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +24 -20
  20. package/ngcc/src/entry_point_finder/tracing_entry_point_finder.d.ts +3 -3
  21. package/ngcc/src/entry_point_finder/tracing_entry_point_finder.js +1 -1
  22. package/ngcc/src/entry_point_finder/utils.d.ts +0 -9
  23. package/ngcc/src/entry_point_finder/utils.js +8 -9
  24. package/ngcc/src/execution/cluster/executor.d.ts +2 -2
  25. package/ngcc/src/execution/cluster/executor.js +1 -1
  26. package/ngcc/src/execution/cluster/master.d.ts +2 -2
  27. package/ngcc/src/execution/cluster/master.js +1 -1
  28. package/ngcc/src/execution/tasks/completion.d.ts +4 -4
  29. package/ngcc/src/execution/tasks/completion.js +4 -12
  30. package/ngcc/src/locking/lock_file.d.ts +2 -2
  31. package/ngcc/src/locking/lock_file.js +1 -1
  32. package/ngcc/src/main.js +6 -6
  33. package/ngcc/src/ngcc_options.js +2 -2
  34. package/ngcc/src/packages/build_marker.d.ts +1 -1
  35. package/ngcc/src/packages/build_marker.js +1 -1
  36. package/ngcc/src/packages/bundle_program.d.ts +3 -3
  37. package/ngcc/src/packages/bundle_program.js +6 -7
  38. package/ngcc/src/packages/configuration.d.ts +3 -3
  39. package/ngcc/src/packages/configuration.js +8 -9
  40. package/ngcc/src/packages/entry_point.d.ts +3 -3
  41. package/ngcc/src/packages/entry_point.js +13 -16
  42. package/ngcc/src/packages/entry_point_bundle.js +1 -1
  43. package/ngcc/src/packages/source_file_cache.d.ts +6 -6
  44. package/ngcc/src/packages/source_file_cache.js +1 -1
  45. package/ngcc/src/packages/transformer.d.ts +2 -2
  46. package/ngcc/src/packages/transformer.js +6 -6
  47. package/ngcc/src/path_mappings.d.ts +2 -2
  48. package/ngcc/src/path_mappings.js +4 -12
  49. package/ngcc/src/rendering/commonjs_rendering_formatter.d.ts +9 -1
  50. package/ngcc/src/rendering/commonjs_rendering_formatter.js +6 -13
  51. package/ngcc/src/rendering/dts_renderer.d.ts +2 -2
  52. package/ngcc/src/rendering/dts_renderer.js +1 -1
  53. package/ngcc/src/rendering/esm_rendering_formatter.d.ts +3 -2
  54. package/ngcc/src/rendering/esm_rendering_formatter.js +6 -4
  55. package/ngcc/src/rendering/renderer.d.ts +2 -2
  56. package/ngcc/src/rendering/renderer.js +1 -1
  57. package/ngcc/src/rendering/source_maps.d.ts +2 -2
  58. package/ngcc/src/rendering/source_maps.js +2 -2
  59. package/ngcc/src/rendering/umd_rendering_formatter.d.ts +9 -1
  60. package/ngcc/src/rendering/umd_rendering_formatter.js +6 -13
  61. package/ngcc/src/utils.d.ts +2 -2
  62. package/ngcc/src/utils.js +1 -1
  63. package/ngcc/src/writing/cleaning/package_cleaner.d.ts +2 -2
  64. package/ngcc/src/writing/cleaning/package_cleaner.js +1 -1
  65. package/ngcc/src/writing/cleaning/utils.d.ts +2 -2
  66. package/ngcc/src/writing/cleaning/utils.js +1 -1
  67. package/ngcc/src/writing/new_entry_point_file_writer.js +15 -15
  68. package/package.json +2 -2
  69. package/src/ngtsc/file_system/index.d.ts +1 -1
  70. package/src/ngtsc/file_system/index.js +1 -1
  71. package/src/ngtsc/file_system/src/node_js_file_system.d.ts +29 -19
  72. package/src/ngtsc/file_system/src/node_js_file_system.js +102 -80
  73. package/src/ngtsc/file_system/src/types.d.ts +34 -23
  74. package/src/ngtsc/file_system/src/types.js +1 -1
  75. package/src/ngtsc/sourcemaps/src/source_file.d.ts +2 -2
  76. package/src/ngtsc/sourcemaps/src/source_file.js +1 -1
  77. package/src/ngtsc/sourcemaps/src/source_file_loader.d.ts +2 -2
  78. package/src/ngtsc/sourcemaps/src/source_file_loader.js +1 -1
  79. package/src/perform_compile.d.ts +3 -1
  80. package/src/perform_compile.js +1 -1
  81. package/src/transformers/downlevel_decorators_transform.js +7 -8
  82. package/src/transformers/patch_alias_reference_resolution.js +25 -13
  83. package/src/version.js +1 -1
@@ -4,12 +4,12 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/compiler-cli/src/ngtsc/file_system/src/node_js_file_system", ["require", "exports", "tslib", "fs", "fs-extra", "path", "@angular/compiler-cli/src/ngtsc/file_system/src/helpers"], factory);
7
+ define("@angular/compiler-cli/src/ngtsc/file_system/src/node_js_file_system", ["require", "exports", "tslib", "fs", "fs-extra", "path"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.NodeJSFileSystem = void 0;
12
+ exports.NodeJSFileSystem = exports.NodeJSReadonlyFileSystem = exports.NodeJSPathManipulation = void 0;
13
13
  var tslib_1 = require("tslib");
14
14
  /**
15
15
  * @license
@@ -22,23 +22,110 @@
22
22
  var fs = require("fs");
23
23
  var fsExtra = require("fs-extra");
24
24
  var p = require("path");
25
- var helpers_1 = require("@angular/compiler-cli/src/ngtsc/file_system/src/helpers");
26
25
  /**
27
- * A wrapper around the Node.js file-system (i.e the `fs` package).
26
+ * A wrapper around the Node.js file-system that supports path manipulation.
28
27
  */
29
- var NodeJSFileSystem = /** @class */ (function () {
30
- function NodeJSFileSystem() {
31
- this._caseSensitive = undefined;
28
+ var NodeJSPathManipulation = /** @class */ (function () {
29
+ function NodeJSPathManipulation() {
30
+ }
31
+ NodeJSPathManipulation.prototype.pwd = function () {
32
+ return this.normalize(process.cwd());
33
+ };
34
+ NodeJSPathManipulation.prototype.chdir = function (dir) {
35
+ process.chdir(dir);
36
+ };
37
+ NodeJSPathManipulation.prototype.resolve = function () {
38
+ var paths = [];
39
+ for (var _i = 0; _i < arguments.length; _i++) {
40
+ paths[_i] = arguments[_i];
41
+ }
42
+ return this.normalize(p.resolve.apply(p, tslib_1.__spread(paths)));
43
+ };
44
+ NodeJSPathManipulation.prototype.dirname = function (file) {
45
+ return this.normalize(p.dirname(file));
46
+ };
47
+ NodeJSPathManipulation.prototype.join = function (basePath) {
48
+ var paths = [];
49
+ for (var _i = 1; _i < arguments.length; _i++) {
50
+ paths[_i - 1] = arguments[_i];
51
+ }
52
+ return this.normalize(p.join.apply(p, tslib_1.__spread([basePath], paths)));
53
+ };
54
+ NodeJSPathManipulation.prototype.isRoot = function (path) {
55
+ return this.dirname(path) === this.normalize(path);
56
+ };
57
+ NodeJSPathManipulation.prototype.isRooted = function (path) {
58
+ return p.isAbsolute(path);
59
+ };
60
+ NodeJSPathManipulation.prototype.relative = function (from, to) {
61
+ return this.normalize(p.relative(from, to));
62
+ };
63
+ NodeJSPathManipulation.prototype.basename = function (filePath, extension) {
64
+ return p.basename(filePath, extension);
65
+ };
66
+ NodeJSPathManipulation.prototype.extname = function (path) {
67
+ return p.extname(path);
68
+ };
69
+ NodeJSPathManipulation.prototype.normalize = function (path) {
70
+ // Convert backslashes to forward slashes
71
+ return path.replace(/\\/g, '/');
72
+ };
73
+ return NodeJSPathManipulation;
74
+ }());
75
+ exports.NodeJSPathManipulation = NodeJSPathManipulation;
76
+ /**
77
+ * A wrapper around the Node.js file-system that supports readonly operations and path manipulation.
78
+ */
79
+ var NodeJSReadonlyFileSystem = /** @class */ (function (_super) {
80
+ tslib_1.__extends(NodeJSReadonlyFileSystem, _super);
81
+ function NodeJSReadonlyFileSystem() {
82
+ var _this = _super !== null && _super.apply(this, arguments) || this;
83
+ _this._caseSensitive = undefined;
84
+ return _this;
32
85
  }
33
- NodeJSFileSystem.prototype.exists = function (path) {
86
+ NodeJSReadonlyFileSystem.prototype.isCaseSensitive = function () {
87
+ if (this._caseSensitive === undefined) {
88
+ // Note the use of the real file-system is intentional:
89
+ // `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.
90
+ this._caseSensitive = !fs.existsSync(this.normalize(toggleCase(__filename)));
91
+ }
92
+ return this._caseSensitive;
93
+ };
94
+ NodeJSReadonlyFileSystem.prototype.exists = function (path) {
34
95
  return fs.existsSync(path);
35
96
  };
36
- NodeJSFileSystem.prototype.readFile = function (path) {
97
+ NodeJSReadonlyFileSystem.prototype.readFile = function (path) {
37
98
  return fs.readFileSync(path, 'utf8');
38
99
  };
39
- NodeJSFileSystem.prototype.readFileBuffer = function (path) {
100
+ NodeJSReadonlyFileSystem.prototype.readFileBuffer = function (path) {
40
101
  return fs.readFileSync(path);
41
102
  };
103
+ NodeJSReadonlyFileSystem.prototype.readdir = function (path) {
104
+ return fs.readdirSync(path);
105
+ };
106
+ NodeJSReadonlyFileSystem.prototype.lstat = function (path) {
107
+ return fs.lstatSync(path);
108
+ };
109
+ NodeJSReadonlyFileSystem.prototype.stat = function (path) {
110
+ return fs.statSync(path);
111
+ };
112
+ NodeJSReadonlyFileSystem.prototype.realpath = function (path) {
113
+ return this.resolve(fs.realpathSync(path));
114
+ };
115
+ NodeJSReadonlyFileSystem.prototype.getDefaultLibLocation = function () {
116
+ return this.resolve(require.resolve('typescript'), '..');
117
+ };
118
+ return NodeJSReadonlyFileSystem;
119
+ }(NodeJSPathManipulation));
120
+ exports.NodeJSReadonlyFileSystem = NodeJSReadonlyFileSystem;
121
+ /**
122
+ * A wrapper around the Node.js file-system (i.e. the `fs` package).
123
+ */
124
+ var NodeJSFileSystem = /** @class */ (function (_super) {
125
+ tslib_1.__extends(NodeJSFileSystem, _super);
126
+ function NodeJSFileSystem() {
127
+ return _super !== null && _super.apply(this, arguments) || this;
128
+ }
42
129
  NodeJSFileSystem.prototype.writeFile = function (path, data, exclusive) {
43
130
  if (exclusive === void 0) { exclusive = false; }
44
131
  fs.writeFileSync(path, data, exclusive ? { flag: 'wx' } : undefined);
@@ -49,21 +136,6 @@
49
136
  NodeJSFileSystem.prototype.symlink = function (target, path) {
50
137
  fs.symlinkSync(target, path);
51
138
  };
52
- NodeJSFileSystem.prototype.readdir = function (path) {
53
- return fs.readdirSync(path);
54
- };
55
- NodeJSFileSystem.prototype.lstat = function (path) {
56
- return fs.lstatSync(path);
57
- };
58
- NodeJSFileSystem.prototype.stat = function (path) {
59
- return fs.statSync(path);
60
- };
61
- NodeJSFileSystem.prototype.pwd = function () {
62
- return this.normalize(process.cwd());
63
- };
64
- NodeJSFileSystem.prototype.chdir = function (dir) {
65
- process.chdir(dir);
66
- };
67
139
  NodeJSFileSystem.prototype.copyFile = function (from, to) {
68
140
  fs.copyFileSync(from, to);
69
141
  };
@@ -83,56 +155,6 @@
83
155
  NodeJSFileSystem.prototype.removeDeep = function (path) {
84
156
  fsExtra.removeSync(path);
85
157
  };
86
- NodeJSFileSystem.prototype.isCaseSensitive = function () {
87
- if (this._caseSensitive === undefined) {
88
- // Note the use of the real file-system is intentional:
89
- // `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.
90
- this._caseSensitive = !fs.existsSync(togglePathCase(__filename));
91
- }
92
- return this._caseSensitive;
93
- };
94
- NodeJSFileSystem.prototype.resolve = function () {
95
- var paths = [];
96
- for (var _i = 0; _i < arguments.length; _i++) {
97
- paths[_i] = arguments[_i];
98
- }
99
- return this.normalize(p.resolve.apply(p, tslib_1.__spread(paths)));
100
- };
101
- NodeJSFileSystem.prototype.dirname = function (file) {
102
- return this.normalize(p.dirname(file));
103
- };
104
- NodeJSFileSystem.prototype.join = function (basePath) {
105
- var paths = [];
106
- for (var _i = 1; _i < arguments.length; _i++) {
107
- paths[_i - 1] = arguments[_i];
108
- }
109
- return this.normalize(p.join.apply(p, tslib_1.__spread([basePath], paths)));
110
- };
111
- NodeJSFileSystem.prototype.isRoot = function (path) {
112
- return this.dirname(path) === this.normalize(path);
113
- };
114
- NodeJSFileSystem.prototype.isRooted = function (path) {
115
- return p.isAbsolute(path);
116
- };
117
- NodeJSFileSystem.prototype.relative = function (from, to) {
118
- return this.normalize(p.relative(from, to));
119
- };
120
- NodeJSFileSystem.prototype.basename = function (filePath, extension) {
121
- return p.basename(filePath, extension);
122
- };
123
- NodeJSFileSystem.prototype.extname = function (path) {
124
- return p.extname(path);
125
- };
126
- NodeJSFileSystem.prototype.realpath = function (path) {
127
- return this.resolve(fs.realpathSync(path));
128
- };
129
- NodeJSFileSystem.prototype.getDefaultLibLocation = function () {
130
- return this.resolve(require.resolve('typescript'), '..');
131
- };
132
- NodeJSFileSystem.prototype.normalize = function (path) {
133
- // Convert backslashes to forward slashes
134
- return path.replace(/\\/g, '/');
135
- };
136
158
  NodeJSFileSystem.prototype.safeMkdir = function (path) {
137
159
  try {
138
160
  fs.mkdirSync(path);
@@ -146,13 +168,13 @@
146
168
  }
147
169
  };
148
170
  return NodeJSFileSystem;
149
- }());
171
+ }(NodeJSReadonlyFileSystem));
150
172
  exports.NodeJSFileSystem = NodeJSFileSystem;
151
173
  /**
152
- * Toggle the case of each character in a file path.
174
+ * Toggle the case of each character in a string.
153
175
  */
154
- function togglePathCase(str) {
155
- return helpers_1.absoluteFrom(str.replace(/\w/g, function (ch) { return ch.toUpperCase() === ch ? ch.toLowerCase() : ch.toUpperCase(); }));
176
+ function toggleCase(str) {
177
+ return str.replace(/\w/g, function (ch) { return ch.toUpperCase() === ch ? ch.toLowerCase() : ch.toUpperCase(); });
156
178
  }
157
179
  });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node_js_file_system.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/file_system/src/node_js_file_system.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n/// <reference types=\"node\" />\nimport * as fs from 'fs';\nimport * as fsExtra from 'fs-extra';\nimport * as p from 'path';\nimport {absoluteFrom} from './helpers';\nimport {AbsoluteFsPath, FileStats, FileSystem, PathSegment, PathString} from './types';\n\n/**\n * A wrapper around the Node.js file-system (i.e the `fs` package).\n */\nexport class NodeJSFileSystem implements FileSystem {\n  private _caseSensitive: boolean|undefined = undefined;\n  exists(path: AbsoluteFsPath): boolean {\n    return fs.existsSync(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    return fs.readFileSync(path, 'utf8');\n  }\n  readFileBuffer(path: AbsoluteFsPath): Uint8Array {\n    return fs.readFileSync(path);\n  }\n  writeFile(path: AbsoluteFsPath, data: string|Uint8Array, exclusive: boolean = false): void {\n    fs.writeFileSync(path, data, exclusive ? {flag: 'wx'} : undefined);\n  }\n  removeFile(path: AbsoluteFsPath): void {\n    fs.unlinkSync(path);\n  }\n  symlink(target: AbsoluteFsPath, path: AbsoluteFsPath): void {\n    fs.symlinkSync(target, path);\n  }\n  readdir(path: AbsoluteFsPath): PathSegment[] {\n    return fs.readdirSync(path) as PathSegment[];\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return fs.lstatSync(path);\n  }\n  stat(path: AbsoluteFsPath): FileStats {\n    return fs.statSync(path);\n  }\n  pwd(): AbsoluteFsPath {\n    return this.normalize(process.cwd()) as AbsoluteFsPath;\n  }\n  chdir(dir: AbsoluteFsPath): void {\n    process.chdir(dir);\n  }\n  copyFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void {\n    fs.copyFileSync(from, to);\n  }\n  moveFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void {\n    fs.renameSync(from, to);\n  }\n  ensureDir(path: AbsoluteFsPath): void {\n    const parents: AbsoluteFsPath[] = [];\n    while (!this.isRoot(path) && !this.exists(path)) {\n      parents.push(path);\n      path = this.dirname(path);\n    }\n    while (parents.length) {\n      this.safeMkdir(parents.pop()!);\n    }\n  }\n  removeDeep(path: AbsoluteFsPath): void {\n    fsExtra.removeSync(path);\n  }\n  isCaseSensitive(): boolean {\n    if (this._caseSensitive === undefined) {\n      // Note the use of the real file-system is intentional:\n      // `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.\n      this._caseSensitive = !fs.existsSync(togglePathCase(__filename));\n    }\n    return this._caseSensitive;\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return this.normalize(p.resolve(...paths)) as AbsoluteFsPath;\n  }\n\n  dirname<T extends string>(file: T): T {\n    return this.normalize(p.dirname(file)) as T;\n  }\n  join<T extends string>(basePath: T, ...paths: string[]): T {\n    return this.normalize(p.join(basePath, ...paths)) as T;\n  }\n  isRoot(path: AbsoluteFsPath): boolean {\n    return this.dirname(path) === this.normalize(path);\n  }\n  isRooted(path: string): boolean {\n    return p.isAbsolute(path);\n  }\n  relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {\n    return this.normalize(p.relative(from, to)) as PathSegment | AbsoluteFsPath;\n  }\n  basename(filePath: string, extension?: string): PathSegment {\n    return p.basename(filePath, extension) as PathSegment;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  realpath(path: AbsoluteFsPath): AbsoluteFsPath {\n    return this.resolve(fs.realpathSync(path));\n  }\n  getDefaultLibLocation(): AbsoluteFsPath {\n    return this.resolve(require.resolve('typescript'), '..');\n  }\n  normalize<T extends string>(path: T): T {\n    // Convert backslashes to forward slashes\n    return path.replace(/\\\\/g, '/') as T;\n  }\n\n  private safeMkdir(path: AbsoluteFsPath): void {\n    try {\n      fs.mkdirSync(path);\n    } catch (err) {\n      // Ignore the error, if the path already exists and points to a directory.\n      // Re-throw otherwise.\n      if (!this.exists(path) || !this.stat(path).isDirectory()) {\n        throw err;\n      }\n    }\n  }\n}\n\n/**\n * Toggle the case of each character in a file path.\n */\nfunction togglePathCase(str: string): AbsoluteFsPath {\n  return absoluteFrom(\n      str.replace(/\\w/g, ch => ch.toUpperCase() === ch ? ch.toLowerCase() : ch.toUpperCase()));\n}\n"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node_js_file_system.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/file_system/src/node_js_file_system.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 */\n/// <reference types=\"node\" />\nimport * as fs from 'fs';\nimport * as fsExtra from 'fs-extra';\nimport * as p from 'path';\nimport {AbsoluteFsPath, FileStats, FileSystem, PathManipulation, PathSegment, PathString, ReadonlyFileSystem} from './types';\n\n/**\n * A wrapper around the Node.js file-system that supports path manipulation.\n */\nexport class NodeJSPathManipulation implements PathManipulation {\n  pwd(): AbsoluteFsPath {\n    return this.normalize(process.cwd()) as AbsoluteFsPath;\n  }\n  chdir(dir: AbsoluteFsPath): void {\n    process.chdir(dir);\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return this.normalize(p.resolve(...paths)) as AbsoluteFsPath;\n  }\n\n  dirname<T extends string>(file: T): T {\n    return this.normalize(p.dirname(file)) as T;\n  }\n  join<T extends string>(basePath: T, ...paths: string[]): T {\n    return this.normalize(p.join(basePath, ...paths)) as T;\n  }\n  isRoot(path: AbsoluteFsPath): boolean {\n    return this.dirname(path) === this.normalize(path);\n  }\n  isRooted(path: string): boolean {\n    return p.isAbsolute(path);\n  }\n  relative<T extends PathString>(from: T, to: T): PathSegment|AbsoluteFsPath {\n    return this.normalize(p.relative(from, to)) as PathSegment | AbsoluteFsPath;\n  }\n  basename(filePath: string, extension?: string): PathSegment {\n    return p.basename(filePath, extension) as PathSegment;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  normalize<T extends string>(path: T): T {\n    // Convert backslashes to forward slashes\n    return path.replace(/\\\\/g, '/') as T;\n  }\n}\n\n/**\n * A wrapper around the Node.js file-system that supports readonly operations and path manipulation.\n */\nexport class NodeJSReadonlyFileSystem extends NodeJSPathManipulation implements ReadonlyFileSystem {\n  private _caseSensitive: boolean|undefined = undefined;\n  isCaseSensitive(): boolean {\n    if (this._caseSensitive === undefined) {\n      // Note the use of the real file-system is intentional:\n      // `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.\n      this._caseSensitive = !fs.existsSync(this.normalize(toggleCase(__filename)));\n    }\n    return this._caseSensitive;\n  }\n  exists(path: AbsoluteFsPath): boolean {\n    return fs.existsSync(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    return fs.readFileSync(path, 'utf8');\n  }\n  readFileBuffer(path: AbsoluteFsPath): Uint8Array {\n    return fs.readFileSync(path);\n  }\n  readdir(path: AbsoluteFsPath): PathSegment[] {\n    return fs.readdirSync(path) as PathSegment[];\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return fs.lstatSync(path);\n  }\n  stat(path: AbsoluteFsPath): FileStats {\n    return fs.statSync(path);\n  }\n  realpath(path: AbsoluteFsPath): AbsoluteFsPath {\n    return this.resolve(fs.realpathSync(path));\n  }\n  getDefaultLibLocation(): AbsoluteFsPath {\n    return this.resolve(require.resolve('typescript'), '..');\n  }\n}\n\n/**\n * A wrapper around the Node.js file-system (i.e. the `fs` package).\n */\nexport class NodeJSFileSystem extends NodeJSReadonlyFileSystem implements FileSystem {\n  writeFile(path: AbsoluteFsPath, data: string|Uint8Array, exclusive: boolean = false): void {\n    fs.writeFileSync(path, data, exclusive ? {flag: 'wx'} : undefined);\n  }\n  removeFile(path: AbsoluteFsPath): void {\n    fs.unlinkSync(path);\n  }\n  symlink(target: AbsoluteFsPath, path: AbsoluteFsPath): void {\n    fs.symlinkSync(target, path);\n  }\n  copyFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void {\n    fs.copyFileSync(from, to);\n  }\n  moveFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void {\n    fs.renameSync(from, to);\n  }\n  ensureDir(path: AbsoluteFsPath): void {\n    const parents: AbsoluteFsPath[] = [];\n    while (!this.isRoot(path) && !this.exists(path)) {\n      parents.push(path);\n      path = this.dirname(path);\n    }\n    while (parents.length) {\n      this.safeMkdir(parents.pop()!);\n    }\n  }\n  removeDeep(path: AbsoluteFsPath): void {\n    fsExtra.removeSync(path);\n  }\n\n  private safeMkdir(path: AbsoluteFsPath): void {\n    try {\n      fs.mkdirSync(path);\n    } catch (err) {\n      // Ignore the error, if the path already exists and points to a directory.\n      // Re-throw otherwise.\n      if (!this.exists(path) || !this.stat(path).isDirectory()) {\n        throw err;\n      }\n    }\n  }\n}\n\n/**\n * Toggle the case of each character in a string.\n */\nfunction toggleCase(str: string): string {\n  return str.replace(/\\w/g, ch => ch.toUpperCase() === ch ? ch.toLowerCase() : ch.toUpperCase());\n}\n"]}
@@ -26,33 +26,14 @@ export declare type AbsoluteFsPath = BrandedPath<'AbsoluteFsPath'>;
26
26
  */
27
27
  export declare type PathSegment = BrandedPath<'PathSegment'>;
28
28
  /**
29
- * A basic interface to abstract the underlying file-system.
30
- *
31
- * This makes it easier to provide mock file-systems in unit tests,
32
- * but also to create clever file-systems that have features such as caching.
29
+ * An abstraction over the path manipulation aspects of a file-system.
33
30
  */
34
- export interface FileSystem {
35
- exists(path: AbsoluteFsPath): boolean;
36
- readFile(path: AbsoluteFsPath): string;
37
- readFileBuffer(path: AbsoluteFsPath): Uint8Array;
38
- writeFile(path: AbsoluteFsPath, data: string | Uint8Array, exclusive?: boolean): void;
39
- removeFile(path: AbsoluteFsPath): void;
40
- symlink(target: AbsoluteFsPath, path: AbsoluteFsPath): void;
41
- readdir(path: AbsoluteFsPath): PathSegment[];
42
- lstat(path: AbsoluteFsPath): FileStats;
43
- stat(path: AbsoluteFsPath): FileStats;
44
- pwd(): AbsoluteFsPath;
45
- chdir(path: AbsoluteFsPath): void;
31
+ export interface PathManipulation {
46
32
  extname(path: AbsoluteFsPath | PathSegment): string;
47
- copyFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void;
48
- moveFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void;
49
- ensureDir(path: AbsoluteFsPath): void;
50
- removeDeep(path: AbsoluteFsPath): void;
51
- isCaseSensitive(): boolean;
52
33
  isRoot(path: AbsoluteFsPath): boolean;
53
34
  isRooted(path: string): boolean;
54
- resolve(...paths: string[]): AbsoluteFsPath;
55
35
  dirname<T extends PathString>(file: T): T;
36
+ extname(path: AbsoluteFsPath | PathSegment): string;
56
37
  join<T extends PathString>(basePath: T, ...paths: string[]): T;
57
38
  /**
58
39
  * Compute the relative path between `from` and `to`.
@@ -63,9 +44,39 @@ export interface FileSystem {
63
44
  */
64
45
  relative<T extends PathString>(from: T, to: T): PathSegment | AbsoluteFsPath;
65
46
  basename(filePath: string, extension?: string): PathSegment;
47
+ normalize<T extends PathString>(path: T): T;
48
+ resolve(...paths: string[]): AbsoluteFsPath;
49
+ pwd(): AbsoluteFsPath;
50
+ chdir(path: AbsoluteFsPath): void;
51
+ }
52
+ /**
53
+ * An abstraction over the read-only aspects of a file-system.
54
+ */
55
+ export interface ReadonlyFileSystem extends PathManipulation {
56
+ isCaseSensitive(): boolean;
57
+ exists(path: AbsoluteFsPath): boolean;
58
+ readFile(path: AbsoluteFsPath): string;
59
+ readFileBuffer(path: AbsoluteFsPath): Uint8Array;
60
+ readdir(path: AbsoluteFsPath): PathSegment[];
61
+ lstat(path: AbsoluteFsPath): FileStats;
62
+ stat(path: AbsoluteFsPath): FileStats;
66
63
  realpath(filePath: AbsoluteFsPath): AbsoluteFsPath;
67
64
  getDefaultLibLocation(): AbsoluteFsPath;
68
- normalize<T extends PathString>(path: T): T;
65
+ }
66
+ /**
67
+ * A basic interface to abstract the underlying file-system.
68
+ *
69
+ * This makes it easier to provide mock file-systems in unit tests,
70
+ * but also to create clever file-systems that have features such as caching.
71
+ */
72
+ export interface FileSystem extends ReadonlyFileSystem {
73
+ writeFile(path: AbsoluteFsPath, data: string | Uint8Array, exclusive?: boolean): void;
74
+ removeFile(path: AbsoluteFsPath): void;
75
+ symlink(target: AbsoluteFsPath, path: AbsoluteFsPath): void;
76
+ copyFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void;
77
+ moveFile(from: AbsoluteFsPath, to: AbsoluteFsPath): void;
78
+ ensureDir(path: AbsoluteFsPath): void;
79
+ removeDeep(path: AbsoluteFsPath): void;
69
80
  }
70
81
  export declare type PathString = string | AbsoluteFsPath | PathSegment;
71
82
  /**
@@ -17,4 +17,4 @@
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
19
  });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2ZpbGVfc3lzdGVtL3NyYy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBBIGBzdHJpbmdgIHJlcHJlc2VudGluZyBhIHNwZWNpZmljIHR5cGUgb2YgcGF0aCwgd2l0aCBhIHBhcnRpY3VsYXIgYnJhbmQgYEJgLlxuICpcbiAqIEEgYHN0cmluZ2AgaXMgbm90IGFzc2lnbmFibGUgdG8gYSBgQnJhbmRlZFBhdGhgLCBidXQgYSBgQnJhbmRlZFBhdGhgIGlzIGFzc2lnbmFibGUgdG8gYSBgc3RyaW5nYC5cbiAqIFR3byBgQnJhbmRlZFBhdGhgcyB3aXRoIGRpZmZlcmVudCBicmFuZHMgYXJlIG5vdCBtdXR1YWxseSBhc3NpZ25hYmxlLlxuICovXG5leHBvcnQgdHlwZSBCcmFuZGVkUGF0aDxCIGV4dGVuZHMgc3RyaW5nPiA9IHN0cmluZyZ7XG4gIF9icmFuZDogQjtcbn07XG5cbi8qKlxuICogQSBmdWxseSBxdWFsaWZpZWQgcGF0aCBpbiB0aGUgZmlsZSBzeXN0ZW0sIGluIFBPU0lYIGZvcm0uXG4gKi9cbmV4cG9ydCB0eXBlIEFic29sdXRlRnNQYXRoID0gQnJhbmRlZFBhdGg8J0Fic29sdXRlRnNQYXRoJz47XG5cbi8qKlxuICogQSBwYXRoIHRoYXQncyByZWxhdGl2ZSB0byBhbm90aGVyICh1bnNwZWNpZmllZCkgcm9vdC5cbiAqXG4gKiBUaGlzIGRvZXMgbm90IG5lY2Vzc2FyaWx5IGhhdmUgdG8gcmVmZXIgdG8gYSBwaHlzaWNhbCBmaWxlLlxuICovXG5leHBvcnQgdHlwZSBQYXRoU2VnbWVudCA9IEJyYW5kZWRQYXRoPCdQYXRoU2VnbWVudCc+O1xuXG4vKipcbiAqIEEgYmFzaWMgaW50ZXJmYWNlIHRvIGFic3RyYWN0IHRoZSB1bmRlcmx5aW5nIGZpbGUtc3lzdGVtLlxuICpcbiAqIFRoaXMgbWFrZXMgaXQgZWFzaWVyIHRvIHByb3ZpZGUgbW9jayBmaWxlLXN5c3RlbXMgaW4gdW5pdCB0ZXN0cyxcbiAqIGJ1dCBhbHNvIHRvIGNyZWF0ZSBjbGV2ZXIgZmlsZS1zeXN0ZW1zIHRoYXQgaGF2ZSBmZWF0dXJlcyBzdWNoIGFzIGNhY2hpbmcuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZVN5c3RlbSB7XG4gIGV4aXN0cyhwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IGJvb2xlYW47XG4gIHJlYWRGaWxlKHBhdGg6IEFic29sdXRlRnNQYXRoKTogc3RyaW5nO1xuICByZWFkRmlsZUJ1ZmZlcihwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IFVpbnQ4QXJyYXk7XG4gIHdyaXRlRmlsZShwYXRoOiBBYnNvbHV0ZUZzUGF0aCwgZGF0YTogc3RyaW5nfFVpbnQ4QXJyYXksIGV4Y2x1c2l2ZT86IGJvb2xlYW4pOiB2b2lkO1xuICByZW1vdmVGaWxlKHBhdGg6IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgc3ltbGluayh0YXJnZXQ6IEFic29sdXRlRnNQYXRoLCBwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG4gIHJlYWRkaXIocGF0aDogQWJzb2x1dGVGc1BhdGgpOiBQYXRoU2VnbWVudFtdO1xuICBsc3RhdChwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IEZpbGVTdGF0cztcbiAgc3RhdChwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IEZpbGVTdGF0cztcbiAgcHdkKCk6IEFic29sdXRlRnNQYXRoO1xuICBjaGRpcihwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG4gIGV4dG5hbWUocGF0aDogQWJzb2x1dGVGc1BhdGh8UGF0aFNlZ21lbnQpOiBzdHJpbmc7XG4gIGNvcHlGaWxlKGZyb206IEFic29sdXRlRnNQYXRoLCB0bzogQWJzb2x1dGVGc1BhdGgpOiB2b2lkO1xuICBtb3ZlRmlsZShmcm9tOiBBYnNvbHV0ZUZzUGF0aCwgdG86IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgZW5zdXJlRGlyKHBhdGg6IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgcmVtb3ZlRGVlcChwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG4gIGlzQ2FzZVNlbnNpdGl2ZSgpOiBib29sZWFuO1xuICBpc1Jvb3QocGF0aDogQWJzb2x1dGVGc1BhdGgpOiBib29sZWFuO1xuICBpc1Jvb3RlZChwYXRoOiBzdHJpbmcpOiBib29sZWFuO1xuICByZXNvbHZlKC4uLnBhdGhzOiBzdHJpbmdbXSk6IEFic29sdXRlRnNQYXRoO1xuICBkaXJuYW1lPFQgZXh0ZW5kcyBQYXRoU3RyaW5nPihmaWxlOiBUKTogVDtcbiAgam9pbjxUIGV4dGVuZHMgUGF0aFN0cmluZz4oYmFzZVBhdGg6IFQsIC4uLnBhdGhzOiBzdHJpbmdbXSk6IFQ7XG4gIC8qKlxuICAgKiBDb21wdXRlIHRoZSByZWxhdGl2ZSBwYXRoIGJldHdlZW4gYGZyb21gIGFuZCBgdG9gLlxuICAgKlxuICAgKiBJbiBmaWxlLXN5c3RlbXMgdGhhdCBjYW4gaGF2ZSBtdWx0aXBsZSBmaWxlIHRyZWVzIHRoZSByZXR1cm5lZCBwYXRoIG1heSBub3QgYWN0dWFsbHkgYmVcbiAgICogXCJyZWxhdGl2ZVwiIChpLmUuIGBQYXRoU2VnbWVudGApLiBGb3IgZXhhbXBsZSwgV2luZG93cyBjYW4gaGF2ZSBtdWx0aXBsZSBkcml2ZXMgOlxuICAgKiBgcmVsYXRpdmUoJ2M6L2EvYicsICdkOi9hL2MnKWAgd291bGQgYmUgYGQ6L2EvYycuXG4gICAqL1xuICByZWxhdGl2ZTxUIGV4dGVuZHMgUGF0aFN0cmluZz4oZnJvbTogVCwgdG86IFQpOiBQYXRoU2VnbWVudHxBYnNvbHV0ZUZzUGF0aDtcbiAgYmFzZW5hbWUoZmlsZVBhdGg6IHN0cmluZywgZXh0ZW5zaW9uPzogc3RyaW5nKTogUGF0aFNlZ21lbnQ7XG4gIHJlYWxwYXRoKGZpbGVQYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IEFic29sdXRlRnNQYXRoO1xuICBnZXREZWZhdWx0TGliTG9jYXRpb24oKTogQWJzb2x1dGVGc1BhdGg7XG4gIG5vcm1hbGl6ZTxUIGV4dGVuZHMgUGF0aFN0cmluZz4ocGF0aDogVCk6IFQ7XG59XG5cbmV4cG9ydCB0eXBlIFBhdGhTdHJpbmcgPSBzdHJpbmd8QWJzb2x1dGVGc1BhdGh8UGF0aFNlZ21lbnQ7XG5cbi8qKlxuICogSW5mb3JtYXRpb24gYWJvdXQgYW4gb2JqZWN0IGluIHRoZSBGaWxlU3lzdGVtLlxuICogVGhpcyBpcyBhbmFsb2dvdXMgdG8gdGhlIGBmcy5TdGF0c2AgY2xhc3MgaW4gTm9kZS5qcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBGaWxlU3RhdHMge1xuICBpc0ZpbGUoKTogYm9vbGVhbjtcbiAgaXNEaXJlY3RvcnkoKTogYm9vbGVhbjtcbiAgaXNTeW1ib2xpY0xpbmsoKTogYm9vbGVhbjtcbn1cbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2ZpbGVfc3lzdGVtL3NyYy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBBIGBzdHJpbmdgIHJlcHJlc2VudGluZyBhIHNwZWNpZmljIHR5cGUgb2YgcGF0aCwgd2l0aCBhIHBhcnRpY3VsYXIgYnJhbmQgYEJgLlxuICpcbiAqIEEgYHN0cmluZ2AgaXMgbm90IGFzc2lnbmFibGUgdG8gYSBgQnJhbmRlZFBhdGhgLCBidXQgYSBgQnJhbmRlZFBhdGhgIGlzIGFzc2lnbmFibGUgdG8gYSBgc3RyaW5nYC5cbiAqIFR3byBgQnJhbmRlZFBhdGhgcyB3aXRoIGRpZmZlcmVudCBicmFuZHMgYXJlIG5vdCBtdXR1YWxseSBhc3NpZ25hYmxlLlxuICovXG5leHBvcnQgdHlwZSBCcmFuZGVkUGF0aDxCIGV4dGVuZHMgc3RyaW5nPiA9IHN0cmluZyZ7XG4gIF9icmFuZDogQjtcbn07XG5cbi8qKlxuICogQSBmdWxseSBxdWFsaWZpZWQgcGF0aCBpbiB0aGUgZmlsZSBzeXN0ZW0sIGluIFBPU0lYIGZvcm0uXG4gKi9cbmV4cG9ydCB0eXBlIEFic29sdXRlRnNQYXRoID0gQnJhbmRlZFBhdGg8J0Fic29sdXRlRnNQYXRoJz47XG5cbi8qKlxuICogQSBwYXRoIHRoYXQncyByZWxhdGl2ZSB0byBhbm90aGVyICh1bnNwZWNpZmllZCkgcm9vdC5cbiAqXG4gKiBUaGlzIGRvZXMgbm90IG5lY2Vzc2FyaWx5IGhhdmUgdG8gcmVmZXIgdG8gYSBwaHlzaWNhbCBmaWxlLlxuICovXG5leHBvcnQgdHlwZSBQYXRoU2VnbWVudCA9IEJyYW5kZWRQYXRoPCdQYXRoU2VnbWVudCc+O1xuXG4vKipcbiAqIEFuIGFic3RyYWN0aW9uIG92ZXIgdGhlIHBhdGggbWFuaXB1bGF0aW9uIGFzcGVjdHMgb2YgYSBmaWxlLXN5c3RlbS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBQYXRoTWFuaXB1bGF0aW9uIHtcbiAgZXh0bmFtZShwYXRoOiBBYnNvbHV0ZUZzUGF0aHxQYXRoU2VnbWVudCk6IHN0cmluZztcbiAgaXNSb290KHBhdGg6IEFic29sdXRlRnNQYXRoKTogYm9vbGVhbjtcbiAgaXNSb290ZWQocGF0aDogc3RyaW5nKTogYm9vbGVhbjtcbiAgZGlybmFtZTxUIGV4dGVuZHMgUGF0aFN0cmluZz4oZmlsZTogVCk6IFQ7XG4gIGV4dG5hbWUocGF0aDogQWJzb2x1dGVGc1BhdGh8UGF0aFNlZ21lbnQpOiBzdHJpbmc7XG4gIGpvaW48VCBleHRlbmRzIFBhdGhTdHJpbmc+KGJhc2VQYXRoOiBULCAuLi5wYXRoczogc3RyaW5nW10pOiBUO1xuICAvKipcbiAgICogQ29tcHV0ZSB0aGUgcmVsYXRpdmUgcGF0aCBiZXR3ZWVuIGBmcm9tYCBhbmQgYHRvYC5cbiAgICpcbiAgICogSW4gZmlsZS1zeXN0ZW1zIHRoYXQgY2FuIGhhdmUgbXVsdGlwbGUgZmlsZSB0cmVlcyB0aGUgcmV0dXJuZWQgcGF0aCBtYXkgbm90IGFjdHVhbGx5IGJlXG4gICAqIFwicmVsYXRpdmVcIiAoaS5lLiBgUGF0aFNlZ21lbnRgKS4gRm9yIGV4YW1wbGUsIFdpbmRvd3MgY2FuIGhhdmUgbXVsdGlwbGUgZHJpdmVzIDpcbiAgICogYHJlbGF0aXZlKCdjOi9hL2InLCAnZDovYS9jJylgIHdvdWxkIGJlIGBkOi9hL2MnLlxuICAgKi9cbiAgcmVsYXRpdmU8VCBleHRlbmRzIFBhdGhTdHJpbmc+KGZyb206IFQsIHRvOiBUKTogUGF0aFNlZ21lbnR8QWJzb2x1dGVGc1BhdGg7XG4gIGJhc2VuYW1lKGZpbGVQYXRoOiBzdHJpbmcsIGV4dGVuc2lvbj86IHN0cmluZyk6IFBhdGhTZWdtZW50O1xuICBub3JtYWxpemU8VCBleHRlbmRzIFBhdGhTdHJpbmc+KHBhdGg6IFQpOiBUO1xuICByZXNvbHZlKC4uLnBhdGhzOiBzdHJpbmdbXSk6IEFic29sdXRlRnNQYXRoO1xuICBwd2QoKTogQWJzb2x1dGVGc1BhdGg7XG4gIGNoZGlyKHBhdGg6IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbn1cblxuLyoqXG4gKiBBbiBhYnN0cmFjdGlvbiBvdmVyIHRoZSByZWFkLW9ubHkgYXNwZWN0cyBvZiBhIGZpbGUtc3lzdGVtLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlYWRvbmx5RmlsZVN5c3RlbSBleHRlbmRzIFBhdGhNYW5pcHVsYXRpb24ge1xuICBpc0Nhc2VTZW5zaXRpdmUoKTogYm9vbGVhbjtcbiAgZXhpc3RzKHBhdGg6IEFic29sdXRlRnNQYXRoKTogYm9vbGVhbjtcbiAgcmVhZEZpbGUocGF0aDogQWJzb2x1dGVGc1BhdGgpOiBzdHJpbmc7XG4gIHJlYWRGaWxlQnVmZmVyKHBhdGg6IEFic29sdXRlRnNQYXRoKTogVWludDhBcnJheTtcbiAgcmVhZGRpcihwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IFBhdGhTZWdtZW50W107XG4gIGxzdGF0KHBhdGg6IEFic29sdXRlRnNQYXRoKTogRmlsZVN0YXRzO1xuICBzdGF0KHBhdGg6IEFic29sdXRlRnNQYXRoKTogRmlsZVN0YXRzO1xuICByZWFscGF0aChmaWxlUGF0aDogQWJzb2x1dGVGc1BhdGgpOiBBYnNvbHV0ZUZzUGF0aDtcbiAgZ2V0RGVmYXVsdExpYkxvY2F0aW9uKCk6IEFic29sdXRlRnNQYXRoO1xufVxuXG4vKipcbiAqIEEgYmFzaWMgaW50ZXJmYWNlIHRvIGFic3RyYWN0IHRoZSB1bmRlcmx5aW5nIGZpbGUtc3lzdGVtLlxuICpcbiAqIFRoaXMgbWFrZXMgaXQgZWFzaWVyIHRvIHByb3ZpZGUgbW9jayBmaWxlLXN5c3RlbXMgaW4gdW5pdCB0ZXN0cyxcbiAqIGJ1dCBhbHNvIHRvIGNyZWF0ZSBjbGV2ZXIgZmlsZS1zeXN0ZW1zIHRoYXQgaGF2ZSBmZWF0dXJlcyBzdWNoIGFzIGNhY2hpbmcuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmlsZVN5c3RlbSBleHRlbmRzIFJlYWRvbmx5RmlsZVN5c3RlbSB7XG4gIHdyaXRlRmlsZShwYXRoOiBBYnNvbHV0ZUZzUGF0aCwgZGF0YTogc3RyaW5nfFVpbnQ4QXJyYXksIGV4Y2x1c2l2ZT86IGJvb2xlYW4pOiB2b2lkO1xuICByZW1vdmVGaWxlKHBhdGg6IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgc3ltbGluayh0YXJnZXQ6IEFic29sdXRlRnNQYXRoLCBwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG4gIGNvcHlGaWxlKGZyb206IEFic29sdXRlRnNQYXRoLCB0bzogQWJzb2x1dGVGc1BhdGgpOiB2b2lkO1xuICBtb3ZlRmlsZShmcm9tOiBBYnNvbHV0ZUZzUGF0aCwgdG86IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgZW5zdXJlRGlyKHBhdGg6IEFic29sdXRlRnNQYXRoKTogdm9pZDtcbiAgcmVtb3ZlRGVlcChwYXRoOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG59XG5cbmV4cG9ydCB0eXBlIFBhdGhTdHJpbmcgPSBzdHJpbmd8QWJzb2x1dGVGc1BhdGh8UGF0aFNlZ21lbnQ7XG5cbi8qKlxuICogSW5mb3JtYXRpb24gYWJvdXQgYW4gb2JqZWN0IGluIHRoZSBGaWxlU3lzdGVtLlxuICogVGhpcyBpcyBhbmFsb2dvdXMgdG8gdGhlIGBmcy5TdGF0c2AgY2xhc3MgaW4gTm9kZS5qcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBGaWxlU3RhdHMge1xuICBpc0ZpbGUoKTogYm9vbGVhbjtcbiAgaXNEaXJlY3RvcnkoKTogYm9vbGVhbjtcbiAgaXNTeW1ib2xpY0xpbmsoKTogYm9vbGVhbjtcbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
1
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/sourcemaps/src/source_file" />
2
- import { AbsoluteFsPath, FileSystem } from '../../file_system';
2
+ import { AbsoluteFsPath, PathManipulation } from '../../file_system';
3
3
  import { RawSourceMap } from './raw_source_map';
4
4
  import { SegmentMarker } from './segment_marker';
5
5
  export declare function removeSourceMapComments(contents: string): string;
@@ -34,7 +34,7 @@ export declare class SourceFile {
34
34
  /** Whether this source file's source map was inline or external. */
35
35
  inline: boolean,
36
36
  /** Any source files referenced by the raw source map associated with this source file. */
37
- sources: (SourceFile | null)[], fs: FileSystem);
37
+ sources: (SourceFile | null)[], fs: PathManipulation);
38
38
  /**
39
39
  * Render the raw source map generated from the flattened mappings.
40
40
  */
@@ -440,4 +440,4 @@
440
440
  return (str.split(/\n/)).map(function (s) { return s.length; });
441
441
  }
442
442
  });
443
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/sourcemaps/src/source_file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 {decode, encode, SourceMapMappings, SourceMapSegment} from 'sourcemap-codec';\n\nimport {AbsoluteFsPath, FileSystem} from '../../file_system';\n\nimport {RawSourceMap} from './raw_source_map';\nimport {compareSegments, offsetSegment, SegmentMarker} 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      private fs: FileSystem,\n  ) {\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 = this.fs.dirname(this.sourcePath);\n    const sourceMap: RawSourceMap = {\n      version: 3,\n      file: this.fs.relative(sourcePathDir, this.sourcePath),\n      sources: sources.map(sf => this.fs.relative(sourcePathDir, sf.sourcePath)),\n      names,\n      mappings: encode(mappings),\n      sourcesContent: sources.map(sf => sf.contents),\n    };\n    return sourceMap;\n  }\n\n  /**\n   * Find the original mapped location for the given `line` and `column` in the generated file.\n   *\n   * First we search for a mapping whose generated segment is at or directly before the given\n   * location. Then we compute the offset between the given location and the matching generated\n   * segment. Finally we apply this offset to the original source segment to get the desired\n   * original location.\n   */\n  getOriginalLocation(line: number, column: number):\n      {file: AbsoluteFsPath, line: number, column: number}|null {\n    if (this.flattenedMappings.length === 0) {\n      return null;\n    }\n\n    let position: number;\n    if (line < this.startOfLinePositions.length) {\n      position = this.startOfLinePositions[line] + column;\n    } else {\n      // The line is off the end of the file, so just assume we are at the end of the file.\n      position = this.contents.length;\n    }\n\n    const locationSegment: SegmentMarker = {line, column, position, next: undefined};\n\n    let mappingIndex =\n        findLastMappingIndexBefore(this.flattenedMappings, locationSegment, false, 0);\n    if (mappingIndex < 0) {\n      mappingIndex = 0;\n    }\n    const {originalSegment, originalSource, generatedSegment} =\n        this.flattenedMappings[mappingIndex];\n    const offset = locationSegment.position - generatedSegment.position;\n    const offsetOriginalSegment =\n        offsetSegment(originalSource.startOfLinePositions, originalSegment, offset);\n\n    return {\n      file: originalSource.sourcePath,\n      line: offsetOriginalSegment.line,\n      column: offsetOriginalSegment.column,\n    };\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(/\\n/)).map(s => s.length);\n}\n"]}
443
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/sourcemaps/src/source_file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 {decode, encode, SourceMapMappings, SourceMapSegment} from 'sourcemap-codec';\n\nimport {AbsoluteFsPath, PathManipulation} from '../../file_system';\n\nimport {RawSourceMap} from './raw_source_map';\nimport {compareSegments, offsetSegment, SegmentMarker} 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      private fs: PathManipulation,\n  ) {\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 = this.fs.dirname(this.sourcePath);\n    const sourceMap: RawSourceMap = {\n      version: 3,\n      file: this.fs.relative(sourcePathDir, this.sourcePath),\n      sources: sources.map(sf => this.fs.relative(sourcePathDir, sf.sourcePath)),\n      names,\n      mappings: encode(mappings),\n      sourcesContent: sources.map(sf => sf.contents),\n    };\n    return sourceMap;\n  }\n\n  /**\n   * Find the original mapped location for the given `line` and `column` in the generated file.\n   *\n   * First we search for a mapping whose generated segment is at or directly before the given\n   * location. Then we compute the offset between the given location and the matching generated\n   * segment. Finally we apply this offset to the original source segment to get the desired\n   * original location.\n   */\n  getOriginalLocation(line: number, column: number):\n      {file: AbsoluteFsPath, line: number, column: number}|null {\n    if (this.flattenedMappings.length === 0) {\n      return null;\n    }\n\n    let position: number;\n    if (line < this.startOfLinePositions.length) {\n      position = this.startOfLinePositions[line] + column;\n    } else {\n      // The line is off the end of the file, so just assume we are at the end of the file.\n      position = this.contents.length;\n    }\n\n    const locationSegment: SegmentMarker = {line, column, position, next: undefined};\n\n    let mappingIndex =\n        findLastMappingIndexBefore(this.flattenedMappings, locationSegment, false, 0);\n    if (mappingIndex < 0) {\n      mappingIndex = 0;\n    }\n    const {originalSegment, originalSource, generatedSegment} =\n        this.flattenedMappings[mappingIndex];\n    const offset = locationSegment.position - generatedSegment.position;\n    const offsetOriginalSegment =\n        offsetSegment(originalSource.startOfLinePositions, originalSegment, offset);\n\n    return {\n      file: originalSource.sourcePath,\n      line: offsetOriginalSegment.line,\n      column: offsetOriginalSegment.column,\n    };\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(/\\n/)).map(s => s.length);\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  /// <amd-module name="@angular/compiler-cli/src/ngtsc/sourcemaps/src/source_file_loader" />
2
- import { AbsoluteFsPath, FileSystem } from '../../file_system';
2
+ import { AbsoluteFsPath, ReadonlyFileSystem } from '../../file_system';
3
3
  import { Logger } from '../../logging';
4
4
  import { RawSourceMap } from './raw_source_map';
5
5
  import { SourceFile } from './source_file';
@@ -18,7 +18,7 @@ export declare class SourceFileLoader {
18
18
  /** A map of URL schemes to base paths. The scheme name should be lowercase. */
19
19
  private schemeMap;
20
20
  private currentPaths;
21
- constructor(fs: FileSystem, logger: Logger,
21
+ constructor(fs: ReadonlyFileSystem, logger: Logger,
22
22
  /** A map of URL schemes to base paths. The scheme name should be lowercase. */
23
23
  schemeMap: Record<string, AbsoluteFsPath>);
24
24
  /**