source: trip-planner-front/node_modules/@angular/cdk/schematics/update-tool/utils/imports.mjs

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: 14.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.getImportOfIdentifier = void 0;
11const ts = require("typescript");
12/** Resolves the import of the specified identifier. */
13function getImportOfIdentifier(node, typeChecker) {
14 // Free standing identifiers which resolve to an import will be handled
15 // as direct imports. e.g. "@Component()" where "Component" is an identifier
16 // referring to an import specifier.
17 const directImport = getSpecificImportOfIdentifier(node, typeChecker);
18 if (directImport !== null) {
19 return directImport;
20 }
21 else if (ts.isQualifiedName(node.parent) && node.parent.right === node) {
22 // Determines the import of a qualified name. e.g. "let t: core.Component". In that
23 // case, the import of the most left identifier will be determined ("core").
24 const qualifierRoot = getQualifiedNameRoot(node.parent);
25 if (qualifierRoot) {
26 const moduleName = getImportOfNamespacedIdentifier(qualifierRoot, typeChecker);
27 if (moduleName) {
28 return { moduleName, symbolName: node.text };
29 }
30 }
31 }
32 else if (ts.isPropertyAccessExpression(node.parent) && node.parent.name === node) {
33 // Determines the import of a property expression. e.g. "@core.Component". In that
34 // case, the import of the most left identifier will be determined ("core").
35 const rootIdentifier = getPropertyAccessRoot(node.parent);
36 if (rootIdentifier) {
37 const moduleName = getImportOfNamespacedIdentifier(rootIdentifier, typeChecker);
38 if (moduleName) {
39 return { moduleName, symbolName: node.text };
40 }
41 }
42 }
43 return null;
44}
45exports.getImportOfIdentifier = getImportOfIdentifier;
46/**
47 * Resolves the import of the specified identifier. Expects the identifier to resolve
48 * to a fine-grained import declaration with import specifiers.
49 */
50function getSpecificImportOfIdentifier(node, typeChecker) {
51 const symbol = typeChecker.getSymbolAtLocation(node);
52 if (!symbol || !symbol.declarations || !symbol.declarations.length) {
53 return null;
54 }
55 const declaration = symbol.declarations[0];
56 if (!ts.isImportSpecifier(declaration)) {
57 return null;
58 }
59 // Since the declaration is an import specifier, we can walk up three times to get a reference
60 // to the import declaration node (NamedImports -> ImportClause -> ImportDeclaration).
61 const importDecl = declaration.parent.parent.parent;
62 if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {
63 return null;
64 }
65 return {
66 moduleName: importDecl.moduleSpecifier.text,
67 symbolName: declaration.propertyName ? declaration.propertyName.text : declaration.name.text
68 };
69}
70/**
71 * Resolves the import of the specified identifier. Expects the identifier to
72 * resolve to a namespaced import declaration. e.g. "import * as core from ...".
73 */
74function getImportOfNamespacedIdentifier(node, typeChecker) {
75 const symbol = typeChecker.getSymbolAtLocation(node);
76 if (!symbol || !symbol.declarations || !symbol.declarations.length) {
77 return null;
78 }
79 const declaration = symbol.declarations[0];
80 if (!ts.isNamespaceImport(declaration)) {
81 return null;
82 }
83 // Since the declaration is a namespace import, we can walk up three times to get a reference
84 // to the import declaration node (NamespaceImport -> ImportClause -> ImportDeclaration).
85 const importDecl = declaration.parent.parent;
86 if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {
87 return null;
88 }
89 return importDecl.moduleSpecifier.text;
90}
91/**
92 * Gets the root identifier of a qualified type chain. For example: "core.GestureConfig"
93 * will return the "core" identifier. Allowing us to find the import of "core".
94 */
95function getQualifiedNameRoot(name) {
96 while (ts.isQualifiedName(name.left)) {
97 name = name.left;
98 }
99 return ts.isIdentifier(name.left) ? name.left : null;
100}
101/**
102 * Gets the root identifier of a property access chain. For example: "core.GestureConfig"
103 * will return the "core" identifier. Allowing us to find the import of "core".
104 */
105function getPropertyAccessRoot(node) {
106 while (ts.isPropertyAccessExpression(node.expression)) {
107 node = node.expression;
108 }
109 return ts.isIdentifier(node.expression) ? node.expression : null;
110}
111//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"imports.js","sourceRoot":"","sources":["../../../../../../../../src/cdk/schematics/update-tool/utils/imports.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,iCAAiC;AAWjC,uDAAuD;AACvD,SAAgB,qBAAqB,CAAC,IAAmB,EAAE,WAA2B;IAEpF,uEAAuE;IACvE,4EAA4E;IAC5E,oCAAoC;IACpC,MAAM,YAAY,GAAG,6BAA6B,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IACtE,IAAI,YAAY,KAAK,IAAI,EAAE;QACzB,OAAO,YAAY,CAAC;KACrB;SAAM,IAAI,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,EAAE;QACxE,mFAAmF;QACnF,4EAA4E;QAC5E,MAAM,aAAa,GAAG,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,aAAa,EAAE;YACjB,MAAM,UAAU,GAAG,+BAA+B,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;YAC/E,IAAI,UAAU,EAAE;gBACd,OAAO,EAAC,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC;aAC5C;SACF;KACF;SAAM,IAAI,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,IAAI,EAAE;QAClF,kFAAkF;QAClF,4EAA4E;QAC5E,MAAM,cAAc,GAAG,qBAAqB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1D,IAAI,cAAc,EAAE;YAClB,MAAM,UAAU,GAAG,+BAA+B,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;YAChF,IAAI,UAAU,EAAE;gBACd,OAAO,EAAC,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC;aAC5C;SACF;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AA9BD,sDA8BC;AAED;;;GAGG;AACH,SAAS,6BAA6B,CAAC,IAAmB,EAAE,WAA2B;IAErF,MAAM,MAAM,GAAG,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACrD,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE;QAClE,OAAO,IAAI,CAAC;KACb;IACD,MAAM,WAAW,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC3C,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;QACtC,OAAO,IAAI,CAAC;KACb;IACD,8FAA8F;IAC9F,sFAAsF;IACtF,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC;IACpD,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE;QACnD,OAAO,IAAI,CAAC;KACb;IACD,OAAO;QACL,UAAU,EAAE,UAAU,CAAC,eAAe,CAAC,IAAI;QAC3C,UAAU,EAAE,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI;KAC7F,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,+BAA+B,CAAC,IAAmB,EAAE,WAA2B;IAEvF,MAAM,MAAM,GAAG,WAAW,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACrD,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE;QAClE,OAAO,IAAI,CAAC;KACb;IACD,MAAM,WAAW,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC3C,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;QACtC,OAAO,IAAI,CAAC;KACb;IACD,6FAA6F;IAC7F,yFAAyF;IACzF,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC;IAC7C,IAAI,CAAC,EAAE,CAAC,eAAe,CAAC,UAAU,CAAC,eAAe,CAAC,EAAE;QACnD,OAAO,IAAI,CAAC;KACb;IAED,OAAO,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC;AACzC,CAAC;AAGD;;;GAGG;AACH,SAAS,oBAAoB,CAAC,IAAsB;IAClD,OAAO,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;QACpC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;KAClB;IACD,OAAO,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;AACvD,CAAC;AAED;;;GAGG;AACH,SAAS,qBAAqB,CAAC,IAAiC;IAC9D,OAAO,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;QACrD,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;KACxB;IACD,OAAO,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;AACnE,CAAC","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\nimport * as ts from 'typescript';\n\n/** Interface describing a resolved import. */\nexport interface Import {\n  /** Name of the imported symbol. */\n  symbolName: string;\n  /** Module name from which the symbol has been imported. */\n  moduleName: string;\n}\n\n\n/** Resolves the import of the specified identifier. */\nexport function getImportOfIdentifier(node: ts.Identifier, typeChecker: ts.TypeChecker): Import|\n    null {\n  // Free standing identifiers which resolve to an import will be handled\n  // as direct imports. e.g. \"@Component()\" where \"Component\" is an identifier\n  // referring to an import specifier.\n  const directImport = getSpecificImportOfIdentifier(node, typeChecker);\n  if (directImport !== null) {\n    return directImport;\n  } else if (ts.isQualifiedName(node.parent) && node.parent.right === node) {\n    // Determines the import of a qualified name. e.g. \"let t: core.Component\". In that\n    // case, the import of the most left identifier will be determined (\"core\").\n    const qualifierRoot = getQualifiedNameRoot(node.parent);\n    if (qualifierRoot) {\n      const moduleName = getImportOfNamespacedIdentifier(qualifierRoot, typeChecker);\n      if (moduleName) {\n        return {moduleName, symbolName: node.text};\n      }\n    }\n  } else if (ts.isPropertyAccessExpression(node.parent) && node.parent.name === node) {\n    // Determines the import of a property expression. e.g. \"@core.Component\". In that\n    // case, the import of the most left identifier will be determined (\"core\").\n    const rootIdentifier = getPropertyAccessRoot(node.parent);\n    if (rootIdentifier) {\n      const moduleName = getImportOfNamespacedIdentifier(rootIdentifier, typeChecker);\n      if (moduleName) {\n        return {moduleName, symbolName: node.text};\n      }\n    }\n  }\n  return null;\n}\n\n/**\n * Resolves the import of the specified identifier. Expects the identifier to resolve\n * to a fine-grained import declaration with import specifiers.\n */\nfunction getSpecificImportOfIdentifier(node: ts.Identifier, typeChecker: ts.TypeChecker): Import|\n    null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n  if (!symbol || !symbol.declarations || !symbol.declarations.length) {\n    return null;\n  }\n  const declaration = symbol.declarations[0];\n  if (!ts.isImportSpecifier(declaration)) {\n    return null;\n  }\n  // Since the declaration is an import specifier, we can walk up three times to get a reference\n  // to the import declaration node (NamedImports -> ImportClause -> ImportDeclaration).\n  const importDecl = declaration.parent.parent.parent;\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n  return {\n    moduleName: importDecl.moduleSpecifier.text,\n    symbolName: declaration.propertyName ? declaration.propertyName.text : declaration.name.text\n  };\n}\n\n/**\n * Resolves the import of the specified identifier. Expects the identifier to\n * resolve to a namespaced import declaration. e.g. \"import * as core from ...\".\n */\nfunction getImportOfNamespacedIdentifier(node: ts.Identifier, typeChecker: ts.TypeChecker): string|\n    null {\n  const symbol = typeChecker.getSymbolAtLocation(node);\n  if (!symbol || !symbol.declarations || !symbol.declarations.length) {\n    return null;\n  }\n  const declaration = symbol.declarations[0];\n  if (!ts.isNamespaceImport(declaration)) {\n    return null;\n  }\n  // Since the declaration is a namespace import, we can walk up three times to get a reference\n  // to the import declaration node (NamespaceImport -> ImportClause -> ImportDeclaration).\n  const importDecl = declaration.parent.parent;\n  if (!ts.isStringLiteral(importDecl.moduleSpecifier)) {\n    return null;\n  }\n\n  return importDecl.moduleSpecifier.text;\n}\n\n\n/**\n * Gets the root identifier of a qualified type chain. For example: \"core.GestureConfig\"\n * will return the \"core\" identifier. Allowing us to find the import of \"core\".\n */\nfunction getQualifiedNameRoot(name: ts.QualifiedName): ts.Identifier|null {\n  while (ts.isQualifiedName(name.left)) {\n    name = name.left;\n  }\n  return ts.isIdentifier(name.left) ? name.left : null;\n}\n\n/**\n * Gets the root identifier of a property access chain. For example: \"core.GestureConfig\"\n * will return the \"core\" identifier. Allowing us to find the import of \"core\".\n */\nfunction getPropertyAccessRoot(node: ts.PropertyAccessExpression): ts.Identifier|null {\n  while (ts.isPropertyAccessExpression(node.expression)) {\n    node = node.expression;\n  }\n  return ts.isIdentifier(node.expression) ? node.expression : null;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.