source: trip-planner-front/node_modules/@angular/compiler-cli/src/perform_compile.js@ 8d391a1

Last change on this file since 8d391a1 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 48.9 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler-cli/src/perform_compile", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/entry_points", "@angular/compiler-cli/src/transformers/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.defaultGatherDiagnostics = exports.performCompilation = exports.exitCodeFromResult = exports.readConfiguration = exports.calcProjectFileAndBasePath = exports.formatDiagnostics = exports.formatDiagnostic = exports.flattenDiagnosticMessageChain = exports.formatDiagnosticPosition = exports.filterErrorsAndWarnings = void 0;
20 var tslib_1 = require("tslib");
21 var compiler_1 = require("@angular/compiler");
22 var ts = require("typescript");
23 var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
24 var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
25 var api = require("@angular/compiler-cli/src/transformers/api");
26 var ng = require("@angular/compiler-cli/src/transformers/entry_points");
27 var util_1 = require("@angular/compiler-cli/src/transformers/util");
28 function filterErrorsAndWarnings(diagnostics) {
29 return diagnostics.filter(function (d) { return d.category !== ts.DiagnosticCategory.Message; });
30 }
31 exports.filterErrorsAndWarnings = filterErrorsAndWarnings;
32 var defaultFormatHost = {
33 getCurrentDirectory: function () { return ts.sys.getCurrentDirectory(); },
34 getCanonicalFileName: function (fileName) { return fileName; },
35 getNewLine: function () { return ts.sys.newLine; }
36 };
37 function displayFileName(fileName, host) {
38 return file_system_1.relative(file_system_1.resolve(host.getCurrentDirectory()), file_system_1.resolve(host.getCanonicalFileName(fileName)));
39 }
40 function formatDiagnosticPosition(position, host) {
41 if (host === void 0) { host = defaultFormatHost; }
42 return displayFileName(position.fileName, host) + "(" + (position.line + 1) + "," + (position.column + 1) + ")";
43 }
44 exports.formatDiagnosticPosition = formatDiagnosticPosition;
45 function flattenDiagnosticMessageChain(chain, host, indent) {
46 var e_1, _a;
47 if (host === void 0) { host = defaultFormatHost; }
48 if (indent === void 0) { indent = 0; }
49 var newLine = host.getNewLine();
50 var result = '';
51 if (indent) {
52 result += newLine;
53 for (var i = 0; i < indent; i++) {
54 result += ' ';
55 }
56 }
57 result += chain.messageText;
58 var position = chain.position;
59 // add position if available, and we are not at the depest frame
60 if (position && indent !== 0) {
61 result += " at " + formatDiagnosticPosition(position, host);
62 }
63 indent++;
64 if (chain.next) {
65 try {
66 for (var _b = tslib_1.__values(chain.next), _c = _b.next(); !_c.done; _c = _b.next()) {
67 var kid = _c.value;
68 result += flattenDiagnosticMessageChain(kid, host, indent);
69 }
70 }
71 catch (e_1_1) { e_1 = { error: e_1_1 }; }
72 finally {
73 try {
74 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
75 }
76 finally { if (e_1) throw e_1.error; }
77 }
78 }
79 return result;
80 }
81 exports.flattenDiagnosticMessageChain = flattenDiagnosticMessageChain;
82 function formatDiagnostic(diagnostic, host) {
83 if (host === void 0) { host = defaultFormatHost; }
84 var result = '';
85 var newLine = host.getNewLine();
86 var span = diagnostic.span;
87 if (span) {
88 result += formatDiagnosticPosition({ fileName: span.start.file.url, line: span.start.line, column: span.start.col }, host) + ": ";
89 }
90 else if (diagnostic.position) {
91 result += formatDiagnosticPosition(diagnostic.position, host) + ": ";
92 }
93 if (diagnostic.span && diagnostic.span.details) {
94 result += diagnostic.span.details + ", " + diagnostic.messageText + newLine;
95 }
96 else if (diagnostic.chain) {
97 result += flattenDiagnosticMessageChain(diagnostic.chain, host) + "." + newLine;
98 }
99 else {
100 result += "" + diagnostic.messageText + newLine;
101 }
102 return result;
103 }
104 exports.formatDiagnostic = formatDiagnostic;
105 function formatDiagnostics(diags, host) {
106 if (host === void 0) { host = defaultFormatHost; }
107 if (diags && diags.length) {
108 return diags
109 .map(function (diagnostic) {
110 if (api.isTsDiagnostic(diagnostic)) {
111 return diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext([diagnostic], host));
112 }
113 else {
114 return formatDiagnostic(diagnostic, host);
115 }
116 })
117 .join('');
118 }
119 else {
120 return '';
121 }
122 }
123 exports.formatDiagnostics = formatDiagnostics;
124 function calcProjectFileAndBasePath(project, host) {
125 if (host === void 0) { host = file_system_1.getFileSystem(); }
126 var absProject = host.resolve(project);
127 var projectIsDir = host.lstat(absProject).isDirectory();
128 var projectFile = projectIsDir ? host.join(absProject, 'tsconfig.json') : absProject;
129 var projectDir = projectIsDir ? absProject : host.dirname(absProject);
130 var basePath = host.resolve(projectDir);
131 return { projectFile: projectFile, basePath: basePath };
132 }
133 exports.calcProjectFileAndBasePath = calcProjectFileAndBasePath;
134 function readConfiguration(project, existingOptions, host) {
135 var _a;
136 if (host === void 0) { host = file_system_1.getFileSystem(); }
137 try {
138 var fs_1 = file_system_1.getFileSystem();
139 var readConfigFile_1 = function (configFile) {
140 return ts.readConfigFile(configFile, function (file) { return host.readFile(host.resolve(file)); });
141 };
142 var readAngularCompilerOptions_1 = function (configFile, parentOptions) {
143 if (parentOptions === void 0) { parentOptions = {}; }
144 var _a = readConfigFile_1(configFile), config = _a.config, error = _a.error;
145 if (error) {
146 // Errors are handled later on by 'parseJsonConfigFileContent'
147 return parentOptions;
148 }
149 // we are only interested into merging 'angularCompilerOptions' as
150 // other options like 'compilerOptions' are merged by TS
151 var existingNgCompilerOptions = tslib_1.__assign(tslib_1.__assign({}, config.angularCompilerOptions), parentOptions);
152 if (config.extends && typeof config.extends === 'string') {
153 var extendedConfigPath = getExtendedConfigPath(configFile, config.extends, host, fs_1);
154 if (extendedConfigPath !== null) {
155 // Call readAngularCompilerOptions recursively to merge NG Compiler options
156 return readAngularCompilerOptions_1(extendedConfigPath, existingNgCompilerOptions);
157 }
158 }
159 return existingNgCompilerOptions;
160 };
161 var _b = calcProjectFileAndBasePath(project, host), projectFile = _b.projectFile, basePath = _b.basePath;
162 var configFileName = host.resolve(host.pwd(), projectFile);
163 var _c = readConfigFile_1(projectFile), config = _c.config, error = _c.error;
164 if (error) {
165 return {
166 project: project,
167 errors: [error],
168 rootNames: [],
169 options: {},
170 emitFlags: api.EmitFlags.Default
171 };
172 }
173 var existingCompilerOptions = tslib_1.__assign(tslib_1.__assign({ genDir: basePath, basePath: basePath }, readAngularCompilerOptions_1(configFileName)), existingOptions);
174 var parseConfigHost = createParseConfigHost(host, fs_1);
175 var _d = ts.parseJsonConfigFileContent(config, parseConfigHost, basePath, existingCompilerOptions, configFileName), options = _d.options, errors = _d.errors, rootNames = _d.fileNames, projectReferences = _d.projectReferences;
176 // Coerce to boolean as `enableIvy` can be `ngtsc|true|false|undefined` here.
177 options.enableIvy = !!((_a = options.enableIvy) !== null && _a !== void 0 ? _a : true);
178 var emitFlags = api.EmitFlags.Default;
179 if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {
180 emitFlags |= api.EmitFlags.Metadata;
181 }
182 if (options.skipTemplateCodegen) {
183 emitFlags = emitFlags & ~api.EmitFlags.Codegen;
184 }
185 return { project: projectFile, rootNames: rootNames, projectReferences: projectReferences, options: options, errors: errors, emitFlags: emitFlags };
186 }
187 catch (e) {
188 var errors = [{
189 category: ts.DiagnosticCategory.Error,
190 messageText: e.stack,
191 file: undefined,
192 start: undefined,
193 length: undefined,
194 source: 'angular',
195 code: api.UNKNOWN_ERROR_CODE,
196 }];
197 return { project: '', errors: errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default };
198 }
199 }
200 exports.readConfiguration = readConfiguration;
201 function createParseConfigHost(host, fs) {
202 if (fs === void 0) { fs = file_system_1.getFileSystem(); }
203 return {
204 fileExists: host.exists.bind(host),
205 readDirectory: ts.sys.readDirectory,
206 readFile: host.readFile.bind(host),
207 useCaseSensitiveFileNames: fs.isCaseSensitive(),
208 };
209 }
210 function getExtendedConfigPath(configFile, extendsValue, host, fs) {
211 var result = getExtendedConfigPathWorker(configFile, extendsValue, host, fs);
212 if (result !== null) {
213 return result;
214 }
215 // Try to resolve the paths with a json extension append a json extension to the file in case if
216 // it is missing and the resolution failed. This is to replicate TypeScript behaviour, see:
217 // https://github.com/microsoft/TypeScript/blob/294a5a7d784a5a95a8048ee990400979a6bc3a1c/src/compiler/commandLineParser.ts#L2806
218 return getExtendedConfigPathWorker(configFile, extendsValue + ".json", host, fs);
219 }
220 function getExtendedConfigPathWorker(configFile, extendsValue, host, fs) {
221 if (extendsValue.startsWith('.') || fs.isRooted(extendsValue)) {
222 var extendedConfigPath = host.resolve(host.dirname(configFile), extendsValue);
223 if (host.exists(extendedConfigPath)) {
224 return extendedConfigPath;
225 }
226 }
227 else {
228 var parseConfigHost = createParseConfigHost(host, fs);
229 // Path isn't a rooted or relative path, resolve like a module.
230 var resolvedModule = ts.nodeModuleNameResolver(extendsValue, configFile, { moduleResolution: ts.ModuleResolutionKind.NodeJs, resolveJsonModule: true }, parseConfigHost).resolvedModule;
231 if (resolvedModule) {
232 return file_system_1.absoluteFrom(resolvedModule.resolvedFileName);
233 }
234 }
235 return null;
236 }
237 function exitCodeFromResult(diags) {
238 if (!diags || filterErrorsAndWarnings(diags).length === 0) {
239 // If we have a result and didn't get any errors, we succeeded.
240 return 0;
241 }
242 // Return 2 if any of the errors were unknown.
243 return diags.some(function (d) { return d.source === 'angular' && d.code === api.UNKNOWN_ERROR_CODE; }) ? 2 : 1;
244 }
245 exports.exitCodeFromResult = exitCodeFromResult;
246 function performCompilation(_a) {
247 var rootNames = _a.rootNames, options = _a.options, host = _a.host, oldProgram = _a.oldProgram, emitCallback = _a.emitCallback, mergeEmitResultsCallback = _a.mergeEmitResultsCallback, _b = _a.gatherDiagnostics, gatherDiagnostics = _b === void 0 ? defaultGatherDiagnostics : _b, customTransformers = _a.customTransformers, _c = _a.emitFlags, emitFlags = _c === void 0 ? api.EmitFlags.Default : _c, _d = _a.modifiedResourceFiles, modifiedResourceFiles = _d === void 0 ? null : _d;
248 var program;
249 var emitResult;
250 var allDiagnostics = [];
251 try {
252 if (!host) {
253 host = ng.createCompilerHost({ options: options });
254 }
255 if (modifiedResourceFiles) {
256 host.getModifiedResourceFiles = function () { return modifiedResourceFiles; };
257 }
258 program = ng.createProgram({ rootNames: rootNames, host: host, options: options, oldProgram: oldProgram });
259 var beforeDiags = Date.now();
260 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spreadArray([], tslib_1.__read(gatherDiagnostics(program))));
261 if (options.diagnostics) {
262 var afterDiags = Date.now();
263 allDiagnostics.push(util_1.createMessageDiagnostic("Time for diagnostics: " + (afterDiags - beforeDiags) + "ms."));
264 }
265 if (!hasErrors(allDiagnostics)) {
266 emitResult =
267 program.emit({ emitCallback: emitCallback, mergeEmitResultsCallback: mergeEmitResultsCallback, customTransformers: customTransformers, emitFlags: emitFlags });
268 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spreadArray([], tslib_1.__read(emitResult.diagnostics)));
269 return { diagnostics: allDiagnostics, program: program, emitResult: emitResult };
270 }
271 return { diagnostics: allDiagnostics, program: program };
272 }
273 catch (e) {
274 var errMsg = void 0;
275 var code = void 0;
276 if (compiler_1.isSyntaxError(e)) {
277 // don't report the stack for syntax errors as they are well known errors.
278 errMsg = e.message;
279 code = api.DEFAULT_ERROR_CODE;
280 }
281 else {
282 errMsg = e.stack;
283 // It is not a syntax error we might have a program with unknown state, discard it.
284 program = undefined;
285 code = api.UNKNOWN_ERROR_CODE;
286 }
287 allDiagnostics.push({ category: ts.DiagnosticCategory.Error, messageText: errMsg, code: code, source: api.SOURCE });
288 return { diagnostics: allDiagnostics, program: program };
289 }
290 }
291 exports.performCompilation = performCompilation;
292 function defaultGatherDiagnostics(program) {
293 var allDiagnostics = [];
294 function checkDiagnostics(diags) {
295 if (diags) {
296 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spreadArray([], tslib_1.__read(diags)));
297 return !hasErrors(diags);
298 }
299 return true;
300 }
301 var checkOtherDiagnostics = true;
302 // Check parameter diagnostics
303 checkOtherDiagnostics = checkOtherDiagnostics &&
304 checkDiagnostics(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(program.getTsOptionDiagnostics())), tslib_1.__read(program.getNgOptionDiagnostics())));
305 // Check syntactic diagnostics
306 checkOtherDiagnostics =
307 checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics());
308 // Check TypeScript semantic and Angular structure diagnostics
309 checkOtherDiagnostics =
310 checkOtherDiagnostics &&
311 checkDiagnostics(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(program.getTsSemanticDiagnostics())), tslib_1.__read(program.getNgStructuralDiagnostics())));
312 // Check Angular semantic diagnostics
313 checkOtherDiagnostics =
314 checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics());
315 return allDiagnostics;
316 }
317 exports.defaultGatherDiagnostics = defaultGatherDiagnostics;
318 function hasErrors(diags) {
319 return diags.some(function (d) { return d.category === ts.DiagnosticCategory.Error; });
320 }
321});
322//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"perform_compile.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/perform_compile.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\nimport {isSyntaxError, Position} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, AbsoluteFsPath, FileSystem, getFileSystem, ReadonlyFileSystem, relative, resolve} from '../src/ngtsc/file_system';\nimport {NgCompilerOptions} from './ngtsc/core/api';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport * as ng from './transformers/entry_points';\nimport {createMessageDiagnostic} from './transformers/util';\n\nexport type Diagnostics = ReadonlyArray<ts.Diagnostic|api.Diagnostic>;\n\nexport function filterErrorsAndWarnings(diagnostics: Diagnostics): Diagnostics {\n  return diagnostics.filter(d => d.category !== ts.DiagnosticCategory.Message);\n}\n\nconst defaultFormatHost: ts.FormatDiagnosticsHost = {\n  getCurrentDirectory: () => ts.sys.getCurrentDirectory(),\n  getCanonicalFileName: fileName => fileName,\n  getNewLine: () => ts.sys.newLine\n};\n\nfunction displayFileName(fileName: string, host: ts.FormatDiagnosticsHost): string {\n  return relative(\n      resolve(host.getCurrentDirectory()), resolve(host.getCanonicalFileName(fileName)));\n}\n\nexport function formatDiagnosticPosition(\n    position: Position, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  return `${displayFileName(position.fileName, host)}(${position.line + 1},${position.column + 1})`;\n}\n\nexport function flattenDiagnosticMessageChain(\n    chain: api.DiagnosticMessageChain, host: ts.FormatDiagnosticsHost = defaultFormatHost,\n    indent = 0): string {\n  const newLine = host.getNewLine();\n  let result = '';\n  if (indent) {\n    result += newLine;\n\n    for (let i = 0; i < indent; i++) {\n      result += '  ';\n    }\n  }\n  result += chain.messageText;\n\n  const position = chain.position;\n  // add position if available, and we are not at the depest frame\n  if (position && indent !== 0) {\n    result += ` at ${formatDiagnosticPosition(position, host)}`;\n  }\n\n  indent++;\n  if (chain.next) {\n    for (const kid of chain.next) {\n      result += flattenDiagnosticMessageChain(kid, host, indent);\n    }\n  }\n  return result;\n}\n\nexport function formatDiagnostic(\n    diagnostic: api.Diagnostic, host: ts.FormatDiagnosticsHost = defaultFormatHost) {\n  let result = '';\n  const newLine = host.getNewLine();\n  const span = diagnostic.span;\n  if (span) {\n    result += `${\n        formatDiagnosticPosition(\n            {fileName: span.start.file.url, line: span.start.line, column: span.start.col},\n            host)}: `;\n  } else if (diagnostic.position) {\n    result += `${formatDiagnosticPosition(diagnostic.position, host)}: `;\n  }\n  if (diagnostic.span && diagnostic.span.details) {\n    result += `${diagnostic.span.details}, ${diagnostic.messageText}${newLine}`;\n  } else if (diagnostic.chain) {\n    result += `${flattenDiagnosticMessageChain(diagnostic.chain, host)}.${newLine}`;\n  } else {\n    result += `${diagnostic.messageText}${newLine}`;\n  }\n  return result;\n}\n\nexport function formatDiagnostics(\n    diags: Diagnostics, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  if (diags && diags.length) {\n    return diags\n        .map(diagnostic => {\n          if (api.isTsDiagnostic(diagnostic)) {\n            return replaceTsWithNgInErrors(\n                ts.formatDiagnosticsWithColorAndContext([diagnostic], host));\n          } else {\n            return formatDiagnostic(diagnostic, host);\n          }\n        })\n        .join('');\n  } else {\n    return '';\n  }\n}\n\n/** Used to read configuration files. */\nexport type ConfigurationHost = Pick<\n    ReadonlyFileSystem, 'readFile'|'exists'|'lstat'|'resolve'|'join'|'dirname'|'extname'|'pwd'>;\n\nexport interface ParsedConfiguration {\n  project: string;\n  options: api.CompilerOptions;\n  rootNames: string[];\n  projectReferences?: readonly ts.ProjectReference[]|undefined;\n  emitFlags: api.EmitFlags;\n  errors: ts.Diagnostic[];\n}\n\nexport function calcProjectFileAndBasePath(\n    project: string, host: ConfigurationHost = getFileSystem()):\n    {projectFile: AbsoluteFsPath, basePath: AbsoluteFsPath} {\n  const absProject = host.resolve(project);\n  const projectIsDir = host.lstat(absProject).isDirectory();\n  const projectFile = projectIsDir ? host.join(absProject, 'tsconfig.json') : absProject;\n  const projectDir = projectIsDir ? absProject : host.dirname(absProject);\n  const basePath = host.resolve(projectDir);\n  return {projectFile, basePath};\n}\n\nexport function readConfiguration(\n    project: string, existingOptions?: api.CompilerOptions,\n    host: ConfigurationHost = getFileSystem()): ParsedConfiguration {\n  try {\n    const fs = getFileSystem();\n\n    const readConfigFile = (configFile: string) =>\n        ts.readConfigFile(configFile, file => host.readFile(host.resolve(file)));\n    const readAngularCompilerOptions =\n        (configFile: string, parentOptions: NgCompilerOptions = {}): NgCompilerOptions => {\n          const {config, error} = readConfigFile(configFile);\n\n          if (error) {\n            // Errors are handled later on by 'parseJsonConfigFileContent'\n            return parentOptions;\n          }\n\n          // we are only interested into merging 'angularCompilerOptions' as\n          // other options like 'compilerOptions' are merged by TS\n          const existingNgCompilerOptions = {...config.angularCompilerOptions, ...parentOptions};\n\n          if (config.extends && typeof config.extends === 'string') {\n            const extendedConfigPath = getExtendedConfigPath(\n                configFile, config.extends, host, fs,\n            );\n\n            if (extendedConfigPath !== null) {\n              // Call readAngularCompilerOptions recursively to merge NG Compiler options\n              return readAngularCompilerOptions(extendedConfigPath, existingNgCompilerOptions);\n            }\n          }\n\n          return existingNgCompilerOptions;\n        };\n\n    const {projectFile, basePath} = calcProjectFileAndBasePath(project, host);\n    const configFileName = host.resolve(host.pwd(), projectFile);\n    const {config, error} = readConfigFile(projectFile);\n    if (error) {\n      return {\n        project,\n        errors: [error],\n        rootNames: [],\n        options: {},\n        emitFlags: api.EmitFlags.Default\n      };\n    }\n    const existingCompilerOptions: api.CompilerOptions = {\n      genDir: basePath,\n      basePath,\n      ...readAngularCompilerOptions(configFileName),\n      ...existingOptions,\n    };\n\n    const parseConfigHost = createParseConfigHost(host, fs);\n    const {options, errors, fileNames: rootNames, projectReferences} =\n        ts.parseJsonConfigFileContent(\n            config, parseConfigHost, basePath, existingCompilerOptions, configFileName);\n\n    // Coerce to boolean as `enableIvy` can be `ngtsc|true|false|undefined` here.\n    options.enableIvy = !!(options.enableIvy ?? true);\n\n    let emitFlags = api.EmitFlags.Default;\n    if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {\n      emitFlags |= api.EmitFlags.Metadata;\n    }\n    if (options.skipTemplateCodegen) {\n      emitFlags = emitFlags & ~api.EmitFlags.Codegen;\n    }\n    return {project: projectFile, rootNames, projectReferences, options, errors, emitFlags};\n  } catch (e) {\n    const errors: ts.Diagnostic[] = [{\n      category: ts.DiagnosticCategory.Error,\n      messageText: e.stack,\n      file: undefined,\n      start: undefined,\n      length: undefined,\n      source: 'angular',\n      code: api.UNKNOWN_ERROR_CODE,\n    }];\n    return {project: '', errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default};\n  }\n}\n\nfunction createParseConfigHost(host: ConfigurationHost, fs = getFileSystem()): ts.ParseConfigHost {\n  return {\n    fileExists: host.exists.bind(host),\n    readDirectory: ts.sys.readDirectory,\n    readFile: host.readFile.bind(host),\n    useCaseSensitiveFileNames: fs.isCaseSensitive(),\n  };\n}\n\nfunction getExtendedConfigPath(\n    configFile: string, extendsValue: string, host: ConfigurationHost,\n    fs: FileSystem): AbsoluteFsPath|null {\n  const result = getExtendedConfigPathWorker(configFile, extendsValue, host, fs);\n  if (result !== null) {\n    return result;\n  }\n\n  // Try to resolve the paths with a json extension append a json extension to the file in case if\n  // it is missing and the resolution failed. This is to replicate TypeScript behaviour, see:\n  // https://github.com/microsoft/TypeScript/blob/294a5a7d784a5a95a8048ee990400979a6bc3a1c/src/compiler/commandLineParser.ts#L2806\n  return getExtendedConfigPathWorker(configFile, `${extendsValue}.json`, host, fs);\n}\n\nfunction getExtendedConfigPathWorker(\n    configFile: string, extendsValue: string, host: ConfigurationHost,\n    fs: FileSystem): AbsoluteFsPath|null {\n  if (extendsValue.startsWith('.') || fs.isRooted(extendsValue)) {\n    const extendedConfigPath = host.resolve(host.dirname(configFile), extendsValue);\n    if (host.exists(extendedConfigPath)) {\n      return extendedConfigPath;\n    }\n  } else {\n    const parseConfigHost = createParseConfigHost(host, fs);\n\n    // Path isn't a rooted or relative path, resolve like a module.\n    const {\n      resolvedModule,\n    } =\n        ts.nodeModuleNameResolver(\n            extendsValue, configFile,\n            {moduleResolution: ts.ModuleResolutionKind.NodeJs, resolveJsonModule: true},\n            parseConfigHost);\n    if (resolvedModule) {\n      return absoluteFrom(resolvedModule.resolvedFileName);\n    }\n  }\n\n  return null;\n}\n\nexport interface PerformCompilationResult {\n  diagnostics: Diagnostics;\n  program?: api.Program;\n  emitResult?: ts.EmitResult;\n}\n\nexport function exitCodeFromResult(diags: Diagnostics|undefined): number {\n  if (!diags || filterErrorsAndWarnings(diags).length === 0) {\n    // If we have a result and didn't get any errors, we succeeded.\n    return 0;\n  }\n\n  // Return 2 if any of the errors were unknown.\n  return diags.some(d => d.source === 'angular' && d.code === api.UNKNOWN_ERROR_CODE) ? 2 : 1;\n}\n\nexport function performCompilation({\n  rootNames,\n  options,\n  host,\n  oldProgram,\n  emitCallback,\n  mergeEmitResultsCallback,\n  gatherDiagnostics = defaultGatherDiagnostics,\n  customTransformers,\n  emitFlags = api.EmitFlags.Default,\n  modifiedResourceFiles = null\n}: {\n  rootNames: string[],\n  options: api.CompilerOptions,\n  host?: api.CompilerHost,\n  oldProgram?: api.Program,\n  emitCallback?: api.TsEmitCallback,\n  mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback,\n  gatherDiagnostics?: (program: api.Program) => Diagnostics,\n  customTransformers?: api.CustomTransformers,\n  emitFlags?: api.EmitFlags,\n  modifiedResourceFiles?: Set<string>| null,\n}): PerformCompilationResult {\n  let program: api.Program|undefined;\n  let emitResult: ts.EmitResult|undefined;\n  let allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n  try {\n    if (!host) {\n      host = ng.createCompilerHost({options});\n    }\n    if (modifiedResourceFiles) {\n      host.getModifiedResourceFiles = () => modifiedResourceFiles;\n    }\n\n    program = ng.createProgram({rootNames, host, options, oldProgram});\n\n    const beforeDiags = Date.now();\n    allDiagnostics.push(...gatherDiagnostics(program!));\n    if (options.diagnostics) {\n      const afterDiags = Date.now();\n      allDiagnostics.push(\n          createMessageDiagnostic(`Time for diagnostics: ${afterDiags - beforeDiags}ms.`));\n    }\n\n    if (!hasErrors(allDiagnostics)) {\n      emitResult =\n          program!.emit({emitCallback, mergeEmitResultsCallback, customTransformers, emitFlags});\n      allDiagnostics.push(...emitResult.diagnostics);\n      return {diagnostics: allDiagnostics, program, emitResult};\n    }\n    return {diagnostics: allDiagnostics, program};\n  } catch (e) {\n    let errMsg: string;\n    let code: number;\n    if (isSyntaxError(e)) {\n      // don't report the stack for syntax errors as they are well known errors.\n      errMsg = e.message;\n      code = api.DEFAULT_ERROR_CODE;\n    } else {\n      errMsg = e.stack;\n      // It is not a syntax error we might have a program with unknown state, discard it.\n      program = undefined;\n      code = api.UNKNOWN_ERROR_CODE;\n    }\n    allDiagnostics.push(\n        {category: ts.DiagnosticCategory.Error, messageText: errMsg, code, source: api.SOURCE});\n    return {diagnostics: allDiagnostics, program};\n  }\n}\nexport function defaultGatherDiagnostics(program: api.Program): Diagnostics {\n  const allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n\n  function checkDiagnostics(diags: Diagnostics|undefined) {\n    if (diags) {\n      allDiagnostics.push(...diags);\n      return !hasErrors(diags);\n    }\n    return true;\n  }\n\n  let checkOtherDiagnostics = true;\n  // Check parameter diagnostics\n  checkOtherDiagnostics = checkOtherDiagnostics &&\n      checkDiagnostics([...program.getTsOptionDiagnostics(), ...program.getNgOptionDiagnostics()]);\n\n  // Check syntactic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics() as Diagnostics);\n\n  // Check TypeScript semantic and Angular structure diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics &&\n      checkDiagnostics(\n          [...program.getTsSemanticDiagnostics(), ...program.getNgStructuralDiagnostics()]);\n\n  // Check Angular semantic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics() as Diagnostics);\n\n  return allDiagnostics;\n}\n\nfunction hasErrors(diags: Diagnostics) {\n  return diags.some(d => d.category === ts.DiagnosticCategory.Error);\n}\n"]}
Note: See TracBrowser for help on using the repository browser.