source: trip-planner-front/node_modules/@angular/cdk/schematics/utils/vendored-ast-utils/index.js

Last change on this file was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 63.8 KB
Line 
1"use strict";
2/**
3 * @license
4 * Copyright Google LLC All Rights Reserved.
5 *
6 * Use of this source code is governed by an MIT-style license that can be
7 * found in the LICENSE file at https://angular.io/license
8 */
9Object.defineProperty(exports, "__esModule", { value: true });
10exports.getAppModulePath = exports.findBootstrapModulePath = exports.findBootstrapModuleCall = exports.addExportToModule = exports.addImportToModule = exports.addDeclarationToModule = exports.addSymbolToNgModuleMetadata = exports.getMetadataField = exports.getDecoratorMetadata = exports.insertAfterLastOccurrence = exports.findNode = exports.getSourceNodes = exports.findNodes = exports.insertImport = void 0;
11// tslint:disable
12/*
13 * Note: This file contains vendored TypeScript AST utils from "@schematics/angular".
14 * Since there is no canonical place for common utils, and we don't want to use the AST
15 * utils directly from "@schematics/angular" to avoid TypeScript version mismatches, we
16 * copy the needed AST utils until there is a general place for such utility functions.
17 *
18 * Taken from:
19 * (1) https://github.com/angular/angular-cli/blob/30df1470a0f18989db336d50b55a79021ab64c85/packages/schematics/angular/utility/ng-ast-utils.ts
20 * (2) https://github.com/angular/angular-cli/blob/30df1470a0f18989db336d50b55a79021ab64c85/packages/schematics/angular/utility/ast-utils.ts
21 */
22const core_1 = require("@angular-devkit/core");
23const schematics_1 = require("@angular-devkit/schematics");
24const change_1 = require("@schematics/angular/utility/change");
25const path_1 = require("path");
26const ts = require("typescript");
27/**
28 * Add Import `import { symbolName } from fileName` if the import doesn't exit
29 * already. Assumes fileToEdit can be resolved and accessed.
30 * @param fileToEdit (file we want to add import to)
31 * @param symbolName (item to import)
32 * @param fileName (path to the file)
33 * @param isDefault (if true, import follows style for importing default exports)
34 * @return Change
35 */
36function insertImport(source, fileToEdit, symbolName, fileName, isDefault = false) {
37 const rootNode = source;
38 const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);
39 // get nodes that map to import statements from the file fileName
40 const relevantImports = allImports.filter(node => {
41 // StringLiteral of the ImportDeclaration is the import file (fileName in this case).
42 const importFiles = node.getChildren()
43 .filter(child => child.kind === ts.SyntaxKind.StringLiteral)
44 .map(n => n.text);
45 return importFiles.filter(file => file === fileName).length === 1;
46 });
47 if (relevantImports.length > 0) {
48 let importsAsterisk = false;
49 // imports from import file
50 const imports = [];
51 relevantImports.forEach(n => {
52 Array.prototype.push.apply(imports, findNodes(n, ts.SyntaxKind.Identifier));
53 if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {
54 importsAsterisk = true;
55 }
56 });
57 // if imports * from fileName, don't add symbolName
58 if (importsAsterisk) {
59 return new change_1.NoopChange();
60 }
61 const importTextNodes = imports.filter(n => n.text === symbolName);
62 // insert import if it's not there
63 if (importTextNodes.length === 0) {
64 const fallbackPos = findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||
65 findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();
66 return insertAfterLastOccurrence(imports, `, ${symbolName}`, fileToEdit, fallbackPos);
67 }
68 return new change_1.NoopChange();
69 }
70 // no such import declaration exists
71 const useStrict = findNodes(rootNode, ts.SyntaxKind.StringLiteral)
72 .filter(n => n.text === 'use strict');
73 let fallbackPos = 0;
74 if (useStrict.length > 0) {
75 fallbackPos = useStrict[0].end;
76 }
77 const open = isDefault ? '' : '{ ';
78 const close = isDefault ? '' : ' }';
79 // if there are no imports or 'use strict' statement, insert import at beginning of file
80 const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;
81 const separator = insertAtBeginning ? '' : ';\n';
82 const toInsert = `${separator}import ${open}${symbolName}${close}` +
83 ` from '${fileName}'${insertAtBeginning ? ';\n' : ''}`;
84 return insertAfterLastOccurrence(allImports, toInsert, fileToEdit, fallbackPos, ts.SyntaxKind.StringLiteral);
85}
86exports.insertImport = insertImport;
87/**
88 * Find all nodes from the AST in the subtree of node of SyntaxKind kind.
89 * @param node
90 * @param kind
91 * @param max The maximum number of items to return.
92 * @param recursive Continue looking for nodes of kind recursive until end
93 * the last child even when node of kind has been found.
94 * @return all nodes of kind, or [] if none is found
95 */
96function findNodes(node, kind, max = Infinity, recursive = false) {
97 if (!node || max == 0) {
98 return [];
99 }
100 const arr = [];
101 if (node.kind === kind) {
102 arr.push(node);
103 max--;
104 }
105 if (max > 0 && (recursive || node.kind !== kind)) {
106 for (const child of node.getChildren()) {
107 findNodes(child, kind, max).forEach(node => {
108 if (max > 0) {
109 arr.push(node);
110 }
111 max--;
112 });
113 if (max <= 0) {
114 break;
115 }
116 }
117 }
118 return arr;
119}
120exports.findNodes = findNodes;
121/**
122 * Get all the nodes from a source.
123 * @param sourceFile The source file object.
124 * @returns {Observable<ts.Node>} An observable of all the nodes in the source.
125 */
126function getSourceNodes(sourceFile) {
127 const nodes = [sourceFile];
128 const result = [];
129 while (nodes.length > 0) {
130 const node = nodes.shift();
131 if (node) {
132 result.push(node);
133 if (node.getChildCount(sourceFile) >= 0) {
134 nodes.unshift(...node.getChildren());
135 }
136 }
137 }
138 return result;
139}
140exports.getSourceNodes = getSourceNodes;
141function findNode(node, kind, text) {
142 if (node.kind === kind && node.getText() === text) {
143 // throw new Error(node.getText());
144 return node;
145 }
146 let foundNode = null;
147 ts.forEachChild(node, childNode => {
148 foundNode = foundNode || findNode(childNode, kind, text);
149 });
150 return foundNode;
151}
152exports.findNode = findNode;
153/**
154 * Helper for sorting nodes.
155 * @return function to sort nodes in increasing order of position in sourceFile
156 */
157function nodesByPosition(first, second) {
158 return first.getStart() - second.getStart();
159}
160/**
161 * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`
162 * or after the last of occurence of `syntaxKind` if the last occurence is a sub child
163 * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.
164 *
165 * @param nodes insert after the last occurence of nodes
166 * @param toInsert string to insert
167 * @param file file to insert changes into
168 * @param fallbackPos position to insert if toInsert happens to be the first occurence
169 * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after
170 * @return Change instance
171 * @throw Error if toInsert is first occurence but fall back is not set
172 */
173function insertAfterLastOccurrence(nodes, toInsert, file, fallbackPos, syntaxKind) {
174 let lastItem;
175 for (const node of nodes) {
176 if (!lastItem || lastItem.getStart() < node.getStart()) {
177 lastItem = node;
178 }
179 }
180 if (syntaxKind && lastItem) {
181 lastItem = findNodes(lastItem, syntaxKind).sort(nodesByPosition).pop();
182 }
183 if (!lastItem && fallbackPos == undefined) {
184 throw new Error(`tried to insert ${toInsert} as first occurence with no fallback position`);
185 }
186 const lastItemPosition = lastItem ? lastItem.getEnd() : fallbackPos;
187 return new change_1.InsertChange(file, lastItemPosition, toInsert);
188}
189exports.insertAfterLastOccurrence = insertAfterLastOccurrence;
190function _angularImportsFromNode(node, _sourceFile) {
191 const ms = node.moduleSpecifier;
192 let modulePath;
193 switch (ms.kind) {
194 case ts.SyntaxKind.StringLiteral:
195 modulePath = ms.text;
196 break;
197 default:
198 return {};
199 }
200 if (!modulePath.startsWith('@angular/')) {
201 return {};
202 }
203 if (node.importClause) {
204 if (node.importClause.name) {
205 // This is of the form `import Name from 'path'`. Ignore.
206 return {};
207 }
208 else if (node.importClause.namedBindings) {
209 const nb = node.importClause.namedBindings;
210 if (nb.kind == ts.SyntaxKind.NamespaceImport) {
211 // This is of the form `import * as name from 'path'`. Return `name.`.
212 return {
213 [nb.name.text + '.']: modulePath,
214 };
215 }
216 else {
217 // This is of the form `import {a,b,c} from 'path'`
218 const namedImports = nb;
219 return namedImports.elements
220 .map((is) => is.propertyName ? is.propertyName.text : is.name.text)
221 .reduce((acc, curr) => {
222 acc[curr] = modulePath;
223 return acc;
224 }, {});
225 }
226 }
227 return {};
228 }
229 else {
230 // This is of the form `import 'path';`. Nothing to do.
231 return {};
232 }
233}
234function getDecoratorMetadata(source, identifier, module) {
235 const angularImports = findNodes(source, ts.SyntaxKind.ImportDeclaration)
236 .map(node => _angularImportsFromNode(node, source))
237 .reduce((acc, current) => {
238 for (const key of Object.keys(current)) {
239 acc[key] = current[key];
240 }
241 return acc;
242 }, {});
243 return getSourceNodes(source)
244 .filter(node => {
245 return node.kind == ts.SyntaxKind.Decorator
246 && node.expression.kind == ts.SyntaxKind.CallExpression;
247 })
248 .map(node => node.expression)
249 .filter(expr => {
250 if (expr.expression.kind == ts.SyntaxKind.Identifier) {
251 const id = expr.expression;
252 return id.text == identifier && angularImports[id.text] === module;
253 }
254 else if (expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression) {
255 // This covers foo.NgModule when importing * as foo.
256 const paExpr = expr.expression;
257 // If the left expression is not an identifier, just give up at that point.
258 if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {
259 return false;
260 }
261 const id = paExpr.name.text;
262 const moduleId = paExpr.expression.text;
263 return id === identifier && (angularImports[moduleId + '.'] === module);
264 }
265 return false;
266 })
267 .filter(expr => expr.arguments[0]
268 && expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression)
269 .map(expr => expr.arguments[0]);
270}
271exports.getDecoratorMetadata = getDecoratorMetadata;
272function getMetadataField(node, metadataField) {
273 return node.properties
274 .filter(prop => ts.isPropertyAssignment(prop))
275 // Filter out every fields that's not "metadataField". Also handles string literals
276 // (but not expressions).
277 .filter(node => {
278 const name = node.name;
279 return (ts.isIdentifier(name) || ts.isStringLiteral(name))
280 && name.getText() === metadataField;
281 });
282}
283exports.getMetadataField = getMetadataField;
284function addSymbolToNgModuleMetadata(source, ngModulePath, metadataField, symbolName, importPath = null) {
285 const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');
286 let node = nodes[0]; // tslint:disable-line:no-any
287 // Find the decorator declaration.
288 if (!node) {
289 return [];
290 }
291 // Get all the children property assignment of object literals.
292 const matchingProperties = getMetadataField(node, metadataField);
293 // Get the last node of the array literal.
294 if (!matchingProperties) {
295 return [];
296 }
297 if (matchingProperties.length == 0) {
298 // We haven't found the field in the metadata declaration. Insert a new field.
299 const expr = node;
300 let position;
301 let toInsert;
302 if (expr.properties.length == 0) {
303 position = expr.getEnd() - 1;
304 toInsert = ` ${metadataField}: [${symbolName}]\n`;
305 }
306 else {
307 node = expr.properties[expr.properties.length - 1];
308 position = node.getEnd();
309 // Get the indentation of the last element, if any.
310 const text = node.getFullText(source);
311 const matches = text.match(/^\r?\n\s*/);
312 if (matches && matches.length > 0) {
313 toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;
314 }
315 else {
316 toInsert = `, ${metadataField}: [${symbolName}]`;
317 }
318 }
319 if (importPath !== null) {
320 return [
321 new change_1.InsertChange(ngModulePath, position, toInsert),
322 insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath),
323 ];
324 }
325 else {
326 return [new change_1.InsertChange(ngModulePath, position, toInsert)];
327 }
328 }
329 const assignment = matchingProperties[0];
330 // If it's not an array, nothing we can do really.
331 if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {
332 return [];
333 }
334 const arrLiteral = assignment.initializer;
335 if (arrLiteral.elements.length == 0) {
336 // Forward the property.
337 node = arrLiteral;
338 }
339 else {
340 node = arrLiteral.elements;
341 }
342 if (!node) {
343 // tslint:disable-next-line: no-console
344 console.error('No app module found. Please add your new class to your component.');
345 return [];
346 }
347 if (Array.isArray(node)) {
348 const nodeArray = node;
349 const symbolsArray = nodeArray.map(node => node.getText());
350 if (symbolsArray.includes(symbolName)) {
351 return [];
352 }
353 node = node[node.length - 1];
354 }
355 let toInsert;
356 let position = node.getEnd();
357 if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {
358 // We haven't found the field in the metadata declaration. Insert a new
359 // field.
360 const expr = node;
361 if (expr.properties.length == 0) {
362 position = expr.getEnd() - 1;
363 toInsert = ` ${symbolName}\n`;
364 }
365 else {
366 // Get the indentation of the last element, if any.
367 const text = node.getFullText(source);
368 if (text.match(/^\r?\r?\n/)) {
369 toInsert = `,${text.match(/^\r?\n\s*/)[0]}${symbolName}`;
370 }
371 else {
372 toInsert = `, ${symbolName}`;
373 }
374 }
375 }
376 else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {
377 // We found the field but it's empty. Insert it just before the `]`.
378 position--;
379 toInsert = `${symbolName}`;
380 }
381 else {
382 // Get the indentation of the last element, if any.
383 const text = node.getFullText(source);
384 if (text.match(/^\r?\n/)) {
385 toInsert = `,${text.match(/^\r?\n(\r?)\s*/)[0]}${symbolName}`;
386 }
387 else {
388 toInsert = `, ${symbolName}`;
389 }
390 }
391 if (importPath !== null) {
392 return [
393 new change_1.InsertChange(ngModulePath, position, toInsert),
394 insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath),
395 ];
396 }
397 return [new change_1.InsertChange(ngModulePath, position, toInsert)];
398}
399exports.addSymbolToNgModuleMetadata = addSymbolToNgModuleMetadata;
400/**
401 * Custom function to insert a declaration (component, pipe, directive)
402 * into NgModule declarations. It also imports the component.
403 */
404function addDeclarationToModule(source, modulePath, classifiedName, importPath) {
405 return addSymbolToNgModuleMetadata(source, modulePath, 'declarations', classifiedName, importPath);
406}
407exports.addDeclarationToModule = addDeclarationToModule;
408/**
409 * Custom function to insert an NgModule into NgModule imports. It also imports the module.
410 */
411function addImportToModule(source, modulePath, classifiedName, importPath) {
412 return addSymbolToNgModuleMetadata(source, modulePath, 'imports', classifiedName, importPath);
413}
414exports.addImportToModule = addImportToModule;
415/**
416 * Custom function to insert an export into NgModule. It also imports it.
417 */
418function addExportToModule(source, modulePath, classifiedName, importPath) {
419 return addSymbolToNgModuleMetadata(source, modulePath, 'exports', classifiedName, importPath);
420}
421exports.addExportToModule = addExportToModule;
422function findBootstrapModuleCall(host, mainPath) {
423 const mainBuffer = host.read(mainPath);
424 if (!mainBuffer) {
425 throw new schematics_1.SchematicsException(`Main file (${mainPath}) not found`);
426 }
427 const mainText = mainBuffer.toString('utf-8');
428 const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);
429 const allNodes = getSourceNodes(source);
430 let bootstrapCall = null;
431 for (const node of allNodes) {
432 let bootstrapCallNode = null;
433 bootstrapCallNode = findNode(node, ts.SyntaxKind.Identifier, 'bootstrapModule');
434 // Walk up the parent until CallExpression is found.
435 while (bootstrapCallNode && bootstrapCallNode.parent
436 && bootstrapCallNode.parent.kind !== ts.SyntaxKind.CallExpression) {
437 bootstrapCallNode = bootstrapCallNode.parent;
438 }
439 if (bootstrapCallNode !== null &&
440 bootstrapCallNode.parent !== undefined &&
441 bootstrapCallNode.parent.kind === ts.SyntaxKind.CallExpression) {
442 bootstrapCall = bootstrapCallNode.parent;
443 break;
444 }
445 }
446 return bootstrapCall;
447}
448exports.findBootstrapModuleCall = findBootstrapModuleCall;
449function findBootstrapModulePath(host, mainPath) {
450 const bootstrapCall = findBootstrapModuleCall(host, mainPath);
451 if (!bootstrapCall) {
452 throw new schematics_1.SchematicsException('Bootstrap call not found');
453 }
454 const bootstrapModule = bootstrapCall.arguments[0];
455 const mainBuffer = host.read(mainPath);
456 if (!mainBuffer) {
457 throw new schematics_1.SchematicsException(`Client app main file (${mainPath}) not found`);
458 }
459 const mainText = mainBuffer.toString('utf-8');
460 const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);
461 const allNodes = getSourceNodes(source);
462 const bootstrapModuleRelativePath = allNodes
463 .filter(node => node.kind === ts.SyntaxKind.ImportDeclaration)
464 .filter(imp => {
465 return findNode(imp, ts.SyntaxKind.Identifier, bootstrapModule.getText());
466 })
467 .map(node => {
468 const modulePath = node.moduleSpecifier;
469 return modulePath.text;
470 })[0];
471 return bootstrapModuleRelativePath;
472}
473exports.findBootstrapModulePath = findBootstrapModulePath;
474function getAppModulePath(host, mainPath) {
475 const moduleRelativePath = findBootstrapModulePath(host, mainPath);
476 const mainDir = path_1.dirname(mainPath);
477 const modulePath = core_1.normalize(`/${mainDir}/${moduleRelativePath}.ts`);
478 return modulePath;
479}
480exports.getAppModulePath = getAppModulePath;
481//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../src/cdk/schematics/utils/vendored-ast-utils/index.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 */\n\n// tslint:disable\n\n/*\n * Note: This file contains vendored TypeScript AST utils from \"@schematics/angular\".\n * Since there is no canonical place for common utils, and we don't want to use the AST\n * utils directly from \"@schematics/angular\" to avoid TypeScript version mismatches, we\n * copy the needed AST utils until there is a general place for such utility functions.\n *\n * Taken from:\n *   (1) https://github.com/angular/angular-cli/blob/30df1470a0f18989db336d50b55a79021ab64c85/packages/schematics/angular/utility/ng-ast-utils.ts\n *   (2) https://github.com/angular/angular-cli/blob/30df1470a0f18989db336d50b55a79021ab64c85/packages/schematics/angular/utility/ast-utils.ts\n */\n\nimport {normalize} from '@angular-devkit/core';\nimport {SchematicsException, Tree} from '@angular-devkit/schematics';\nimport {Change, InsertChange, NoopChange} from '@schematics/angular/utility/change';\nimport {dirname} from 'path';\n\nimport * as ts from 'typescript';\n\n/**\n * Add Import `import { symbolName } from fileName` if the import doesn't exit\n * already. Assumes fileToEdit can be resolved and accessed.\n * @param fileToEdit (file we want to add import to)\n * @param symbolName (item to import)\n * @param fileName (path to the file)\n * @param isDefault (if true, import follows style for importing default exports)\n * @return Change\n */\nexport function insertImport(source: ts.SourceFile, fileToEdit: string, symbolName: string,\n                             fileName: string, isDefault = false): Change {\n  const rootNode = source;\n  const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);\n\n  // get nodes that map to import statements from the file fileName\n  const relevantImports = allImports.filter(node => {\n    // StringLiteral of the ImportDeclaration is the import file (fileName in this case).\n    const importFiles = node.getChildren()\n      .filter(child => child.kind === ts.SyntaxKind.StringLiteral)\n      .map(n => (n as ts.StringLiteral).text);\n\n    return importFiles.filter(file => file === fileName).length === 1;\n  });\n\n  if (relevantImports.length > 0) {\n    let importsAsterisk = false;\n    // imports from import file\n    const imports: ts.Node[] = [];\n    relevantImports.forEach(n => {\n      Array.prototype.push.apply(imports, findNodes(n, ts.SyntaxKind.Identifier));\n      if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {\n        importsAsterisk = true;\n      }\n    });\n\n    // if imports * from fileName, don't add symbolName\n    if (importsAsterisk) {\n      return new NoopChange();\n    }\n\n    const importTextNodes = imports.filter(n => (n as ts.Identifier).text === symbolName);\n\n    // insert import if it's not there\n    if (importTextNodes.length === 0) {\n      const fallbackPos =\n        findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||\n        findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();\n\n      return insertAfterLastOccurrence(imports, `, ${symbolName}`, fileToEdit, fallbackPos);\n    }\n\n    return new NoopChange();\n  }\n\n  // no such import declaration exists\n  const useStrict = findNodes(rootNode, ts.SyntaxKind.StringLiteral)\n    .filter(n => (n as ts.StringLiteral).text === 'use strict');\n  let fallbackPos = 0;\n  if (useStrict.length > 0) {\n    fallbackPos = useStrict[0].end;\n  }\n  const open = isDefault ? '' : '{ ';\n  const close = isDefault ? '' : ' }';\n  // if there are no imports or 'use strict' statement, insert import at beginning of file\n  const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;\n  const separator = insertAtBeginning ? '' : ';\\n';\n  const toInsert = `${separator}import ${open}${symbolName}${close}` +\n    ` from '${fileName}'${insertAtBeginning ? ';\\n' : ''}`;\n\n  return insertAfterLastOccurrence(\n    allImports,\n    toInsert,\n    fileToEdit,\n    fallbackPos,\n    ts.SyntaxKind.StringLiteral,\n  );\n}\n\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @param recursive Continue looking for nodes of kind recursive until end\n * the last child even when node of kind has been found.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(node: ts.Node, kind: ts.SyntaxKind, max = Infinity, recursive = false): ts.Node[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const arr: ts.Node[] = [];\n  if (node.kind === kind) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0 && (recursive || node.kind !== kind)) {\n    for (const child of node.getChildren()) {\n      findNodes(child, kind, max).forEach(node => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns {Observable<ts.Node>} An observable of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result: ts.Node[] = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\nexport function findNode(node: ts.Node, kind: ts.SyntaxKind, text: string): ts.Node | null {\n  if (node.kind === kind && node.getText() === text) {\n    // throw new Error(node.getText());\n    return node;\n  }\n\n  let foundNode: ts.Node | null = null;\n  ts.forEachChild(node, childNode => {\n    foundNode = foundNode || findNode(childNode, kind, text);\n  });\n\n  return foundNode;\n}\n\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.getStart() - second.getStart();\n}\n\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(nodes: ts.Node[],\n                                          toInsert: string,\n                                          file: string,\n                                          fallbackPos: number,\n                                          syntaxKind?: ts.SyntaxKind): Change {\n  let lastItem: ts.Node | undefined;\n  for (const node of nodes) {\n    if (!lastItem || lastItem.getStart() < node.getStart()) {\n      lastItem = node;\n    }\n  }\n  if (syntaxKind && lastItem) {\n    lastItem = findNodes(lastItem, syntaxKind).sort(nodesByPosition).pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(`tried to insert ${toInsert} as first occurence with no fallback position`);\n  }\n  const lastItemPosition: number = lastItem ? lastItem.getEnd() : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nfunction _angularImportsFromNode(node: ts.ImportDeclaration,\n                                 _sourceFile: ts.SourceFile): {[name: string]: string} {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [(nb as ts.NamespaceImport).name.text + '.']: modulePath,\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb as ts.NamedImports;\n\n        return namedImports.elements\n          .map((is: ts.ImportSpecifier) => is.propertyName ? is.propertyName.text : is.name.text)\n          .reduce((acc: {[name: string]: string}, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(source: ts.SourceFile, identifier: string,\n                                     module: string): ts.Node[] {\n  const angularImports: {[name: string]: string}\n    = findNodes(source, ts.SyntaxKind.ImportDeclaration)\n    .map(node => _angularImportsFromNode(node as ts.ImportDeclaration, source))\n    .reduce((acc: {[name: string]: string}, current: {[name: string]: string}) => {\n      for (const key of Object.keys(current)) {\n        acc[key] = current[key];\n      }\n\n      return acc;\n    }, {});\n\n  return getSourceNodes(source)\n    .filter(node => {\n      return node.kind == ts.SyntaxKind.Decorator\n        && (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression;\n    })\n    .map(node => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter(expr => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return id.text == identifier && angularImports[id.text] === module;\n      } else if (expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).text;\n\n        return id === identifier && (angularImports[moduleId + '.'] === module);\n      }\n\n      return false;\n    })\n    .filter(expr => expr.arguments[0]\n      && expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression)\n    .map(expr => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nexport function getMetadataField(\n  node: ts.ObjectLiteralExpression,\n  metadataField: string,\n): ts.ObjectLiteralElement[] {\n  return node.properties\n    .filter(prop => ts.isPropertyAssignment(prop))\n    // Filter out every fields that's not \"metadataField\". Also handles string literals\n    // (but not expressions).\n    .filter(node => {\n      const name = (node as ts.PropertyAssignment).name;\n      return (ts.isIdentifier(name) || ts.isStringLiteral(name))\n        && name.getText() === metadataField;\n    });\n}\n\nexport function addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string | null = null,\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  let node: any = nodes[0];  // tslint:disable-line:no-any\n\n  // Find the decorator declaration.\n  if (!node) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties = getMetadataField(\n    node as ts.ObjectLiteralExpression,\n    metadataField,\n  );\n\n  // Get the last node of the array literal.\n  if (!matchingProperties) {\n    return [];\n  }\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    const expr = node as ts.ObjectLiteralExpression;\n    let position: number;\n    let toInsert: string;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      const matches = text.match(/^\\r?\\n\\s*/);\n      if (matches && matches.length > 0) {\n        toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    if (importPath !== null) {\n      return [\n        new InsertChange(ngModulePath, position, toInsert),\n        insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n      ];\n    } else {\n      return [new InsertChange(ngModulePath, position, toInsert)];\n    }\n  }\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  // If it's not an array, nothing we can do really.\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return [];\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n  if (arrLiteral.elements.length == 0) {\n    // Forward the property.\n    node = arrLiteral;\n  } else {\n    node = arrLiteral.elements;\n  }\n\n  if (!node) {\n    // tslint:disable-next-line: no-console\n    console.error('No app module found. Please add your new class to your component.');\n\n    return [];\n  }\n\n  if (Array.isArray(node)) {\n    const nodeArray = node as {} as Array<ts.Node>;\n    const symbolsArray = nodeArray.map(node => node.getText());\n    if (symbolsArray.includes(symbolName)) {\n      return [];\n    }\n\n    node = node[node.length - 1];\n  }\n\n  let toInsert: string;\n  let position = node.getEnd();\n  if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {\n    // We haven't found the field in the metadata declaration. Insert a new\n    // field.\n    const expr = node as ts.ObjectLiteralExpression;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${symbolName}\\n`;\n    } else {\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      if (text.match(/^\\r?\\r?\\n/)) {\n        toInsert = `,${text.match(/^\\r?\\n\\s*/)[0]}${symbolName}`;\n      } else {\n        toInsert = `, ${symbolName}`;\n      }\n    }\n  } else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `${symbolName}`;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = node.getFullText(source);\n    if (text.match(/^\\r?\\n/)) {\n      toInsert = `,${text.match(/^\\r?\\n(\\r?)\\s*/)[0]}${symbolName}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n  if (importPath !== null) {\n    return [\n      new InsertChange(ngModulePath, position, toInsert),\n      insertImport(source, ngModulePath, symbolName.replace(/\\..*$/, ''), importPath),\n    ];\n  }\n\n  return [new InsertChange(ngModulePath, position, toInsert)];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(source: ts.SourceFile,\n                                       modulePath: string, classifiedName: string,\n                                       importPath: string): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source, modulePath, 'declarations', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an NgModule into NgModule imports. It also imports the module.\n */\nexport function addImportToModule(source: ts.SourceFile,\n                                  modulePath: string, classifiedName: string,\n                                  importPath: string): Change[] {\n\n  return addSymbolToNgModuleMetadata(source, modulePath, 'imports', classifiedName, importPath);\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(source: ts.SourceFile,\n                                  modulePath: string, classifiedName: string,\n                                  importPath: string): Change[] {\n  return addSymbolToNgModuleMetadata(source, modulePath, 'exports', classifiedName, importPath);\n}\n\nexport function findBootstrapModuleCall(host: Tree, mainPath: string): ts.CallExpression | null {\n  const mainBuffer = host.read(mainPath);\n  if (!mainBuffer) {\n    throw new SchematicsException(`Main file (${mainPath}) not found`);\n  }\n  const mainText = mainBuffer.toString('utf-8');\n  const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);\n\n  const allNodes = getSourceNodes(source);\n\n  let bootstrapCall: ts.CallExpression | null = null;\n\n  for (const node of allNodes) {\n\n    let bootstrapCallNode: ts.Node | null = null;\n    bootstrapCallNode = findNode(node, ts.SyntaxKind.Identifier, 'bootstrapModule');\n\n    // Walk up the parent until CallExpression is found.\n    while (bootstrapCallNode && bootstrapCallNode.parent\n    && bootstrapCallNode.parent.kind !== ts.SyntaxKind.CallExpression) {\n\n      bootstrapCallNode = bootstrapCallNode.parent;\n    }\n\n    if (bootstrapCallNode !== null &&\n      bootstrapCallNode.parent !== undefined &&\n      bootstrapCallNode.parent.kind === ts.SyntaxKind.CallExpression) {\n      bootstrapCall = bootstrapCallNode.parent as ts.CallExpression;\n      break;\n    }\n  }\n\n  return bootstrapCall;\n}\n\nexport function findBootstrapModulePath(host: Tree, mainPath: string): string {\n  const bootstrapCall = findBootstrapModuleCall(host, mainPath);\n  if (!bootstrapCall) {\n    throw new SchematicsException('Bootstrap call not found');\n  }\n\n  const bootstrapModule = bootstrapCall.arguments[0];\n\n  const mainBuffer = host.read(mainPath);\n  if (!mainBuffer) {\n    throw new SchematicsException(`Client app main file (${mainPath}) not found`);\n  }\n  const mainText = mainBuffer.toString('utf-8');\n  const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);\n  const allNodes = getSourceNodes(source);\n  const bootstrapModuleRelativePath = allNodes\n    .filter(node => node.kind === ts.SyntaxKind.ImportDeclaration)\n    .filter(imp => {\n      return findNode(imp, ts.SyntaxKind.Identifier, bootstrapModule.getText());\n    })\n    .map(node => {\n      const modulePath = (node as ts.ImportDeclaration).moduleSpecifier as ts.StringLiteral;\n      return modulePath.text;\n    })[0];\n\n  return bootstrapModuleRelativePath;\n}\n\nexport function getAppModulePath(host: Tree, mainPath: string): string {\n  const moduleRelativePath = findBootstrapModulePath(host, mainPath);\n  const mainDir = dirname(mainPath);\n  const modulePath = normalize(`/${mainDir}/${moduleRelativePath}.ts`);\n\n  return modulePath;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.