source: trip-planner-front/node_modules/@angular/compiler-cli/src/ngtsc/metadata/src/util.js@ 6a3a178

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

initial commit

  • Property mode set to 100644
File size: 31.5 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler-cli/src/ngtsc/metadata/src/util", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/src/ngtsc/imports", "@angular/compiler-cli/src/ngtsc/reflection", "@angular/compiler-cli/src/ngtsc/util/src/typescript"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.hasInjectableFields = exports.CompoundMetadataReader = exports.extractDirectiveTypeCheckMeta = exports.readStringArrayType = exports.readStringMapType = exports.readStringType = exports.extractReferencesFromType = void 0;
20 var tslib_1 = require("tslib");
21 var ts = require("typescript");
22 var imports_1 = require("@angular/compiler-cli/src/ngtsc/imports");
23 var reflection_1 = require("@angular/compiler-cli/src/ngtsc/reflection");
24 var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
25 function extractReferencesFromType(checker, def, bestGuessOwningModule) {
26 if (!ts.isTupleTypeNode(def)) {
27 return [];
28 }
29 return def.elements.map(function (element) {
30 if (!ts.isTypeQueryNode(element)) {
31 throw new Error("Expected TypeQueryNode: " + typescript_1.nodeDebugInfo(element));
32 }
33 var type = element.exprName;
34 var _a = reflection_1.reflectTypeEntityToDeclaration(type, checker), node = _a.node, from = _a.from;
35 if (!reflection_1.isNamedClassDeclaration(node)) {
36 throw new Error("Expected named ClassDeclaration: " + typescript_1.nodeDebugInfo(node));
37 }
38 if (from !== null && !from.startsWith('.')) {
39 // The symbol was imported using an absolute module specifier so return a reference that
40 // uses that absolute module specifier as its best guess owning module.
41 return new imports_1.Reference(node, { specifier: from, resolutionContext: def.getSourceFile().fileName });
42 }
43 else {
44 // For local symbols or symbols that were imported using a relative module import it is
45 // assumed that the symbol is exported from the provided best guess owning module.
46 return new imports_1.Reference(node, bestGuessOwningModule);
47 }
48 });
49 }
50 exports.extractReferencesFromType = extractReferencesFromType;
51 function readStringType(type) {
52 if (!ts.isLiteralTypeNode(type) || !ts.isStringLiteral(type.literal)) {
53 return null;
54 }
55 return type.literal.text;
56 }
57 exports.readStringType = readStringType;
58 function readStringMapType(type) {
59 if (!ts.isTypeLiteralNode(type)) {
60 return {};
61 }
62 var obj = {};
63 type.members.forEach(function (member) {
64 if (!ts.isPropertySignature(member) || member.type === undefined || member.name === undefined ||
65 !ts.isStringLiteral(member.name)) {
66 return;
67 }
68 var value = readStringType(member.type);
69 if (value === null) {
70 return null;
71 }
72 obj[member.name.text] = value;
73 });
74 return obj;
75 }
76 exports.readStringMapType = readStringMapType;
77 function readStringArrayType(type) {
78 if (!ts.isTupleTypeNode(type)) {
79 return [];
80 }
81 var res = [];
82 type.elements.forEach(function (el) {
83 if (!ts.isLiteralTypeNode(el) || !ts.isStringLiteral(el.literal)) {
84 return;
85 }
86 res.push(el.literal.text);
87 });
88 return res;
89 }
90 exports.readStringArrayType = readStringArrayType;
91 /**
92 * Inspects the class' members and extracts the metadata that is used when type-checking templates
93 * that use the directive. This metadata does not contain information from a base class, if any,
94 * making this metadata invariant to changes of inherited classes.
95 */
96 function extractDirectiveTypeCheckMeta(node, inputs, reflector) {
97 var e_1, _a;
98 var members = reflector.getMembersOfClass(node);
99 var staticMembers = members.filter(function (member) { return member.isStatic; });
100 var ngTemplateGuards = staticMembers.map(extractTemplateGuard)
101 .filter(function (guard) { return guard !== null; });
102 var hasNgTemplateContextGuard = staticMembers.some(function (member) { return member.kind === reflection_1.ClassMemberKind.Method && member.name === 'ngTemplateContextGuard'; });
103 var coercedInputFields = new Set(staticMembers.map(extractCoercedInput)
104 .filter(function (inputName) { return inputName !== null; }));
105 var restrictedInputFields = new Set();
106 var stringLiteralInputFields = new Set();
107 var undeclaredInputFields = new Set();
108 var _loop_1 = function (classPropertyName) {
109 var field = members.find(function (member) { return member.name === classPropertyName; });
110 if (field === undefined || field.node === null) {
111 undeclaredInputFields.add(classPropertyName);
112 return "continue";
113 }
114 if (isRestricted(field.node)) {
115 restrictedInputFields.add(classPropertyName);
116 }
117 if (field.nameNode !== null && ts.isStringLiteral(field.nameNode)) {
118 stringLiteralInputFields.add(classPropertyName);
119 }
120 };
121 try {
122 for (var _b = tslib_1.__values(inputs.classPropertyNames), _c = _b.next(); !_c.done; _c = _b.next()) {
123 var classPropertyName = _c.value;
124 _loop_1(classPropertyName);
125 }
126 }
127 catch (e_1_1) { e_1 = { error: e_1_1 }; }
128 finally {
129 try {
130 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
131 }
132 finally { if (e_1) throw e_1.error; }
133 }
134 var arity = reflector.getGenericArityOfClass(node);
135 return {
136 hasNgTemplateContextGuard: hasNgTemplateContextGuard,
137 ngTemplateGuards: ngTemplateGuards,
138 coercedInputFields: coercedInputFields,
139 restrictedInputFields: restrictedInputFields,
140 stringLiteralInputFields: stringLiteralInputFields,
141 undeclaredInputFields: undeclaredInputFields,
142 isGeneric: arity !== null && arity > 0,
143 };
144 }
145 exports.extractDirectiveTypeCheckMeta = extractDirectiveTypeCheckMeta;
146 function isRestricted(node) {
147 if (node.modifiers === undefined) {
148 return false;
149 }
150 return node.modifiers.some(function (modifier) { return modifier.kind === ts.SyntaxKind.PrivateKeyword ||
151 modifier.kind === ts.SyntaxKind.ProtectedKeyword ||
152 modifier.kind === ts.SyntaxKind.ReadonlyKeyword; });
153 }
154 function extractTemplateGuard(member) {
155 if (!member.name.startsWith('ngTemplateGuard_')) {
156 return null;
157 }
158 var inputName = afterUnderscore(member.name);
159 if (member.kind === reflection_1.ClassMemberKind.Property) {
160 var type = null;
161 if (member.type !== null && ts.isLiteralTypeNode(member.type) &&
162 ts.isStringLiteral(member.type.literal)) {
163 type = member.type.literal.text;
164 }
165 // Only property members with string literal type 'binding' are considered as template guard.
166 if (type !== 'binding') {
167 return null;
168 }
169 return { inputName: inputName, type: type };
170 }
171 else if (member.kind === reflection_1.ClassMemberKind.Method) {
172 return { inputName: inputName, type: 'invocation' };
173 }
174 else {
175 return null;
176 }
177 }
178 function extractCoercedInput(member) {
179 if (member.kind !== reflection_1.ClassMemberKind.Property || !member.name.startsWith('ngAcceptInputType_')) {
180 return null;
181 }
182 return afterUnderscore(member.name);
183 }
184 /**
185 * A `MetadataReader` that reads from an ordered set of child readers until it obtains the requested
186 * metadata.
187 *
188 * This is used to combine `MetadataReader`s that read from different sources (e.g. from a registry
189 * and from .d.ts files).
190 */
191 var CompoundMetadataReader = /** @class */ (function () {
192 function CompoundMetadataReader(readers) {
193 this.readers = readers;
194 }
195 CompoundMetadataReader.prototype.getDirectiveMetadata = function (node) {
196 var e_2, _a;
197 try {
198 for (var _b = tslib_1.__values(this.readers), _c = _b.next(); !_c.done; _c = _b.next()) {
199 var reader = _c.value;
200 var meta = reader.getDirectiveMetadata(node);
201 if (meta !== null) {
202 return meta;
203 }
204 }
205 }
206 catch (e_2_1) { e_2 = { error: e_2_1 }; }
207 finally {
208 try {
209 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
210 }
211 finally { if (e_2) throw e_2.error; }
212 }
213 return null;
214 };
215 CompoundMetadataReader.prototype.getNgModuleMetadata = function (node) {
216 var e_3, _a;
217 try {
218 for (var _b = tslib_1.__values(this.readers), _c = _b.next(); !_c.done; _c = _b.next()) {
219 var reader = _c.value;
220 var meta = reader.getNgModuleMetadata(node);
221 if (meta !== null) {
222 return meta;
223 }
224 }
225 }
226 catch (e_3_1) { e_3 = { error: e_3_1 }; }
227 finally {
228 try {
229 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
230 }
231 finally { if (e_3) throw e_3.error; }
232 }
233 return null;
234 };
235 CompoundMetadataReader.prototype.getPipeMetadata = function (node) {
236 var e_4, _a;
237 try {
238 for (var _b = tslib_1.__values(this.readers), _c = _b.next(); !_c.done; _c = _b.next()) {
239 var reader = _c.value;
240 var meta = reader.getPipeMetadata(node);
241 if (meta !== null) {
242 return meta;
243 }
244 }
245 }
246 catch (e_4_1) { e_4 = { error: e_4_1 }; }
247 finally {
248 try {
249 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
250 }
251 finally { if (e_4) throw e_4.error; }
252 }
253 return null;
254 };
255 return CompoundMetadataReader;
256 }());
257 exports.CompoundMetadataReader = CompoundMetadataReader;
258 function afterUnderscore(str) {
259 var pos = str.indexOf('_');
260 if (pos === -1) {
261 throw new Error("Expected '" + str + "' to contain '_'");
262 }
263 return str.substr(pos + 1);
264 }
265 /** Returns whether a class declaration has the necessary class fields to make it injectable. */
266 function hasInjectableFields(clazz, host) {
267 var members = host.getMembersOfClass(clazz);
268 return members.some(function (_a) {
269 var isStatic = _a.isStatic, name = _a.name;
270 return isStatic && (name === 'ɵprov' || name === 'ɵfac');
271 });
272 }
273 exports.hasInjectableFields = hasInjectableFields;
274});
275//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/metadata/src/util.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\nimport * as ts from 'typescript';\n\nimport {OwningModule, Reference} from '../../imports';\nimport {ClassDeclaration, ClassMember, ClassMemberKind, isNamedClassDeclaration, ReflectionHost, reflectTypeEntityToDeclaration} from '../../reflection';\nimport {nodeDebugInfo} from '../../util/src/typescript';\n\nimport {DirectiveMeta, DirectiveTypeCheckMeta, MetadataReader, NgModuleMeta, PipeMeta, TemplateGuardMeta} from './api';\nimport {ClassPropertyMapping, ClassPropertyName} from './property_mapping';\n\nexport function extractReferencesFromType(\n    checker: ts.TypeChecker, def: ts.TypeNode,\n    bestGuessOwningModule: OwningModule|null): Reference<ClassDeclaration>[] {\n  if (!ts.isTupleTypeNode(def)) {\n    return [];\n  }\n\n  return def.elements.map(element => {\n    if (!ts.isTypeQueryNode(element)) {\n      throw new Error(`Expected TypeQueryNode: ${nodeDebugInfo(element)}`);\n    }\n    const type = element.exprName;\n    const {node, from} = reflectTypeEntityToDeclaration(type, checker);\n    if (!isNamedClassDeclaration(node)) {\n      throw new Error(`Expected named ClassDeclaration: ${nodeDebugInfo(node)}`);\n    }\n    if (from !== null && !from.startsWith('.')) {\n      // The symbol was imported using an absolute module specifier so return a reference that\n      // uses that absolute module specifier as its best guess owning module.\n      return new Reference(\n          node, {specifier: from, resolutionContext: def.getSourceFile().fileName});\n    } else {\n      // For local symbols or symbols that were imported using a relative module import it is\n      // assumed that the symbol is exported from the provided best guess owning module.\n      return new Reference(node, bestGuessOwningModule);\n    }\n  });\n}\n\nexport function readStringType(type: ts.TypeNode): string|null {\n  if (!ts.isLiteralTypeNode(type) || !ts.isStringLiteral(type.literal)) {\n    return null;\n  }\n  return type.literal.text;\n}\n\nexport function readStringMapType(type: ts.TypeNode): {[key: string]: string} {\n  if (!ts.isTypeLiteralNode(type)) {\n    return {};\n  }\n  const obj: {[key: string]: string} = {};\n  type.members.forEach(member => {\n    if (!ts.isPropertySignature(member) || member.type === undefined || member.name === undefined ||\n        !ts.isStringLiteral(member.name)) {\n      return;\n    }\n    const value = readStringType(member.type);\n    if (value === null) {\n      return null;\n    }\n    obj[member.name.text] = value;\n  });\n  return obj;\n}\n\nexport function readStringArrayType(type: ts.TypeNode): string[] {\n  if (!ts.isTupleTypeNode(type)) {\n    return [];\n  }\n  const res: string[] = [];\n  type.elements.forEach(el => {\n    if (!ts.isLiteralTypeNode(el) || !ts.isStringLiteral(el.literal)) {\n      return;\n    }\n    res.push(el.literal.text);\n  });\n  return res;\n}\n\n/**\n * Inspects the class' members and extracts the metadata that is used when type-checking templates\n * that use the directive. This metadata does not contain information from a base class, if any,\n * making this metadata invariant to changes of inherited classes.\n */\nexport function extractDirectiveTypeCheckMeta(\n    node: ClassDeclaration, inputs: ClassPropertyMapping,\n    reflector: ReflectionHost): DirectiveTypeCheckMeta {\n  const members = reflector.getMembersOfClass(node);\n  const staticMembers = members.filter(member => member.isStatic);\n  const ngTemplateGuards = staticMembers.map(extractTemplateGuard)\n                               .filter((guard): guard is TemplateGuardMeta => guard !== null);\n  const hasNgTemplateContextGuard = staticMembers.some(\n      member => member.kind === ClassMemberKind.Method && member.name === 'ngTemplateContextGuard');\n\n  const coercedInputFields =\n      new Set(staticMembers.map(extractCoercedInput)\n                  .filter((inputName): inputName is ClassPropertyName => inputName !== null));\n\n  const restrictedInputFields = new Set<ClassPropertyName>();\n  const stringLiteralInputFields = new Set<ClassPropertyName>();\n  const undeclaredInputFields = new Set<ClassPropertyName>();\n\n  for (const classPropertyName of inputs.classPropertyNames) {\n    const field = members.find(member => member.name === classPropertyName);\n    if (field === undefined || field.node === null) {\n      undeclaredInputFields.add(classPropertyName);\n      continue;\n    }\n    if (isRestricted(field.node)) {\n      restrictedInputFields.add(classPropertyName);\n    }\n    if (field.nameNode !== null && ts.isStringLiteral(field.nameNode)) {\n      stringLiteralInputFields.add(classPropertyName);\n    }\n  }\n\n  const arity = reflector.getGenericArityOfClass(node);\n\n  return {\n    hasNgTemplateContextGuard,\n    ngTemplateGuards,\n    coercedInputFields,\n    restrictedInputFields,\n    stringLiteralInputFields,\n    undeclaredInputFields,\n    isGeneric: arity !== null && arity > 0,\n  };\n}\n\nfunction isRestricted(node: ts.Node): boolean {\n  if (node.modifiers === undefined) {\n    return false;\n  }\n\n  return node.modifiers.some(\n      modifier => modifier.kind === ts.SyntaxKind.PrivateKeyword ||\n          modifier.kind === ts.SyntaxKind.ProtectedKeyword ||\n          modifier.kind === ts.SyntaxKind.ReadonlyKeyword);\n}\n\nfunction extractTemplateGuard(member: ClassMember): TemplateGuardMeta|null {\n  if (!member.name.startsWith('ngTemplateGuard_')) {\n    return null;\n  }\n  const inputName = afterUnderscore(member.name);\n  if (member.kind === ClassMemberKind.Property) {\n    let type: string|null = null;\n    if (member.type !== null && ts.isLiteralTypeNode(member.type) &&\n        ts.isStringLiteral(member.type.literal)) {\n      type = member.type.literal.text;\n    }\n\n    // Only property members with string literal type 'binding' are considered as template guard.\n    if (type !== 'binding') {\n      return null;\n    }\n    return {inputName, type};\n  } else if (member.kind === ClassMemberKind.Method) {\n    return {inputName, type: 'invocation'};\n  } else {\n    return null;\n  }\n}\n\nfunction extractCoercedInput(member: ClassMember): string|null {\n  if (member.kind !== ClassMemberKind.Property || !member.name.startsWith('ngAcceptInputType_')) {\n    return null!;\n  }\n  return afterUnderscore(member.name);\n}\n\n/**\n * A `MetadataReader` that reads from an ordered set of child readers until it obtains the requested\n * metadata.\n *\n * This is used to combine `MetadataReader`s that read from different sources (e.g. from a registry\n * and from .d.ts files).\n */\nexport class CompoundMetadataReader implements MetadataReader {\n  constructor(private readers: MetadataReader[]) {}\n\n  getDirectiveMetadata(node: Reference<ClassDeclaration<ts.Declaration>>): DirectiveMeta|null {\n    for (const reader of this.readers) {\n      const meta = reader.getDirectiveMetadata(node);\n      if (meta !== null) {\n        return meta;\n      }\n    }\n    return null;\n  }\n\n  getNgModuleMetadata(node: Reference<ClassDeclaration<ts.Declaration>>): NgModuleMeta|null {\n    for (const reader of this.readers) {\n      const meta = reader.getNgModuleMetadata(node);\n      if (meta !== null) {\n        return meta;\n      }\n    }\n    return null;\n  }\n  getPipeMetadata(node: Reference<ClassDeclaration<ts.Declaration>>): PipeMeta|null {\n    for (const reader of this.readers) {\n      const meta = reader.getPipeMetadata(node);\n      if (meta !== null) {\n        return meta;\n      }\n    }\n    return null;\n  }\n}\n\nfunction afterUnderscore(str: string): string {\n  const pos = str.indexOf('_');\n  if (pos === -1) {\n    throw new Error(`Expected '${str}' to contain '_'`);\n  }\n  return str.substr(pos + 1);\n}\n\n/** Returns whether a class declaration has the necessary class fields to make it injectable. */\nexport function hasInjectableFields(clazz: ClassDeclaration, host: ReflectionHost): boolean {\n  const members = host.getMembersOfClass(clazz);\n  return members.some(({isStatic, name}) => isStatic && (name === 'ɵprov' || name === 'ɵfac'));\n}\n"]}
Note: See TracBrowser for help on using the repository browser.