UNPKG

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