UNPKG

36.4 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google Inc. 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", "fs", "path", "typescript", "@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 var tslib_1 = require("tslib");
20 var compiler_1 = require("@angular/compiler");
21 var fs = require("fs");
22 var path = require("path");
23 var ts = require("typescript");
24 var api = require("@angular/compiler-cli/src/transformers/api");
25 var ng = require("@angular/compiler-cli/src/transformers/entry_points");
26 var util_1 = require("@angular/compiler-cli/src/transformers/util");
27 var TS_EXT = /\.ts$/;
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 path.relative(host.getCurrentDirectory(), 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) {
46 if (host === void 0) { host = defaultFormatHost; }
47 var result = chain.messageText;
48 var indent = 1;
49 var current = chain.next;
50 var newLine = host.getNewLine();
51 while (current) {
52 result += newLine;
53 for (var i = 0; i < indent; i++) {
54 result += ' ';
55 }
56 result += current.messageText;
57 var position = current.position;
58 if (position) {
59 result += " at " + formatDiagnosticPosition(position, host);
60 }
61 current = current.next;
62 indent++;
63 }
64 return result;
65 }
66 exports.flattenDiagnosticMessageChain = flattenDiagnosticMessageChain;
67 function formatDiagnostic(diagnostic, host) {
68 if (host === void 0) { host = defaultFormatHost; }
69 var result = '';
70 var newLine = host.getNewLine();
71 var span = diagnostic.span;
72 if (span) {
73 result += formatDiagnosticPosition({
74 fileName: span.start.file.url,
75 line: span.start.line,
76 column: span.start.col
77 }, host) + ": ";
78 }
79 else if (diagnostic.position) {
80 result += formatDiagnosticPosition(diagnostic.position, host) + ": ";
81 }
82 if (diagnostic.span && diagnostic.span.details) {
83 result += ": " + diagnostic.span.details + ", " + diagnostic.messageText + newLine;
84 }
85 else if (diagnostic.chain) {
86 result += flattenDiagnosticMessageChain(diagnostic.chain, host) + "." + newLine;
87 }
88 else {
89 result += ": " + diagnostic.messageText + newLine;
90 }
91 return result;
92 }
93 exports.formatDiagnostic = formatDiagnostic;
94 function formatDiagnostics(diags, host) {
95 if (host === void 0) { host = defaultFormatHost; }
96 if (diags && diags.length) {
97 return diags
98 .map(function (diagnostic) {
99 if (api.isTsDiagnostic(diagnostic)) {
100 return ts.formatDiagnostics([diagnostic], host);
101 }
102 else {
103 return formatDiagnostic(diagnostic, host);
104 }
105 })
106 .join('');
107 }
108 else {
109 return '';
110 }
111 }
112 exports.formatDiagnostics = formatDiagnostics;
113 function calcProjectFileAndBasePath(project) {
114 var projectIsDir = fs.lstatSync(project).isDirectory();
115 var projectFile = projectIsDir ? path.join(project, 'tsconfig.json') : project;
116 var projectDir = projectIsDir ? project : path.dirname(project);
117 var basePath = path.resolve(process.cwd(), projectDir);
118 return { projectFile: projectFile, basePath: basePath };
119 }
120 exports.calcProjectFileAndBasePath = calcProjectFileAndBasePath;
121 function createNgCompilerOptions(basePath, config, tsOptions) {
122 return tslib_1.__assign({}, tsOptions, config.angularCompilerOptions, { genDir: basePath, basePath: basePath });
123 }
124 exports.createNgCompilerOptions = createNgCompilerOptions;
125 function readConfiguration(project, existingOptions) {
126 try {
127 var _a = calcProjectFileAndBasePath(project), projectFile = _a.projectFile, basePath = _a.basePath;
128 var _b = ts.readConfigFile(projectFile, ts.sys.readFile), config = _b.config, error = _b.error;
129 if (error) {
130 return {
131 project: project,
132 errors: [error],
133 rootNames: [],
134 options: {},
135 emitFlags: api.EmitFlags.Default
136 };
137 }
138 var parseConfigHost = {
139 useCaseSensitiveFileNames: true,
140 fileExists: fs.existsSync,
141 readDirectory: ts.sys.readDirectory,
142 readFile: ts.sys.readFile
143 };
144 var parsed = ts.parseJsonConfigFileContent(config, parseConfigHost, basePath, existingOptions);
145 var rootNames = parsed.fileNames.map(function (f) { return path.normalize(f); });
146 var options = createNgCompilerOptions(basePath, config, parsed.options);
147 var emitFlags = api.EmitFlags.Default;
148 if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {
149 emitFlags |= api.EmitFlags.Metadata;
150 }
151 if (options.skipTemplateCodegen) {
152 emitFlags = emitFlags & ~api.EmitFlags.Codegen;
153 }
154 return { project: projectFile, rootNames: rootNames, options: options, errors: parsed.errors, emitFlags: emitFlags };
155 }
156 catch (e) {
157 var errors = [{
158 category: ts.DiagnosticCategory.Error,
159 messageText: e.stack,
160 source: api.SOURCE,
161 code: api.UNKNOWN_ERROR_CODE
162 }];
163 return { project: '', errors: errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default };
164 }
165 }
166 exports.readConfiguration = readConfiguration;
167 function exitCodeFromResult(diags) {
168 if (!diags || filterErrorsAndWarnings(diags).length === 0) {
169 // If we have a result and didn't get any errors, we succeeded.
170 return 0;
171 }
172 // Return 2 if any of the errors were unknown.
173 return diags.some(function (d) { return d.source === 'angular' && d.code === api.UNKNOWN_ERROR_CODE; }) ? 2 : 1;
174 }
175 exports.exitCodeFromResult = exitCodeFromResult;
176 function performCompilation(_a) {
177 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;
178 var program;
179 var emitResult;
180 var allDiagnostics = [];
181 try {
182 if (!host) {
183 host = ng.createCompilerHost({ options: options });
184 }
185 program = ng.createProgram({ rootNames: rootNames, host: host, options: options, oldProgram: oldProgram });
186 var beforeDiags = Date.now();
187 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spread(gatherDiagnostics(program)));
188 if (options.diagnostics) {
189 var afterDiags = Date.now();
190 allDiagnostics.push(util_1.createMessageDiagnostic("Time for diagnostics: " + (afterDiags - beforeDiags) + "ms."));
191 }
192 if (!hasErrors(allDiagnostics)) {
193 emitResult =
194 program.emit({ emitCallback: emitCallback, mergeEmitResultsCallback: mergeEmitResultsCallback, customTransformers: customTransformers, emitFlags: emitFlags });
195 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spread(emitResult.diagnostics));
196 return { diagnostics: allDiagnostics, program: program, emitResult: emitResult };
197 }
198 return { diagnostics: allDiagnostics, program: program };
199 }
200 catch (e) {
201 var errMsg = void 0;
202 var code = void 0;
203 if (compiler_1.isSyntaxError(e)) {
204 // don't report the stack for syntax errors as they are well known errors.
205 errMsg = e.message;
206 code = api.DEFAULT_ERROR_CODE;
207 }
208 else {
209 errMsg = e.stack;
210 // It is not a syntax error we might have a program with unknown state, discard it.
211 program = undefined;
212 code = api.UNKNOWN_ERROR_CODE;
213 }
214 allDiagnostics.push({ category: ts.DiagnosticCategory.Error, messageText: errMsg, code: code, source: api.SOURCE });
215 return { diagnostics: allDiagnostics, program: program };
216 }
217 }
218 exports.performCompilation = performCompilation;
219 function defaultGatherDiagnostics(program) {
220 var allDiagnostics = [];
221 function checkDiagnostics(diags) {
222 if (diags) {
223 allDiagnostics.push.apply(allDiagnostics, tslib_1.__spread(diags));
224 return !hasErrors(diags);
225 }
226 return true;
227 }
228 var checkOtherDiagnostics = true;
229 // Check parameter diagnostics
230 checkOtherDiagnostics = checkOtherDiagnostics &&
231 checkDiagnostics(tslib_1.__spread(program.getTsOptionDiagnostics(), program.getNgOptionDiagnostics()));
232 // Check syntactic diagnostics
233 checkOtherDiagnostics =
234 checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics());
235 // Check TypeScript semantic and Angular structure diagnostics
236 checkOtherDiagnostics =
237 checkOtherDiagnostics &&
238 checkDiagnostics(tslib_1.__spread(program.getTsSemanticDiagnostics(), program.getNgStructuralDiagnostics()));
239 // Check Angular semantic diagnostics
240 checkOtherDiagnostics =
241 checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics());
242 return allDiagnostics;
243 }
244 function hasErrors(diags) {
245 return diags.some(function (d) { return d.category === ts.DiagnosticCategory.Error; });
246 }
247});
248//# 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 Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Position, isSyntaxError, syntaxError} from '@angular/compiler';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport * as api from './transformers/api';\nimport * as ng from './transformers/entry_points';\nimport {createMessageDiagnostic} from './transformers/util';\n\nconst TS_EXT = /\\.ts$/;\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 path.relative(host.getCurrentDirectory(), 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): string {\n  let result = chain.messageText;\n  let indent = 1;\n  let current = chain.next;\n  const newLine = host.getNewLine();\n  while (current) {\n    result += newLine;\n    for (let i = 0; i < indent; i++) {\n      result += '  ';\n    }\n    result += current.messageText;\n    const position = current.position;\n    if (position) {\n      result += ` at ${formatDiagnosticPosition(position, host)}`;\n    }\n    current = current.next;\n    indent++;\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 += `${formatDiagnosticPosition({\n      fileName: span.start.file.url,\n      line: span.start.line,\n      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 ts.formatDiagnostics([diagnostic], host);\n          } else {\n            return formatDiagnostic(diagnostic, host);\n          }\n        })\n        .join('');\n  } else {\n    return '';\n  }\n}\n\nexport interface ParsedConfiguration {\n  project: string;\n  options: api.CompilerOptions;\n  rootNames: string[];\n  emitFlags: api.EmitFlags;\n  errors: Diagnostics;\n}\n\nexport function calcProjectFileAndBasePath(project: string):\n    {projectFile: string, basePath: string} {\n  const projectIsDir = fs.lstatSync(project).isDirectory();\n  const projectFile = projectIsDir ? path.join(project, 'tsconfig.json') : project;\n  const projectDir = projectIsDir ? project : path.dirname(project);\n  const basePath = path.resolve(process.cwd(), projectDir);\n  return {projectFile, basePath};\n}\n\nexport function createNgCompilerOptions(\n    basePath: string, config: any, tsOptions: ts.CompilerOptions): api.CompilerOptions {\n  return {...tsOptions, ...config.angularCompilerOptions, genDir: basePath, basePath};\n}\n\nexport function readConfiguration(\n    project: string, existingOptions?: ts.CompilerOptions): ParsedConfiguration {\n  try {\n    const {projectFile, basePath} = calcProjectFileAndBasePath(project);\n\n    let {config, error} = ts.readConfigFile(projectFile, ts.sys.readFile);\n\n    if (error) {\n      return {\n        project,\n        errors: [error],\n        rootNames: [],\n        options: {},\n        emitFlags: api.EmitFlags.Default\n      };\n    }\n    const parseConfigHost = {\n      useCaseSensitiveFileNames: true,\n      fileExists: fs.existsSync,\n      readDirectory: ts.sys.readDirectory,\n      readFile: ts.sys.readFile\n    };\n    const parsed =\n        ts.parseJsonConfigFileContent(config, parseConfigHost, basePath, existingOptions);\n    const rootNames = parsed.fileNames.map(f => path.normalize(f));\n\n    const options = createNgCompilerOptions(basePath, config, parsed.options);\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, options, errors: parsed.errors, emitFlags};\n  } catch (e) {\n    const errors: Diagnostics = [{\n      category: ts.DiagnosticCategory.Error,\n      messageText: e.stack,\n      source: api.SOURCE,\n      code: api.UNKNOWN_ERROR_CODE\n    }];\n    return {project: '', errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default};\n  }\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({rootNames, options, host, oldProgram, emitCallback,\n                                    mergeEmitResultsCallback,\n                                    gatherDiagnostics = defaultGatherDiagnostics,\n                                    customTransformers, emitFlags = api.EmitFlags.Default}: {\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}): 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\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}\nfunction 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"]}
\No newline at end of file