1 | (function (factory) {
|
---|
2 | if (typeof module === "object" && typeof module.exports === "object") {
|
---|
3 | var v = factory(require, exports);
|
---|
4 | if (v !== undefined) module.exports = v;
|
---|
5 | }
|
---|
6 | else if (typeof define === "function" && define.amd) {
|
---|
7 | define("@angular/compiler-cli/ngcc/src/rendering/renderer", ["require", "exports", "tslib", "@angular/compiler", "magic-string", "@angular/compiler-cli/src/ngtsc/translator", "@angular/compiler-cli/ngcc/src/constants", "@angular/compiler-cli/ngcc/src/rendering/rendering_formatter", "@angular/compiler-cli/ngcc/src/rendering/source_maps", "@angular/compiler-cli/ngcc/src/rendering/utils"], factory);
|
---|
8 | }
|
---|
9 | })(function (require, exports) {
|
---|
10 | "use strict";
|
---|
11 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
12 | exports.renderConstantPool = exports.Renderer = void 0;
|
---|
13 | var tslib_1 = require("tslib");
|
---|
14 | /**
|
---|
15 | * @license
|
---|
16 | * Copyright Google LLC All Rights Reserved.
|
---|
17 | *
|
---|
18 | * Use of this source code is governed by an MIT-style license that can be
|
---|
19 | * found in the LICENSE file at https://angular.io/license
|
---|
20 | */
|
---|
21 | var compiler_1 = require("@angular/compiler");
|
---|
22 | var magic_string_1 = require("magic-string");
|
---|
23 | var translator_1 = require("@angular/compiler-cli/src/ngtsc/translator");
|
---|
24 | var constants_1 = require("@angular/compiler-cli/ngcc/src/constants");
|
---|
25 | var rendering_formatter_1 = require("@angular/compiler-cli/ngcc/src/rendering/rendering_formatter");
|
---|
26 | var source_maps_1 = require("@angular/compiler-cli/ngcc/src/rendering/source_maps");
|
---|
27 | var utils_1 = require("@angular/compiler-cli/ngcc/src/rendering/utils");
|
---|
28 | /**
|
---|
29 | * A base-class for rendering an `AnalyzedFile`.
|
---|
30 | *
|
---|
31 | * Package formats have output files that must be rendered differently. Concrete sub-classes must
|
---|
32 | * implement the `addImports`, `addDefinitions` and `removeDecorators` abstract methods.
|
---|
33 | */
|
---|
34 | var Renderer = /** @class */ (function () {
|
---|
35 | function Renderer(host, srcFormatter, fs, logger, bundle, tsConfig) {
|
---|
36 | if (tsConfig === void 0) { tsConfig = null; }
|
---|
37 | this.host = host;
|
---|
38 | this.srcFormatter = srcFormatter;
|
---|
39 | this.fs = fs;
|
---|
40 | this.logger = logger;
|
---|
41 | this.bundle = bundle;
|
---|
42 | this.tsConfig = tsConfig;
|
---|
43 | }
|
---|
44 | Renderer.prototype.renderProgram = function (decorationAnalyses, switchMarkerAnalyses, privateDeclarationsAnalyses) {
|
---|
45 | var _this = this;
|
---|
46 | var renderedFiles = [];
|
---|
47 | // Transform the source files.
|
---|
48 | this.bundle.src.program.getSourceFiles().forEach(function (sourceFile) {
|
---|
49 | if (decorationAnalyses.has(sourceFile) || switchMarkerAnalyses.has(sourceFile) ||
|
---|
50 | sourceFile === _this.bundle.src.file) {
|
---|
51 | var compiledFile = decorationAnalyses.get(sourceFile);
|
---|
52 | var switchMarkerAnalysis = switchMarkerAnalyses.get(sourceFile);
|
---|
53 | renderedFiles.push.apply(renderedFiles, tslib_1.__spreadArray([], tslib_1.__read(_this.renderFile(sourceFile, compiledFile, switchMarkerAnalysis, privateDeclarationsAnalyses))));
|
---|
54 | }
|
---|
55 | });
|
---|
56 | return renderedFiles;
|
---|
57 | };
|
---|
58 | /**
|
---|
59 | * Render the source code and source-map for an Analyzed file.
|
---|
60 | * @param compiledFile The analyzed file to render.
|
---|
61 | * @param targetPath The absolute path where the rendered file will be written.
|
---|
62 | */
|
---|
63 | Renderer.prototype.renderFile = function (sourceFile, compiledFile, switchMarkerAnalysis, privateDeclarationsAnalyses) {
|
---|
64 | var _this = this;
|
---|
65 | var isEntryPoint = sourceFile === this.bundle.src.file;
|
---|
66 | var outputText = new magic_string_1.default(sourceFile.text);
|
---|
67 | if (switchMarkerAnalysis) {
|
---|
68 | this.srcFormatter.rewriteSwitchableDeclarations(outputText, switchMarkerAnalysis.sourceFile, switchMarkerAnalysis.declarations);
|
---|
69 | }
|
---|
70 | var importManager = new translator_1.ImportManager(utils_1.getImportRewriter(this.bundle.src.r3SymbolsFile, this.bundle.isCore, this.bundle.isFlatCore), constants_1.IMPORT_PREFIX);
|
---|
71 | if (compiledFile) {
|
---|
72 | // TODO: remove constructor param metadata and property decorators (we need info from the
|
---|
73 | // handlers to do this)
|
---|
74 | var decoratorsToRemove = this.computeDecoratorsToRemove(compiledFile.compiledClasses);
|
---|
75 | this.srcFormatter.removeDecorators(outputText, decoratorsToRemove);
|
---|
76 | compiledFile.compiledClasses.forEach(function (clazz) {
|
---|
77 | var _a;
|
---|
78 | var renderedDefinition = _this.renderDefinitions(compiledFile.sourceFile, clazz, importManager, !!((_a = _this.tsConfig) === null || _a === void 0 ? void 0 : _a.options.annotateForClosureCompiler));
|
---|
79 | _this.srcFormatter.addDefinitions(outputText, clazz, renderedDefinition);
|
---|
80 | var renderedStatements = _this.renderAdjacentStatements(compiledFile.sourceFile, clazz, importManager);
|
---|
81 | _this.srcFormatter.addAdjacentStatements(outputText, clazz, renderedStatements);
|
---|
82 | });
|
---|
83 | if (!isEntryPoint && compiledFile.reexports.length > 0) {
|
---|
84 | this.srcFormatter.addDirectExports(outputText, compiledFile.reexports, importManager, compiledFile.sourceFile);
|
---|
85 | }
|
---|
86 | this.srcFormatter.addConstants(outputText, renderConstantPool(this.srcFormatter, compiledFile.sourceFile, compiledFile.constantPool, importManager), compiledFile.sourceFile);
|
---|
87 | }
|
---|
88 | // Add exports to the entry-point file
|
---|
89 | if (isEntryPoint) {
|
---|
90 | var entryPointBasePath = utils_1.stripExtension(this.bundle.src.path);
|
---|
91 | this.srcFormatter.addExports(outputText, entryPointBasePath, privateDeclarationsAnalyses, importManager, sourceFile);
|
---|
92 | }
|
---|
93 | if (isEntryPoint || compiledFile) {
|
---|
94 | this.srcFormatter.addImports(outputText, importManager.getAllImports(sourceFile.fileName), sourceFile);
|
---|
95 | }
|
---|
96 | if (compiledFile || switchMarkerAnalysis || isEntryPoint) {
|
---|
97 | return source_maps_1.renderSourceAndMap(this.logger, this.fs, sourceFile, outputText);
|
---|
98 | }
|
---|
99 | else {
|
---|
100 | return [];
|
---|
101 | }
|
---|
102 | };
|
---|
103 | /**
|
---|
104 | * From the given list of classes, computes a map of decorators that should be removed.
|
---|
105 | * The decorators to remove are keyed by their container node, such that we can tell if
|
---|
106 | * we should remove the entire decorator property.
|
---|
107 | * @param classes The list of classes that may have decorators to remove.
|
---|
108 | * @returns A map of decorators to remove, keyed by their container node.
|
---|
109 | */
|
---|
110 | Renderer.prototype.computeDecoratorsToRemove = function (classes) {
|
---|
111 | var decoratorsToRemove = new rendering_formatter_1.RedundantDecoratorMap();
|
---|
112 | classes.forEach(function (clazz) {
|
---|
113 | if (clazz.decorators === null) {
|
---|
114 | return;
|
---|
115 | }
|
---|
116 | clazz.decorators.forEach(function (dec) {
|
---|
117 | if (dec.node === null) {
|
---|
118 | return;
|
---|
119 | }
|
---|
120 | var decoratorArray = dec.node.parent;
|
---|
121 | if (!decoratorsToRemove.has(decoratorArray)) {
|
---|
122 | decoratorsToRemove.set(decoratorArray, [dec.node]);
|
---|
123 | }
|
---|
124 | else {
|
---|
125 | decoratorsToRemove.get(decoratorArray).push(dec.node);
|
---|
126 | }
|
---|
127 | });
|
---|
128 | });
|
---|
129 | return decoratorsToRemove;
|
---|
130 | };
|
---|
131 | /**
|
---|
132 | * Render the definitions as source code for the given class.
|
---|
133 | * @param sourceFile The file containing the class to process.
|
---|
134 | * @param clazz The class whose definitions are to be rendered.
|
---|
135 | * @param compilation The results of analyzing the class - this is used to generate the rendered
|
---|
136 | * definitions.
|
---|
137 | * @param imports An object that tracks the imports that are needed by the rendered definitions.
|
---|
138 | */
|
---|
139 | Renderer.prototype.renderDefinitions = function (sourceFile, compiledClass, imports, annotateForClosureCompiler) {
|
---|
140 | var name = this.host.getInternalNameOfClass(compiledClass.declaration);
|
---|
141 | var leadingComment = annotateForClosureCompiler ? compiler_1.jsDocComment([{ tagName: 'nocollapse' }]) : undefined;
|
---|
142 | var statements = compiledClass.compilation.map(function (c) { return createAssignmentStatement(name, c.name, c.initializer, leadingComment); });
|
---|
143 | return this.renderStatements(sourceFile, statements, imports);
|
---|
144 | };
|
---|
145 | /**
|
---|
146 | * Render the adjacent statements as source code for the given class.
|
---|
147 | * @param sourceFile The file containing the class to process.
|
---|
148 | * @param clazz The class whose statements are to be rendered.
|
---|
149 | * @param compilation The results of analyzing the class - this is used to generate the rendered
|
---|
150 | * definitions.
|
---|
151 | * @param imports An object that tracks the imports that are needed by the rendered definitions.
|
---|
152 | */
|
---|
153 | Renderer.prototype.renderAdjacentStatements = function (sourceFile, compiledClass, imports) {
|
---|
154 | var e_1, _a;
|
---|
155 | var statements = [];
|
---|
156 | try {
|
---|
157 | for (var _b = tslib_1.__values(compiledClass.compilation), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
158 | var c = _c.value;
|
---|
159 | statements.push.apply(statements, tslib_1.__spreadArray([], tslib_1.__read(c.statements)));
|
---|
160 | }
|
---|
161 | }
|
---|
162 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
163 | finally {
|
---|
164 | try {
|
---|
165 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
166 | }
|
---|
167 | finally { if (e_1) throw e_1.error; }
|
---|
168 | }
|
---|
169 | return this.renderStatements(sourceFile, statements, imports);
|
---|
170 | };
|
---|
171 | Renderer.prototype.renderStatements = function (sourceFile, statements, imports) {
|
---|
172 | var _this = this;
|
---|
173 | var printStatement = function (stmt) {
|
---|
174 | return _this.srcFormatter.printStatement(stmt, sourceFile, imports);
|
---|
175 | };
|
---|
176 | return statements.map(printStatement).join('\n');
|
---|
177 | };
|
---|
178 | return Renderer;
|
---|
179 | }());
|
---|
180 | exports.Renderer = Renderer;
|
---|
181 | /**
|
---|
182 | * Render the constant pool as source code for the given class.
|
---|
183 | */
|
---|
184 | function renderConstantPool(formatter, sourceFile, constantPool, imports) {
|
---|
185 | var printStatement = function (stmt) { return formatter.printStatement(stmt, sourceFile, imports); };
|
---|
186 | return constantPool.statements.map(printStatement).join('\n');
|
---|
187 | }
|
---|
188 | exports.renderConstantPool = renderConstantPool;
|
---|
189 | /**
|
---|
190 | * Create an Angular AST statement node that contains the assignment of the
|
---|
191 | * compiled decorator to be applied to the class.
|
---|
192 | * @param analyzedClass The info about the class whose statement we want to create.
|
---|
193 | */
|
---|
194 | function createAssignmentStatement(receiverName, propName, initializer, leadingComment) {
|
---|
195 | var receiver = new compiler_1.WrappedNodeExpr(receiverName);
|
---|
196 | var statement = new compiler_1.WritePropExpr(receiver, propName, initializer, /* type */ undefined, /* sourceSpan */ undefined)
|
---|
197 | .toStmt();
|
---|
198 | if (leadingComment !== undefined) {
|
---|
199 | statement.addLeadingComment(leadingComment);
|
---|
200 | }
|
---|
201 | return statement;
|
---|
202 | }
|
---|
203 | });
|
---|
204 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/rendering/renderer.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 */\nimport {ConstantPool, Expression, jsDocComment, LeadingComment, Statement, WrappedNodeExpr, WritePropExpr} from '@angular/compiler';\nimport MagicString from 'magic-string';\nimport * as ts from 'typescript';\n\nimport {ReadonlyFileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {ImportManager} from '../../../src/ngtsc/translator';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {PrivateDeclarationsAnalyses} from '../analysis/private_declarations_analyzer';\nimport {SwitchMarkerAnalyses, SwitchMarkerAnalysis} from '../analysis/switch_marker_analyzer';\nimport {CompiledClass, CompiledFile, DecorationAnalyses} from '../analysis/types';\nimport {IMPORT_PREFIX} from '../constants';\nimport {NgccReflectionHost} from '../host/ngcc_host';\nimport {EntryPointBundle} from '../packages/entry_point_bundle';\n\nimport {RedundantDecoratorMap, RenderingFormatter} from './rendering_formatter';\nimport {renderSourceAndMap} from './source_maps';\nimport {FileToWrite, getImportRewriter, stripExtension} from './utils';\n\n/**\n * A base-class for rendering an `AnalyzedFile`.\n *\n * Package formats have output files that must be rendered differently. Concrete sub-classes must\n * implement the `addImports`, `addDefinitions` and `removeDecorators` abstract methods.\n */\nexport class Renderer {\n  constructor(\n      private host: NgccReflectionHost, private srcFormatter: RenderingFormatter,\n      private fs: ReadonlyFileSystem, private logger: Logger, private bundle: EntryPointBundle,\n      private tsConfig: ParsedConfiguration|null = null) {}\n\n  renderProgram(\n      decorationAnalyses: DecorationAnalyses, switchMarkerAnalyses: SwitchMarkerAnalyses,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const renderedFiles: FileToWrite[] = [];\n\n    // Transform the source files.\n    this.bundle.src.program.getSourceFiles().forEach(sourceFile => {\n      if (decorationAnalyses.has(sourceFile) || switchMarkerAnalyses.has(sourceFile) ||\n          sourceFile === this.bundle.src.file) {\n        const compiledFile = decorationAnalyses.get(sourceFile);\n        const switchMarkerAnalysis = switchMarkerAnalyses.get(sourceFile);\n        renderedFiles.push(...this.renderFile(\n            sourceFile, compiledFile, switchMarkerAnalysis, privateDeclarationsAnalyses));\n      }\n    });\n\n    return renderedFiles;\n  }\n\n  /**\n   * Render the source code and source-map for an Analyzed file.\n   * @param compiledFile The analyzed file to render.\n   * @param targetPath The absolute path where the rendered file will be written.\n   */\n  renderFile(\n      sourceFile: ts.SourceFile, compiledFile: CompiledFile|undefined,\n      switchMarkerAnalysis: SwitchMarkerAnalysis|undefined,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const isEntryPoint = sourceFile === this.bundle.src.file;\n    const outputText = new MagicString(sourceFile.text);\n\n    if (switchMarkerAnalysis) {\n      this.srcFormatter.rewriteSwitchableDeclarations(\n          outputText, switchMarkerAnalysis.sourceFile, switchMarkerAnalysis.declarations);\n    }\n\n    const importManager = new ImportManager(\n        getImportRewriter(\n            this.bundle.src.r3SymbolsFile, this.bundle.isCore, this.bundle.isFlatCore),\n        IMPORT_PREFIX);\n\n    if (compiledFile) {\n      // TODO: remove constructor param metadata and property decorators (we need info from the\n      // handlers to do this)\n      const decoratorsToRemove = this.computeDecoratorsToRemove(compiledFile.compiledClasses);\n      this.srcFormatter.removeDecorators(outputText, decoratorsToRemove);\n\n      compiledFile.compiledClasses.forEach(clazz => {\n        const renderedDefinition = this.renderDefinitions(\n            compiledFile.sourceFile, clazz, importManager,\n            !!this.tsConfig?.options.annotateForClosureCompiler);\n        this.srcFormatter.addDefinitions(outputText, clazz, renderedDefinition);\n\n        const renderedStatements =\n            this.renderAdjacentStatements(compiledFile.sourceFile, clazz, importManager);\n        this.srcFormatter.addAdjacentStatements(outputText, clazz, renderedStatements);\n      });\n\n      if (!isEntryPoint && compiledFile.reexports.length > 0) {\n        this.srcFormatter.addDirectExports(\n            outputText, compiledFile.reexports, importManager, compiledFile.sourceFile);\n      }\n\n      this.srcFormatter.addConstants(\n          outputText,\n          renderConstantPool(\n              this.srcFormatter, compiledFile.sourceFile, compiledFile.constantPool, importManager),\n          compiledFile.sourceFile);\n    }\n\n    // Add exports to the entry-point file\n    if (isEntryPoint) {\n      const entryPointBasePath = stripExtension(this.bundle.src.path);\n      this.srcFormatter.addExports(\n          outputText, entryPointBasePath, privateDeclarationsAnalyses, importManager, sourceFile);\n    }\n\n    if (isEntryPoint || compiledFile) {\n      this.srcFormatter.addImports(\n          outputText, importManager.getAllImports(sourceFile.fileName), sourceFile);\n    }\n\n    if (compiledFile || switchMarkerAnalysis || isEntryPoint) {\n      return renderSourceAndMap(this.logger, this.fs, sourceFile, outputText);\n    } else {\n      return [];\n    }\n  }\n\n  /**\n   * From the given list of classes, computes a map of decorators that should be removed.\n   * The decorators to remove are keyed by their container node, such that we can tell if\n   * we should remove the entire decorator property.\n   * @param classes The list of classes that may have decorators to remove.\n   * @returns A map of decorators to remove, keyed by their container node.\n   */\n  private computeDecoratorsToRemove(classes: CompiledClass[]): RedundantDecoratorMap {\n    const decoratorsToRemove = new RedundantDecoratorMap();\n    classes.forEach(clazz => {\n      if (clazz.decorators === null) {\n        return;\n      }\n\n      clazz.decorators.forEach(dec => {\n        if (dec.node === null) {\n          return;\n        }\n        const decoratorArray = dec.node.parent!;\n        if (!decoratorsToRemove.has(decoratorArray)) {\n          decoratorsToRemove.set(decoratorArray, [dec.node]);\n        } else {\n          decoratorsToRemove.get(decoratorArray)!.push(dec.node);\n        }\n      });\n    });\n    return decoratorsToRemove;\n  }\n\n  /**\n   * Render the definitions as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose definitions are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderDefinitions(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager,\n      annotateForClosureCompiler: boolean): string {\n    const name = this.host.getInternalNameOfClass(compiledClass.declaration);\n    const leadingComment =\n        annotateForClosureCompiler ? jsDocComment([{tagName: 'nocollapse'}]) : undefined;\n    const statements: Statement[] = compiledClass.compilation.map(\n        c => createAssignmentStatement(name, c.name, c.initializer, leadingComment));\n    return this.renderStatements(sourceFile, statements, imports);\n  }\n\n  /**\n   * Render the adjacent statements as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose statements are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderAdjacentStatements(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager): string {\n    const statements: Statement[] = [];\n    for (const c of compiledClass.compilation) {\n      statements.push(...c.statements);\n    }\n    return this.renderStatements(sourceFile, statements, imports);\n  }\n\n  private renderStatements(\n      sourceFile: ts.SourceFile, statements: Statement[], imports: ImportManager): string {\n    const printStatement = (stmt: Statement) =>\n        this.srcFormatter.printStatement(stmt, sourceFile, imports);\n    return statements.map(printStatement).join('\\n');\n  }\n}\n\n/**\n * Render the constant pool as source code for the given class.\n */\nexport function renderConstantPool(\n    formatter: RenderingFormatter, sourceFile: ts.SourceFile, constantPool: ConstantPool,\n    imports: ImportManager): string {\n  const printStatement = (stmt: Statement) => formatter.printStatement(stmt, sourceFile, imports);\n  return constantPool.statements.map(printStatement).join('\\n');\n}\n\n/**\n * Create an Angular AST statement node that contains the assignment of the\n * compiled decorator to be applied to the class.\n * @param analyzedClass The info about the class whose statement we want to create.\n */\nfunction createAssignmentStatement(\n    receiverName: ts.DeclarationName, propName: string, initializer: Expression,\n    leadingComment?: LeadingComment): Statement {\n  const receiver = new WrappedNodeExpr(receiverName);\n  const statement =\n      new WritePropExpr(\n          receiver, propName, initializer, /* type */ undefined, /* sourceSpan */ undefined)\n          .toStmt();\n  if (leadingComment !== undefined) {\n    statement.addLeadingComment(leadingComment);\n  }\n  return statement;\n}\n"]} |
---|