UNPKG

23.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", "tslib", "reflect-metadata", "typescript", "tsickle/src/tsickle", "@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 var tslib_1 = require("tslib");
14 require("reflect-metadata");
15 var ts = require("typescript");
16 var tsickle = require("tsickle/src/tsickle");
17 var api = require("@angular/compiler-cli/src/transformers/api");
18 var util_1 = require("@angular/compiler-cli/src/transformers/util");
19 var perform_compile_1 = require("@angular/compiler-cli/src/perform_compile");
20 var perform_watch_1 = require("@angular/compiler-cli/src/perform_watch");
21 function main(args, consoleError, config) {
22 if (consoleError === void 0) { consoleError = console.error; }
23 var _a = config || readNgcCommandLineAndConfiguration(args), project = _a.project, rootNames = _a.rootNames, options = _a.options, configErrors = _a.errors, watch = _a.watch, emitFlags = _a.emitFlags;
24 if (configErrors.length) {
25 return reportErrorsAndExit(configErrors, /*options*/ undefined, consoleError);
26 }
27 if (watch) {
28 var result = watchMode(project, options, consoleError);
29 return reportErrorsAndExit(result.firstCompileResult, options, consoleError);
30 }
31 var compileDiags = perform_compile_1.performCompilation({ rootNames: rootNames, options: options, emitFlags: emitFlags, emitCallback: createEmitCallback(options) }).diagnostics;
32 return reportErrorsAndExit(compileDiags, options, consoleError);
33 }
34 exports.main = main;
35 function createEmitCallback(options) {
36 var transformDecorators = options.annotationsAs !== 'decorators';
37 var transformTypesToClosure = options.annotateForClosureCompiler;
38 if (!transformDecorators && !transformTypesToClosure) {
39 return undefined;
40 }
41 if (transformDecorators) {
42 // This is needed as a workaround for https://github.com/angular/tsickle/issues/635
43 // Otherwise tsickle might emit references to non imported values
44 // as TypeScript elided the import.
45 options.emitDecoratorMetadata = true;
46 }
47 var tsickleHost = {
48 shouldSkipTsickleProcessing: function (fileName) {
49 return /\.d\.ts$/.test(fileName) || util_1.GENERATED_FILES.test(fileName);
50 },
51 pathToModuleName: function (context, importPath) { return ''; },
52 shouldIgnoreWarningsForPath: function (filePath) { return false; },
53 fileNameToModuleId: function (fileName) { return fileName; },
54 googmodule: false,
55 untyped: true,
56 convertIndexImportShorthand: false, transformDecorators: transformDecorators, transformTypesToClosure: transformTypesToClosure,
57 };
58 return function (_a) {
59 var program = _a.program, targetSourceFile = _a.targetSourceFile, writeFile = _a.writeFile, cancellationToken = _a.cancellationToken, emitOnlyDtsFiles = _a.emitOnlyDtsFiles, _b = _a.customTransformers, customTransformers = _b === void 0 ? {} : _b, host = _a.host, options = _a.options;
60 return tsickle.emitWithTsickle(program, tslib_1.__assign({}, tsickleHost, { options: options, host: host }), host, options, targetSourceFile, writeFile, cancellationToken, emitOnlyDtsFiles, {
61 beforeTs: customTransformers.before,
62 afterTs: customTransformers.after,
63 });
64 };
65 }
66 function readNgcCommandLineAndConfiguration(args) {
67 var options = {};
68 var parsedArgs = require('minimist')(args);
69 if (parsedArgs.i18nFile)
70 options.i18nInFile = parsedArgs.i18nFile;
71 if (parsedArgs.i18nFormat)
72 options.i18nInFormat = parsedArgs.i18nFormat;
73 if (parsedArgs.locale)
74 options.i18nInLocale = parsedArgs.locale;
75 var mt = parsedArgs.missingTranslation;
76 if (mt === 'error' || mt === 'warning' || mt === 'ignore') {
77 options.i18nInMissingTranslations = mt;
78 }
79 var config = readCommandLineAndConfiguration(args, options, ['i18nFile', 'i18nFormat', 'locale', 'missingTranslation', 'watch']);
80 var watch = parsedArgs.w || parsedArgs.watch;
81 return tslib_1.__assign({}, config, { watch: watch });
82 }
83 function readCommandLineAndConfiguration(args, existingOptions, ngCmdLineOptions) {
84 if (existingOptions === void 0) { existingOptions = {}; }
85 if (ngCmdLineOptions === void 0) { ngCmdLineOptions = []; }
86 var cmdConfig = ts.parseCommandLine(args);
87 var project = cmdConfig.options.project || '.';
88 var cmdErrors = cmdConfig.errors.filter(function (e) {
89 if (typeof e.messageText === 'string') {
90 var msg_1 = e.messageText;
91 return !ngCmdLineOptions.some(function (o) { return msg_1.indexOf(o) >= 0; });
92 }
93 return true;
94 });
95 if (cmdErrors.length) {
96 return {
97 project: project,
98 rootNames: [],
99 options: cmdConfig.options,
100 errors: cmdErrors,
101 emitFlags: api.EmitFlags.Default
102 };
103 }
104 var allDiagnostics = [];
105 var config = perform_compile_1.readConfiguration(project, cmdConfig.options);
106 var options = tslib_1.__assign({}, config.options, existingOptions);
107 if (options.locale) {
108 options.i18nInLocale = options.locale;
109 }
110 return {
111 project: project,
112 rootNames: config.rootNames, options: options,
113 errors: config.errors,
114 emitFlags: config.emitFlags
115 };
116 }
117 exports.readCommandLineAndConfiguration = readCommandLineAndConfiguration;
118 function reportErrorsAndExit(allDiagnostics, options, consoleError) {
119 if (consoleError === void 0) { consoleError = console.error; }
120 var errorsAndWarnings = perform_compile_1.filterErrorsAndWarnings(allDiagnostics);
121 if (errorsAndWarnings.length) {
122 var currentDir_1 = options ? options.basePath : undefined;
123 var formatHost = {
124 getCurrentDirectory: function () { return currentDir_1 || ts.sys.getCurrentDirectory(); },
125 getCanonicalFileName: function (fileName) { return fileName; },
126 getNewLine: function () { return ts.sys.newLine; }
127 };
128 consoleError(perform_compile_1.formatDiagnostics(errorsAndWarnings, formatHost));
129 }
130 return perform_compile_1.exitCodeFromResult(allDiagnostics);
131 }
132 function watchMode(project, options, consoleError) {
133 return perform_watch_1.performWatchCompilation(perform_watch_1.createPerformWatchHost(project, function (diagnostics) {
134 consoleError(perform_compile_1.formatDiagnostics(diagnostics));
135 }, options, function (options) { return createEmitCallback(options); }));
136 }
137 exports.watchMode = watchMode;
138 // CLI entry point
139 if (require.main === module) {
140 var args = process.argv.slice(2);
141 process.exitCode = main(args);
142 }
143});
144//# 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 fs from 'fs';\nimport * as path from 'path';\nimport * as tsickle from 'tsickle';\nimport * as api from './transformers/api';\nimport * as ngc from './transformers/entry_points';\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): 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, options, emitFlags, emitCallback: createEmitCallback(options)});\n  return reportErrorsAndExit(compileDiags, options, consoleError);\n}\n\n\nfunction createEmitCallback(options: api.CompilerOptions): api.TsEmitCallback|undefined {\n  const transformDecorators = 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  return ({\n           program,\n           targetSourceFile,\n           writeFile,\n           cancellationToken,\n           emitOnlyDtsFiles,\n           customTransformers = {},\n           host,\n           options\n         }) =>\n             tsickle.emitWithTsickle(\n                 program, {...tsickleHost, options, host}, host, options, targetSourceFile,\n                 writeFile, cancellationToken, emitOnlyDtsFiles, {\n                   beforeTs: customTransformers.before,\n                   afterTs: customTransformers.after,\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 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    let currentDir = options ? options.basePath : undefined;\n    const formatHost: ts.FormatDiagnosticsHost = {\n      getCurrentDirectory: () => currentDir || ts.sys.getCurrentDirectory(),\n      getCanonicalFileName: fileName => fileName,\n      getNewLine: () => ts.sys.newLine\n    };\n    consoleError(formatDiagnostics(errorsAndWarnings, formatHost));\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));\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