UNPKG

30.4 kBJavaScriptView Raw
1#!/usr/bin/env node
2(function (factory) {
3 if (typeof module === "object" && typeof module.exports === "object") {
4 var v = factory(require, exports);
5 if (v !== undefined) module.exports = v;
6 }
7 else if (typeof define === "function" && define.amd) {
8 define("@angular/compiler-cli/src/main", ["require", "exports", "reflect-metadata", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/transformers/api", "@angular/compiler-cli/src/transformers/util", "@angular/compiler-cli/src/perform_compile", "@angular/compiler-cli/src/perform_watch"], factory);
9 }
10})(function (require, exports) {
11 "use strict";
12 Object.defineProperty(exports, "__esModule", { value: true });
13 require("reflect-metadata");
14 const ts = require("typescript");
15 const diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
16 const api = require("@angular/compiler-cli/src/transformers/api");
17 const util_1 = require("@angular/compiler-cli/src/transformers/util");
18 const perform_compile_1 = require("@angular/compiler-cli/src/perform_compile");
19 const perform_watch_1 = require("@angular/compiler-cli/src/perform_watch");
20 function main(args, consoleError = console.error, config, customTransformers) {
21 let { project, rootNames, options, errors: configErrors, watch, emitFlags } = config || readNgcCommandLineAndConfiguration(args);
22 if (configErrors.length) {
23 return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);
24 }
25 if (watch) {
26 const result = watchMode(project, options, consoleError);
27 return reportErrorsAndExit(result.firstCompileResult, options, consoleError);
28 }
29 const { diagnostics: compileDiags } = perform_compile_1.performCompilation({
30 rootNames,
31 options,
32 emitFlags,
33 emitCallback: createEmitCallback(options), customTransformers
34 });
35 return reportErrorsAndExit(compileDiags, options, consoleError);
36 }
37 exports.main = main;
38 function mainDiagnosticsForTest(args, config) {
39 let { project, rootNames, options, errors: configErrors, watch, emitFlags } = config || readNgcCommandLineAndConfiguration(args);
40 if (configErrors.length) {
41 return configErrors;
42 }
43 const { diagnostics: compileDiags } = perform_compile_1.performCompilation({ rootNames, options, emitFlags, emitCallback: createEmitCallback(options) });
44 return compileDiags;
45 }
46 exports.mainDiagnosticsForTest = mainDiagnosticsForTest;
47 function createEmitCallback(options) {
48 const transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&
49 options.annotationsAs !== 'decorators';
50 const transformTypesToClosure = options.annotateForClosureCompiler;
51 if (!transformDecorators && !transformTypesToClosure) {
52 return undefined;
53 }
54 if (transformDecorators) {
55 // This is needed as a workaround for https://github.com/angular/tsickle/issues/635
56 // Otherwise tsickle might emit references to non imported values
57 // as TypeScript elided the import.
58 options.emitDecoratorMetadata = true;
59 }
60 const tsickleHost = {
61 shouldSkipTsickleProcessing: (fileName) => /\.d\.ts$/.test(fileName) || util_1.GENERATED_FILES.test(fileName),
62 pathToModuleName: (context, importPath) => '',
63 shouldIgnoreWarningsForPath: (filePath) => false,
64 fileNameToModuleId: (fileName) => fileName,
65 googmodule: false,
66 untyped: true,
67 convertIndexImportShorthand: false, transformDecorators, transformTypesToClosure,
68 };
69 if (options.annotateForClosureCompiler || options.annotationsAs === 'static fields') {
70 return ({ program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers = {}, host, options }) =>
71 // tslint:disable-next-line:no-require-imports only depend on tsickle if requested
72 require('tsickle').emitWithTsickle(program, Object.assign({}, tsickleHost, { options, host }), host, options, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, {
73 beforeTs: customTransformers.before,
74 afterTs: customTransformers.after,
75 });
76 }
77 else {
78 return ({ program, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, customTransformers = {}, }) => program.emit(targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, { after: customTransformers.after, before: customTransformers.before });
79 }
80 }
81 function readNgcCommandLineAndConfiguration(args) {
82 const options = {};
83 const parsedArgs = require('minimist')(args);
84 if (parsedArgs.i18nFile)
85 options.i18nInFile = parsedArgs.i18nFile;
86 if (parsedArgs.i18nFormat)
87 options.i18nInFormat = parsedArgs.i18nFormat;
88 if (parsedArgs.locale)
89 options.i18nInLocale = parsedArgs.locale;
90 const mt = parsedArgs.missingTranslation;
91 if (mt === 'error' || mt === 'warning' || mt === 'ignore') {
92 options.i18nInMissingTranslations = mt;
93 }
94 const config = readCommandLineAndConfiguration(args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);
95 const watch = parsedArgs.w || parsedArgs.watch;
96 return Object.assign({}, config, { watch });
97 }
98 function readCommandLineAndConfiguration(args, existingOptions = {}, ngCmdLineOptions = []) {
99 let cmdConfig = ts.parseCommandLine(args);
100 const project = cmdConfig.options.project || '.';
101 const cmdErrors = cmdConfig.errors.filter(e => {
102 if (typeof e.messageText === 'string') {
103 const msg = e.messageText;
104 return !ngCmdLineOptions.some(o => msg.indexOf(o) >= 0);
105 }
106 return true;
107 });
108 if (cmdErrors.length) {
109 return {
110 project,
111 rootNames: [],
112 options: cmdConfig.options,
113 errors: cmdErrors,
114 emitFlags: api.EmitFlags.Default
115 };
116 }
117 const allDiagnostics = [];
118 const config = perform_compile_1.readConfiguration(project, cmdConfig.options);
119 const options = Object.assign({}, config.options, existingOptions);
120 if (options.locale) {
121 options.i18nInLocale = options.locale;
122 }
123 return {
124 project,
125 rootNames: config.rootNames, options,
126 errors: config.errors,
127 emitFlags: config.emitFlags
128 };
129 }
130 exports.readCommandLineAndConfiguration = readCommandLineAndConfiguration;
131 function getFormatDiagnosticsHost(options) {
132 const basePath = options ? options.basePath : undefined;
133 return {
134 getCurrentDirectory: () => basePath || ts.sys.getCurrentDirectory(),
135 // We need to normalize the path separators here because by default, TypeScript
136 // compiler hosts use posix canonical paths. In order to print consistent diagnostics,
137 // we also normalize the paths.
138 getCanonicalFileName: fileName => fileName.replace(/\\/g, '/'),
139 getNewLine: () => {
140 // Manually determine the proper new line string based on the passed compiler
141 // options. There is no public TypeScript function that returns the corresponding
142 // new line string. see: https://github.com/Microsoft/TypeScript/issues/29581
143 if (options && options.newLine !== undefined) {
144 return options.newLine === ts.NewLineKind.LineFeed ? '\n' : '\r\n';
145 }
146 return ts.sys.newLine;
147 },
148 };
149 }
150 function reportErrorsAndExit(allDiagnostics, options, consoleError = console.error) {
151 const errorsAndWarnings = perform_compile_1.filterErrorsAndWarnings(allDiagnostics);
152 if (errorsAndWarnings.length) {
153 const formatHost = getFormatDiagnosticsHost(options);
154 if (options && (options.enableIvy === true || options.enableIvy === 'ngtsc')) {
155 const ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);
156 const tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);
157 consoleError(diagnostics_1.replaceTsWithNgInErrors(ts.formatDiagnosticsWithColorAndContext(tsDiagnostics, formatHost)));
158 consoleError(perform_compile_1.formatDiagnostics(ngDiagnostics, formatHost));
159 }
160 else {
161 consoleError(perform_compile_1.formatDiagnostics(errorsAndWarnings, formatHost));
162 }
163 }
164 return perform_compile_1.exitCodeFromResult(allDiagnostics);
165 }
166 function watchMode(project, options, consoleError) {
167 return perform_watch_1.performWatchCompilation(perform_watch_1.createPerformWatchHost(project, diagnostics => {
168 consoleError(perform_compile_1.formatDiagnostics(diagnostics, getFormatDiagnosticsHost(options)));
169 }, options, options => createEmitCallback(options)));
170 }
171 exports.watchMode = watchMode;
172 // CLI entry point
173 if (require.main === module) {
174 const args = process.argv.slice(2);
175 process.exitCode = main(args);
176 }
177});
178//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/main.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\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\n// Must be imported first, because Angular decorators throw on load.\nimport 'reflect-metadata';\n\nimport * as ts from 'typescript';\nimport * as tsickle from 'tsickle';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport {GENERATED_FILES} from './transformers/util';\n\nimport {exitCodeFromResult, performCompilation, readConfiguration, formatDiagnostics, Diagnostics, ParsedConfiguration, PerformCompilationResult, filterErrorsAndWarnings} from './perform_compile';\nimport {performWatchCompilation, createPerformWatchHost} from './perform_watch';\n\nexport function main(\n    args: string[], consoleError: (s: string) => void = console.error,\n    config?: NgcParsedConfiguration, customTransformers?: api.CustomTransformers): number {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);\n  }\n  if (watch) {\n    const result = watchMode(project, options, consoleError);\n    return reportErrorsAndExit(result.firstCompileResult, options, consoleError);\n  }\n  const {diagnostics: compileDiags} = performCompilation({\n    rootNames,\n    options,\n    emitFlags,\n    emitCallback: createEmitCallback(options), customTransformers\n  });\n  return reportErrorsAndExit(compileDiags, options, consoleError);\n}\n\nexport function mainDiagnosticsForTest(\n    args: string[], config?: NgcParsedConfiguration): ReadonlyArray<ts.Diagnostic|api.Diagnostic> {\n  let {project, rootNames, options, errors: configErrors, watch, emitFlags} =\n      config || readNgcCommandLineAndConfiguration(args);\n  if (configErrors.length) {\n    return configErrors;\n  }\n  const {diagnostics: compileDiags} = performCompilation(\n      {rootNames, options, emitFlags, emitCallback: createEmitCallback(options)});\n  return compileDiags;\n}\n\nfunction createEmitCallback(options: api.CompilerOptions): api.TsEmitCallback|undefined {\n  const transformDecorators = options.enableIvy !== 'ngtsc' && options.enableIvy !== 'tsc' &&\n      options.annotationsAs !== 'decorators';\n  const transformTypesToClosure = options.annotateForClosureCompiler;\n  if (!transformDecorators && !transformTypesToClosure) {\n    return undefined;\n  }\n  if (transformDecorators) {\n    // This is needed as a workaround for https://github.com/angular/tsickle/issues/635\n    // Otherwise tsickle might emit references to non imported values\n    // as TypeScript elided the import.\n    options.emitDecoratorMetadata = true;\n  }\n  const tsickleHost: Pick<\n      tsickle.TsickleHost, 'shouldSkipTsickleProcessing'|'pathToModuleName'|\n      'shouldIgnoreWarningsForPath'|'fileNameToModuleId'|'googmodule'|'untyped'|\n      'convertIndexImportShorthand'|'transformDecorators'|'transformTypesToClosure'> = {\n    shouldSkipTsickleProcessing: (fileName) =>\n                                     /\\.d\\.ts$/.test(fileName) || GENERATED_FILES.test(fileName),\n    pathToModuleName: (context, importPath) => '',\n    shouldIgnoreWarningsForPath: (filePath) => false,\n    fileNameToModuleId: (fileName) => fileName,\n    googmodule: false,\n    untyped: true,\n    convertIndexImportShorthand: false, transformDecorators, transformTypesToClosure,\n  };\n\n  if (options.annotateForClosureCompiler || options.annotationsAs === 'static fields') {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n             host,\n             options\n           }) =>\n               // tslint:disable-next-line:no-require-imports only depend on tsickle if requested\n        require('tsickle').emitWithTsickle(\n            program, {...tsickleHost, options, host}, host, options, targetSourceFile, writeFile,\n            cancellationToken, emitOnlyDtsFiles, {\n              beforeTs: customTransformers.before,\n              afterTs: customTransformers.after,\n            });\n  } else {\n    return ({\n             program,\n             targetSourceFile,\n             writeFile,\n             cancellationToken,\n             emitOnlyDtsFiles,\n             customTransformers = {},\n           }) =>\n               program.emit(\n                   targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles,\n                   {after: customTransformers.after, before: customTransformers.before});\n  }\n}\n\nexport interface NgcParsedConfiguration extends ParsedConfiguration { watch?: boolean; }\n\nfunction readNgcCommandLineAndConfiguration(args: string[]): NgcParsedConfiguration {\n  const options: api.CompilerOptions = {};\n  const parsedArgs = require('minimist')(args);\n  if (parsedArgs.i18nFile) options.i18nInFile = parsedArgs.i18nFile;\n  if (parsedArgs.i18nFormat) options.i18nInFormat = parsedArgs.i18nFormat;\n  if (parsedArgs.locale) options.i18nInLocale = parsedArgs.locale;\n  const mt = parsedArgs.missingTranslation;\n  if (mt === 'error' || mt === 'warning' || mt === 'ignore') {\n    options.i18nInMissingTranslations = mt;\n  }\n  const config = readCommandLineAndConfiguration(\n      args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);\n  const watch = parsedArgs.w || parsedArgs.watch;\n  return {...config, watch};\n}\n\nexport function readCommandLineAndConfiguration(\n    args: string[], existingOptions: api.CompilerOptions = {},\n    ngCmdLineOptions: string[] = []): ParsedConfiguration {\n  let cmdConfig = ts.parseCommandLine(args);\n  const project = cmdConfig.options.project || '.';\n  const cmdErrors = cmdConfig.errors.filter(e => {\n    if (typeof e.messageText === 'string') {\n      const msg = e.messageText;\n      return !ngCmdLineOptions.some(o => msg.indexOf(o) >= 0);\n    }\n    return true;\n  });\n  if (cmdErrors.length) {\n    return {\n      project,\n      rootNames: [],\n      options: cmdConfig.options,\n      errors: cmdErrors,\n      emitFlags: api.EmitFlags.Default\n    };\n  }\n  const allDiagnostics: Diagnostics = [];\n  const config = readConfiguration(project, cmdConfig.options);\n  const options = {...config.options, ...existingOptions};\n  if (options.locale) {\n    options.i18nInLocale = options.locale;\n  }\n  return {\n    project,\n    rootNames: config.rootNames, options,\n    errors: config.errors,\n    emitFlags: config.emitFlags\n  };\n}\n\nfunction getFormatDiagnosticsHost(options?: api.CompilerOptions): ts.FormatDiagnosticsHost {\n  const basePath = options ? options.basePath : undefined;\n  return {\n    getCurrentDirectory: () => basePath || ts.sys.getCurrentDirectory(),\n    // We need to normalize the path separators here because by default, TypeScript\n    // compiler hosts use posix canonical paths. In order to print consistent diagnostics,\n    // we also normalize the paths.\n    getCanonicalFileName: fileName => fileName.replace(/\\\\/g, '/'),\n    getNewLine: () => {\n      // Manually determine the proper new line string based on the passed compiler\n      // options. There is no public TypeScript function that returns the corresponding\n      // new line string. see: https://github.com/Microsoft/TypeScript/issues/29581\n      if (options && options.newLine !== undefined) {\n        return options.newLine === ts.NewLineKind.LineFeed ? '\\n' : '\\r\\n';\n      }\n      return ts.sys.newLine;\n    },\n  };\n}\n\nfunction reportErrorsAndExit(\n    allDiagnostics: Diagnostics, options?: api.CompilerOptions,\n    consoleError: (s: string) => void = console.error): number {\n  const errorsAndWarnings = filterErrorsAndWarnings(allDiagnostics);\n  if (errorsAndWarnings.length) {\n    const formatHost = getFormatDiagnosticsHost(options);\n    if (options && (options.enableIvy === true || options.enableIvy === 'ngtsc')) {\n      const ngDiagnostics = errorsAndWarnings.filter(api.isNgDiagnostic);\n      const tsDiagnostics = errorsAndWarnings.filter(api.isTsDiagnostic);\n      consoleError(replaceTsWithNgInErrors(\n          ts.formatDiagnosticsWithColorAndContext(tsDiagnostics, formatHost)));\n      consoleError(formatDiagnostics(ngDiagnostics, formatHost));\n    } else {\n      consoleError(formatDiagnostics(errorsAndWarnings, formatHost));\n    }\n  }\n  return exitCodeFromResult(allDiagnostics);\n}\n\nexport function watchMode(\n    project: string, options: api.CompilerOptions, consoleError: (s: string) => void) {\n  return performWatchCompilation(createPerformWatchHost(project, diagnostics => {\n    consoleError(formatDiagnostics(diagnostics, getFormatDiagnosticsHost(options)));\n  }, options, options => createEmitCallback(options)));\n}\n\n// CLI entry point\nif (require.main === module) {\n  const args = process.argv.slice(2);\n  process.exitCode = main(args);\n}\n"]}
\No newline at end of file