source: trip-planner-front/node_modules/@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.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: 28.2 KB
Line 
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/linker/src/file_linker/partial_linkers/partial_linker_selector", ["require", "exports", "tslib", "semver", "@angular/compiler-cli/linker/src/file_linker/get_source_file", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_class_metadata_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_component_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_directive_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_factory_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_injectable_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_injector_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_ng_module_linker_1", "@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_pipe_linker_1"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.PartialLinkerSelector = exports.createLinkerMap = exports.declarationFunctions = exports.ɵɵngDeclarePipe = exports.ɵɵngDeclareNgModule = exports.ɵɵngDeclareInjector = exports.ɵɵngDeclareInjectable = exports.ɵɵngDeclareFactory = exports.ɵɵngDeclareComponent = exports.ɵɵngDeclareClassMetadata = exports.ɵɵngDeclareDirective = 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 semver_1 = require("semver");
22 var get_source_file_1 = require("@angular/compiler-cli/linker/src/file_linker/get_source_file");
23 var partial_class_metadata_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_class_metadata_linker_1");
24 var partial_component_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_component_linker_1");
25 var partial_directive_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_directive_linker_1");
26 var partial_factory_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_factory_linker_1");
27 var partial_injectable_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_injectable_linker_1");
28 var partial_injector_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_injector_linker_1");
29 var partial_ng_module_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_ng_module_linker_1");
30 var partial_pipe_linker_1_1 = require("@angular/compiler-cli/linker/src/file_linker/partial_linkers/partial_pipe_linker_1");
31 exports.ɵɵngDeclareDirective = 'ɵɵngDeclareDirective';
32 exports.ɵɵngDeclareClassMetadata = 'ɵɵngDeclareClassMetadata';
33 exports.ɵɵngDeclareComponent = 'ɵɵngDeclareComponent';
34 exports.ɵɵngDeclareFactory = 'ɵɵngDeclareFactory';
35 exports.ɵɵngDeclareInjectable = 'ɵɵngDeclareInjectable';
36 exports.ɵɵngDeclareInjector = 'ɵɵngDeclareInjector';
37 exports.ɵɵngDeclareNgModule = 'ɵɵngDeclareNgModule';
38 exports.ɵɵngDeclarePipe = 'ɵɵngDeclarePipe';
39 exports.declarationFunctions = [
40 exports.ɵɵngDeclareDirective, exports.ɵɵngDeclareClassMetadata, exports.ɵɵngDeclareComponent, exports.ɵɵngDeclareFactory,
41 exports.ɵɵngDeclareInjectable, exports.ɵɵngDeclareInjector, exports.ɵɵngDeclareNgModule, exports.ɵɵngDeclarePipe
42 ];
43 /**
44 * Create a mapping between partial-declaration call name and collections of partial-linkers.
45 *
46 * Each collection of partial-linkers will contain a version range that will be matched against the
47 * `minVersion` of the partial-declaration. (Additionally, a partial-linker may modify its behaviour
48 * internally based on the `version` property of the declaration.)
49 *
50 * Versions should be sorted in ascending order. The most recent partial-linker will be used as the
51 * fallback linker if none of the other version ranges match. For example:
52 *
53 * ```
54 * {range: getRange('<=', '13.0.0'), linker PartialDirectiveLinkerVersion2(...) },
55 * {range: getRange('<=', '13.1.0'), linker PartialDirectiveLinkerVersion3(...) },
56 * {range: getRange('<=', '14.0.0'), linker PartialDirectiveLinkerVersion4(...) },
57 * {range: LATEST_VERSION_RANGE, linker: new PartialDirectiveLinkerVersion1(...)},
58 * ```
59 *
60 * If the `LATEST_VERSION_RANGE` is `<=15.0.0` then the fallback linker would be
61 * `PartialDirectiveLinkerVersion1` for any version greater than `15.0.0`.
62 *
63 * When there is a change to a declaration interface that requires a new partial-linker, the
64 * `minVersion` of the partial-declaration should be updated, the new linker implementation should
65 * be added to the end of the collection, and the version of the previous linker should be updated.
66 */
67 function createLinkerMap(environment, sourceUrl, code) {
68 var linkers = new Map();
69 var LATEST_VERSION_RANGE = getRange('<=', '12.2.9');
70 linkers.set(exports.ɵɵngDeclareDirective, [
71 { range: LATEST_VERSION_RANGE, linker: new partial_directive_linker_1_1.PartialDirectiveLinkerVersion1(sourceUrl, code) },
72 ]);
73 linkers.set(exports.ɵɵngDeclareClassMetadata, [
74 { range: LATEST_VERSION_RANGE, linker: new partial_class_metadata_linker_1_1.PartialClassMetadataLinkerVersion1() },
75 ]);
76 linkers.set(exports.ɵɵngDeclareComponent, [
77 {
78 range: LATEST_VERSION_RANGE,
79 linker: new partial_component_linker_1_1.PartialComponentLinkerVersion1(get_source_file_1.createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl, code)
80 },
81 ]);
82 linkers.set(exports.ɵɵngDeclareFactory, [
83 { range: LATEST_VERSION_RANGE, linker: new partial_factory_linker_1_1.PartialFactoryLinkerVersion1() },
84 ]);
85 linkers.set(exports.ɵɵngDeclareInjectable, [
86 { range: LATEST_VERSION_RANGE, linker: new partial_injectable_linker_1_1.PartialInjectableLinkerVersion1() },
87 ]);
88 linkers.set(exports.ɵɵngDeclareInjector, [
89 { range: LATEST_VERSION_RANGE, linker: new partial_injector_linker_1_1.PartialInjectorLinkerVersion1() },
90 ]);
91 linkers.set(exports.ɵɵngDeclareNgModule, [
92 {
93 range: LATEST_VERSION_RANGE,
94 linker: new partial_ng_module_linker_1_1.PartialNgModuleLinkerVersion1(environment.options.linkerJitMode)
95 },
96 ]);
97 linkers.set(exports.ɵɵngDeclarePipe, [
98 { range: LATEST_VERSION_RANGE, linker: new partial_pipe_linker_1_1.PartialPipeLinkerVersion1() },
99 ]);
100 return linkers;
101 }
102 exports.createLinkerMap = createLinkerMap;
103 /**
104 * A helper that selects the appropriate `PartialLinker` for a given declaration.
105 *
106 * The selection is made from a database of linker instances, chosen if their given semver range
107 * satisfies the `minVersion` of the partial declaration to be linked.
108 *
109 * Note that the ranges are checked in order, and the first matching range will be selected. So
110 * ranges should be most restrictive first. In practice, since ranges are always `<=X.Y.Z` this
111 * means that ranges should be in ascending order.
112 *
113 * Note that any "pre-release" versions are stripped from ranges. Therefore if a `minVersion` is
114 * `11.1.0-next.1` then this would match `11.1.0-next.2` and also `12.0.0-next.1`. (This is
115 * different to standard semver range checking, where pre-release versions do not cross full version
116 * boundaries.)
117 */
118 var PartialLinkerSelector = /** @class */ (function () {
119 function PartialLinkerSelector(linkers, logger, unknownDeclarationVersionHandling) {
120 this.linkers = linkers;
121 this.logger = logger;
122 this.unknownDeclarationVersionHandling = unknownDeclarationVersionHandling;
123 }
124 /**
125 * Returns true if there are `PartialLinker` classes that can handle functions with this name.
126 */
127 PartialLinkerSelector.prototype.supportsDeclaration = function (functionName) {
128 return this.linkers.has(functionName);
129 };
130 /**
131 * Returns the `PartialLinker` that can handle functions with the given name and version.
132 * Throws an error if there is none.
133 */
134 PartialLinkerSelector.prototype.getLinker = function (functionName, minVersion, version) {
135 var e_1, _a;
136 if (!this.linkers.has(functionName)) {
137 throw new Error("Unknown partial declaration function " + functionName + ".");
138 }
139 var linkerRanges = this.linkers.get(functionName);
140 if (version === '12.2.9') {
141 // Special case if the `version` is the same as the current compiler version.
142 // This helps with compliance tests where the version placeholders have not been replaced.
143 return linkerRanges[linkerRanges.length - 1].linker;
144 }
145 var declarationRange = getRange('>=', minVersion);
146 try {
147 for (var linkerRanges_1 = tslib_1.__values(linkerRanges), linkerRanges_1_1 = linkerRanges_1.next(); !linkerRanges_1_1.done; linkerRanges_1_1 = linkerRanges_1.next()) {
148 var _b = linkerRanges_1_1.value, linkerRange = _b.range, linker = _b.linker;
149 if (semver_1.intersects(declarationRange, linkerRange)) {
150 return linker;
151 }
152 }
153 }
154 catch (e_1_1) { e_1 = { error: e_1_1 }; }
155 finally {
156 try {
157 if (linkerRanges_1_1 && !linkerRanges_1_1.done && (_a = linkerRanges_1.return)) _a.call(linkerRanges_1);
158 }
159 finally { if (e_1) throw e_1.error; }
160 }
161 var message = "This application depends upon a library published using Angular version " + version + ", " +
162 ("which requires Angular version " + minVersion + " or newer to work correctly.\n") +
163 "Consider upgrading your application to use a more recent version of Angular.";
164 if (this.unknownDeclarationVersionHandling === 'error') {
165 throw new Error(message);
166 }
167 else if (this.unknownDeclarationVersionHandling === 'warn') {
168 this.logger.warn(message + "\nAttempting to continue using this version of Angular.");
169 }
170 // No linker was matched for this declaration, so just use the most recent one.
171 return linkerRanges[linkerRanges.length - 1].linker;
172 };
173 return PartialLinkerSelector;
174 }());
175 exports.PartialLinkerSelector = PartialLinkerSelector;
176 /**
177 * Compute a semver Range from the `version` and comparator.
178 *
179 * The range is computed as any version greater/less than or equal to the given `versionStr`
180 * depending upon the `comparator` (ignoring any prerelease versions).
181 *
182 * @param comparator a string that determines whether the version specifies a minimum or a maximum
183 * range.
184 * @param versionStr the version given in the partial declaration
185 * @returns A semver range for the provided `version` and comparator.
186 */
187 function getRange(comparator, versionStr) {
188 var version = new semver_1.SemVer(versionStr);
189 // Wipe out any prerelease versions
190 version.prerelease = [];
191 return new semver_1.Range("" + comparator + version.format());
192 }
193});
194//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"partial_linker_selector.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.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 {intersects, Range, SemVer} from 'semver';\n\nimport {AbsoluteFsPath} from '../../../../src/ngtsc/file_system';\nimport {Logger} from '../../../../src/ngtsc/logging';\nimport {createGetSourceFile} from '../get_source_file';\nimport {LinkerEnvironment} from '../linker_environment';\n\nimport {PartialClassMetadataLinkerVersion1} from './partial_class_metadata_linker_1';\nimport {PartialComponentLinkerVersion1} from './partial_component_linker_1';\nimport {PartialDirectiveLinkerVersion1} from './partial_directive_linker_1';\nimport {PartialFactoryLinkerVersion1} from './partial_factory_linker_1';\nimport {PartialInjectableLinkerVersion1} from './partial_injectable_linker_1';\nimport {PartialInjectorLinkerVersion1} from './partial_injector_linker_1';\nimport {PartialLinker} from './partial_linker';\nimport {PartialNgModuleLinkerVersion1} from './partial_ng_module_linker_1';\nimport {PartialPipeLinkerVersion1} from './partial_pipe_linker_1';\n\nexport const ɵɵngDeclareDirective = 'ɵɵngDeclareDirective';\nexport const ɵɵngDeclareClassMetadata = 'ɵɵngDeclareClassMetadata';\nexport const ɵɵngDeclareComponent = 'ɵɵngDeclareComponent';\nexport const ɵɵngDeclareFactory = 'ɵɵngDeclareFactory';\nexport const ɵɵngDeclareInjectable = 'ɵɵngDeclareInjectable';\nexport const ɵɵngDeclareInjector = 'ɵɵngDeclareInjector';\nexport const ɵɵngDeclareNgModule = 'ɵɵngDeclareNgModule';\nexport const ɵɵngDeclarePipe = 'ɵɵngDeclarePipe';\nexport const declarationFunctions = [\n  ɵɵngDeclareDirective, ɵɵngDeclareClassMetadata, ɵɵngDeclareComponent, ɵɵngDeclareFactory,\n  ɵɵngDeclareInjectable, ɵɵngDeclareInjector, ɵɵngDeclareNgModule, ɵɵngDeclarePipe\n];\n\nexport interface LinkerRange<TExpression> {\n  range: Range;\n  linker: PartialLinker<TExpression>;\n}\n\n/**\n * Create a mapping between partial-declaration call name and collections of partial-linkers.\n *\n * Each collection of partial-linkers will contain a version range that will be matched against the\n * `minVersion` of the partial-declaration. (Additionally, a partial-linker may modify its behaviour\n * internally based on the `version` property of the declaration.)\n *\n * Versions should be sorted in ascending order. The most recent partial-linker will be used as the\n * fallback linker if none of the other version ranges match. For example:\n *\n * ```\n * {range: getRange('<=', '13.0.0'), linker PartialDirectiveLinkerVersion2(...) },\n * {range: getRange('<=', '13.1.0'), linker PartialDirectiveLinkerVersion3(...) },\n * {range: getRange('<=', '14.0.0'), linker PartialDirectiveLinkerVersion4(...) },\n * {range: LATEST_VERSION_RANGE, linker: new PartialDirectiveLinkerVersion1(...)},\n * ```\n *\n * If the `LATEST_VERSION_RANGE` is `<=15.0.0` then the fallback linker would be\n * `PartialDirectiveLinkerVersion1` for any version greater than `15.0.0`.\n *\n * When there is a change to a declaration interface that requires a new partial-linker, the\n * `minVersion` of the partial-declaration should be updated, the new linker implementation should\n * be added to the end of the collection, and the version of the previous linker should be updated.\n */\nexport function createLinkerMap<TStatement, TExpression>(\n    environment: LinkerEnvironment<TStatement, TExpression>, sourceUrl: AbsoluteFsPath,\n    code: string): Map<string, LinkerRange<TExpression>[]> {\n  const linkers = new Map<string, LinkerRange<TExpression>[]>();\n  const LATEST_VERSION_RANGE = getRange('<=', '0.0.0-PLACEHOLDER');\n\n  linkers.set(ɵɵngDeclareDirective, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialDirectiveLinkerVersion1(sourceUrl, code)},\n  ]);\n  linkers.set(ɵɵngDeclareClassMetadata, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialClassMetadataLinkerVersion1()},\n  ]);\n  linkers.set(ɵɵngDeclareComponent, [\n    {\n      range: LATEST_VERSION_RANGE,\n      linker: new PartialComponentLinkerVersion1(\n          createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl, code)\n    },\n  ]);\n  linkers.set(ɵɵngDeclareFactory, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialFactoryLinkerVersion1()},\n  ]);\n  linkers.set(ɵɵngDeclareInjectable, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialInjectableLinkerVersion1()},\n  ]);\n  linkers.set(ɵɵngDeclareInjector, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialInjectorLinkerVersion1()},\n  ]);\n  linkers.set(ɵɵngDeclareNgModule, [\n    {\n      range: LATEST_VERSION_RANGE,\n      linker: new PartialNgModuleLinkerVersion1(environment.options.linkerJitMode)\n    },\n  ]);\n  linkers.set(ɵɵngDeclarePipe, [\n    {range: LATEST_VERSION_RANGE, linker: new PartialPipeLinkerVersion1()},\n  ]);\n\n  return linkers;\n}\n\n/**\n * A helper that selects the appropriate `PartialLinker` for a given declaration.\n *\n * The selection is made from a database of linker instances, chosen if their given semver range\n * satisfies the `minVersion` of the partial declaration to be linked.\n *\n * Note that the ranges are checked in order, and the first matching range will be selected. So\n * ranges should be most restrictive first. In practice, since ranges are always `<=X.Y.Z` this\n * means that ranges should be in ascending order.\n *\n * Note that any \"pre-release\" versions are stripped from ranges. Therefore if a `minVersion` is\n * `11.1.0-next.1` then this would match `11.1.0-next.2` and also `12.0.0-next.1`. (This is\n * different to standard semver range checking, where pre-release versions do not cross full version\n * boundaries.)\n */\nexport class PartialLinkerSelector<TExpression> {\n  constructor(\n      private readonly linkers: Map<string, LinkerRange<TExpression>[]>,\n      private readonly logger: Logger,\n      private readonly unknownDeclarationVersionHandling: 'ignore'|'warn'|'error') {}\n\n  /**\n   * Returns true if there are `PartialLinker` classes that can handle functions with this name.\n   */\n  supportsDeclaration(functionName: string): boolean {\n    return this.linkers.has(functionName);\n  }\n\n  /**\n   * Returns the `PartialLinker` that can handle functions with the given name and version.\n   * Throws an error if there is none.\n   */\n  getLinker(functionName: string, minVersion: string, version: string): PartialLinker<TExpression> {\n    if (!this.linkers.has(functionName)) {\n      throw new Error(`Unknown partial declaration function ${functionName}.`);\n    }\n    const linkerRanges = this.linkers.get(functionName)!;\n\n    if (version === '0.0.0-PLACEHOLDER') {\n      // Special case if the `version` is the same as the current compiler version.\n      // This helps with compliance tests where the version placeholders have not been replaced.\n      return linkerRanges[linkerRanges.length - 1].linker;\n    }\n\n    const declarationRange = getRange('>=', minVersion);\n    for (const {range: linkerRange, linker} of linkerRanges) {\n      if (intersects(declarationRange, linkerRange)) {\n        return linker;\n      }\n    }\n\n    const message =\n        `This application depends upon a library published using Angular version ${version}, ` +\n        `which requires Angular version ${minVersion} or newer to work correctly.\\n` +\n        `Consider upgrading your application to use a more recent version of Angular.`;\n\n    if (this.unknownDeclarationVersionHandling === 'error') {\n      throw new Error(message);\n    } else if (this.unknownDeclarationVersionHandling === 'warn') {\n      this.logger.warn(`${message}\\nAttempting to continue using this version of Angular.`);\n    }\n\n    // No linker was matched for this declaration, so just use the most recent one.\n    return linkerRanges[linkerRanges.length - 1].linker;\n  }\n}\n\n/**\n * Compute a semver Range from the `version` and comparator.\n *\n * The range is computed as any version greater/less than or equal to the given `versionStr`\n * depending upon the `comparator` (ignoring any prerelease versions).\n *\n * @param comparator a string that determines whether the version specifies a minimum or a maximum\n *     range.\n * @param versionStr the version given in the partial declaration\n * @returns A semver range for the provided `version` and comparator.\n */\nfunction getRange(comparator: '<='|'>=', versionStr: string): Range {\n  const version = new SemVer(versionStr);\n  // Wipe out any prerelease versions\n  version.prerelease = [];\n  return new Range(`${comparator}${version.format()}`);\n}\n"]}
Note: See TracBrowser for help on using the repository browser.