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/packages/entry_point", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/ngcc/src/host/umd_host", "@angular/compiler-cli/ngcc/src/utils"], factory);
|
---|
8 | }
|
---|
9 | })(function (require, exports) {
|
---|
10 | "use strict";
|
---|
11 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
12 | exports.getEntryPointFormat = exports.isEntryPoint = exports.getEntryPointInfo = exports.INCOMPATIBLE_ENTRY_POINT = exports.IGNORED_ENTRY_POINT = exports.NO_ENTRY_POINT = exports.SUPPORTED_FORMAT_PROPERTIES = 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 ts = require("typescript");
|
---|
22 | var umd_host_1 = require("@angular/compiler-cli/ngcc/src/host/umd_host");
|
---|
23 | var utils_1 = require("@angular/compiler-cli/ngcc/src/utils");
|
---|
24 | // We need to keep the elements of this const and the `EntryPointJsonProperty` type in sync.
|
---|
25 | exports.SUPPORTED_FORMAT_PROPERTIES = ['fesm2015', 'fesm5', 'es2015', 'esm2015', 'esm5', 'main', 'module', 'browser'];
|
---|
26 | /**
|
---|
27 | * The path does not represent an entry-point, i.e. there is no package.json at the path and there
|
---|
28 | * is no config to force an entry-point.
|
---|
29 | */
|
---|
30 | exports.NO_ENTRY_POINT = 'no-entry-point';
|
---|
31 | /**
|
---|
32 | * The path represents an entry-point that is `ignored` by an ngcc config.
|
---|
33 | */
|
---|
34 | exports.IGNORED_ENTRY_POINT = 'ignored-entry-point';
|
---|
35 | /**
|
---|
36 | * The path has a package.json, but it is not a valid entry-point for ngcc processing.
|
---|
37 | */
|
---|
38 | exports.INCOMPATIBLE_ENTRY_POINT = 'incompatible-entry-point';
|
---|
39 | /**
|
---|
40 | * Try to create an entry-point from the given paths and properties.
|
---|
41 | *
|
---|
42 | * @param packagePath the absolute path to the containing npm package
|
---|
43 | * @param entryPointPath the absolute path to the potential entry-point.
|
---|
44 | * @returns
|
---|
45 | * - An entry-point if it is valid and not ignored.
|
---|
46 | * - `NO_ENTRY_POINT` when there is no package.json at the path and there is no config to force an
|
---|
47 | * entry-point,
|
---|
48 | * - `IGNORED_ENTRY_POINT` when the entry-point is ignored by an ngcc config.
|
---|
49 | * - `INCOMPATIBLE_ENTRY_POINT` when there is a package.json but it is not a valid Angular compiled
|
---|
50 | * entry-point.
|
---|
51 | */
|
---|
52 | function getEntryPointInfo(fs, config, logger, packagePath, entryPointPath) {
|
---|
53 | var packagePackageJsonPath = fs.resolve(packagePath, 'package.json');
|
---|
54 | var entryPointPackageJsonPath = fs.resolve(entryPointPath, 'package.json');
|
---|
55 | var loadedPackagePackageJson = loadPackageJson(fs, packagePackageJsonPath);
|
---|
56 | var loadedEntryPointPackageJson = (packagePackageJsonPath === entryPointPackageJsonPath) ?
|
---|
57 | loadedPackagePackageJson :
|
---|
58 | loadPackageJson(fs, entryPointPackageJsonPath);
|
---|
59 | var _a = getPackageNameAndVersion(fs, packagePath, loadedPackagePackageJson, loadedEntryPointPackageJson), packageName = _a.packageName, packageVersion = _a.packageVersion;
|
---|
60 | var packageConfig = config.getPackageConfig(packageName, packagePath, packageVersion);
|
---|
61 | var entryPointConfig = packageConfig.entryPoints.get(entryPointPath);
|
---|
62 | var entryPointPackageJson;
|
---|
63 | if (entryPointConfig === undefined) {
|
---|
64 | if (!fs.exists(entryPointPackageJsonPath)) {
|
---|
65 | // No `package.json` and no config.
|
---|
66 | return exports.NO_ENTRY_POINT;
|
---|
67 | }
|
---|
68 | else if (loadedEntryPointPackageJson === null) {
|
---|
69 | // `package.json` exists but could not be parsed and there is no redeeming config.
|
---|
70 | logger.warn("Failed to read entry point info from invalid 'package.json' file: " + entryPointPackageJsonPath);
|
---|
71 | return exports.INCOMPATIBLE_ENTRY_POINT;
|
---|
72 | }
|
---|
73 | else {
|
---|
74 | entryPointPackageJson = loadedEntryPointPackageJson;
|
---|
75 | }
|
---|
76 | }
|
---|
77 | else if (entryPointConfig.ignore === true) {
|
---|
78 | // Explicitly ignored entry-point.
|
---|
79 | return exports.IGNORED_ENTRY_POINT;
|
---|
80 | }
|
---|
81 | else {
|
---|
82 | entryPointPackageJson = mergeConfigAndPackageJson(fs, loadedEntryPointPackageJson, entryPointConfig, packagePath, entryPointPath);
|
---|
83 | }
|
---|
84 | var typings = entryPointPackageJson.typings || entryPointPackageJson.types ||
|
---|
85 | guessTypingsFromPackageJson(fs, entryPointPath, entryPointPackageJson);
|
---|
86 | if (typeof typings !== 'string') {
|
---|
87 | // Missing the required `typings` property
|
---|
88 | return exports.INCOMPATIBLE_ENTRY_POINT;
|
---|
89 | }
|
---|
90 | // An entry-point is assumed to be compiled by Angular if there is either:
|
---|
91 | // * a `metadata.json` file next to the typings entry-point
|
---|
92 | // * a custom config for this entry-point
|
---|
93 | var metadataPath = fs.resolve(entryPointPath, typings.replace(/\.d\.ts$/, '') + '.metadata.json');
|
---|
94 | var compiledByAngular = entryPointConfig !== undefined || fs.exists(metadataPath);
|
---|
95 | var entryPointInfo = {
|
---|
96 | name: entryPointPackageJson.name,
|
---|
97 | path: entryPointPath,
|
---|
98 | packageName: packageName,
|
---|
99 | packagePath: packagePath,
|
---|
100 | packageJson: entryPointPackageJson,
|
---|
101 | typings: fs.resolve(entryPointPath, typings),
|
---|
102 | compiledByAngular: compiledByAngular,
|
---|
103 | ignoreMissingDependencies: entryPointConfig !== undefined ? !!entryPointConfig.ignoreMissingDependencies : false,
|
---|
104 | generateDeepReexports: entryPointConfig !== undefined ? !!entryPointConfig.generateDeepReexports : false,
|
---|
105 | };
|
---|
106 | return entryPointInfo;
|
---|
107 | }
|
---|
108 | exports.getEntryPointInfo = getEntryPointInfo;
|
---|
109 | function isEntryPoint(result) {
|
---|
110 | return result !== exports.NO_ENTRY_POINT && result !== exports.INCOMPATIBLE_ENTRY_POINT &&
|
---|
111 | result !== exports.IGNORED_ENTRY_POINT;
|
---|
112 | }
|
---|
113 | exports.isEntryPoint = isEntryPoint;
|
---|
114 | /**
|
---|
115 | * Convert a package.json property into an entry-point format.
|
---|
116 | *
|
---|
117 | * @param property The property to convert to a format.
|
---|
118 | * @returns An entry-point format or `undefined` if none match the given property.
|
---|
119 | */
|
---|
120 | function getEntryPointFormat(fs, entryPoint, property) {
|
---|
121 | switch (property) {
|
---|
122 | case 'fesm2015':
|
---|
123 | return 'esm2015';
|
---|
124 | case 'fesm5':
|
---|
125 | return 'esm5';
|
---|
126 | case 'es2015':
|
---|
127 | return 'esm2015';
|
---|
128 | case 'esm2015':
|
---|
129 | return 'esm2015';
|
---|
130 | case 'esm5':
|
---|
131 | return 'esm5';
|
---|
132 | case 'browser':
|
---|
133 | var browserFile = entryPoint.packageJson['browser'];
|
---|
134 | if (typeof browserFile !== 'string') {
|
---|
135 | return undefined;
|
---|
136 | }
|
---|
137 | return sniffModuleFormat(fs, fs.join(entryPoint.path, browserFile));
|
---|
138 | case 'main':
|
---|
139 | var mainFile = entryPoint.packageJson['main'];
|
---|
140 | if (mainFile === undefined) {
|
---|
141 | return undefined;
|
---|
142 | }
|
---|
143 | return sniffModuleFormat(fs, fs.join(entryPoint.path, mainFile));
|
---|
144 | case 'module':
|
---|
145 | var moduleFilePath = entryPoint.packageJson['module'];
|
---|
146 | // As of version 10, the `module` property in `package.json` should point to
|
---|
147 | // the ESM2015 format output as per Angular Package format specification. This
|
---|
148 | // means that the `module` property captures multiple formats, as old libraries
|
---|
149 | // built with the old APF can still be processed. We detect the format by checking
|
---|
150 | // the paths that should be used as per APF specification.
|
---|
151 | if (typeof moduleFilePath === 'string' && moduleFilePath.includes('esm2015')) {
|
---|
152 | return "esm2015";
|
---|
153 | }
|
---|
154 | return 'esm5';
|
---|
155 | default:
|
---|
156 | return undefined;
|
---|
157 | }
|
---|
158 | }
|
---|
159 | exports.getEntryPointFormat = getEntryPointFormat;
|
---|
160 | /**
|
---|
161 | * Parse the JSON from a `package.json` file.
|
---|
162 | * @param packageJsonPath the absolute path to the `package.json` file.
|
---|
163 | * @returns JSON from the `package.json` file if it is valid, `null` otherwise.
|
---|
164 | */
|
---|
165 | function loadPackageJson(fs, packageJsonPath) {
|
---|
166 | try {
|
---|
167 | return JSON.parse(fs.readFile(packageJsonPath));
|
---|
168 | }
|
---|
169 | catch (_a) {
|
---|
170 | return null;
|
---|
171 | }
|
---|
172 | }
|
---|
173 | function sniffModuleFormat(fs, sourceFilePath) {
|
---|
174 | var resolvedPath = utils_1.resolveFileWithPostfixes(fs, sourceFilePath, ['', '.js', '/index.js']);
|
---|
175 | if (resolvedPath === null) {
|
---|
176 | return undefined;
|
---|
177 | }
|
---|
178 | var sourceFile = ts.createSourceFile(sourceFilePath, fs.readFile(resolvedPath), ts.ScriptTarget.ES5);
|
---|
179 | if (sourceFile.statements.length === 0) {
|
---|
180 | return undefined;
|
---|
181 | }
|
---|
182 | if (ts.isExternalModule(sourceFile)) {
|
---|
183 | return 'esm5';
|
---|
184 | }
|
---|
185 | else if (umd_host_1.parseStatementForUmdModule(sourceFile.statements[0]) !== null) {
|
---|
186 | return 'umd';
|
---|
187 | }
|
---|
188 | else {
|
---|
189 | return 'commonjs';
|
---|
190 | }
|
---|
191 | }
|
---|
192 | function mergeConfigAndPackageJson(fs, entryPointPackageJson, entryPointConfig, packagePath, entryPointPath) {
|
---|
193 | if (entryPointPackageJson !== null) {
|
---|
194 | return tslib_1.__assign(tslib_1.__assign({}, entryPointPackageJson), entryPointConfig.override);
|
---|
195 | }
|
---|
196 | else {
|
---|
197 | var name = fs.basename(packagePath) + "/" + fs.relative(packagePath, entryPointPath);
|
---|
198 | return tslib_1.__assign({ name: name }, entryPointConfig.override);
|
---|
199 | }
|
---|
200 | }
|
---|
201 | function guessTypingsFromPackageJson(fs, entryPointPath, entryPointPackageJson) {
|
---|
202 | var e_1, _a;
|
---|
203 | try {
|
---|
204 | for (var SUPPORTED_FORMAT_PROPERTIES_1 = tslib_1.__values(exports.SUPPORTED_FORMAT_PROPERTIES), SUPPORTED_FORMAT_PROPERTIES_1_1 = SUPPORTED_FORMAT_PROPERTIES_1.next(); !SUPPORTED_FORMAT_PROPERTIES_1_1.done; SUPPORTED_FORMAT_PROPERTIES_1_1 = SUPPORTED_FORMAT_PROPERTIES_1.next()) {
|
---|
205 | var prop = SUPPORTED_FORMAT_PROPERTIES_1_1.value;
|
---|
206 | var field = entryPointPackageJson[prop];
|
---|
207 | if (typeof field !== 'string') {
|
---|
208 | // Some crazy packages have things like arrays in these fields!
|
---|
209 | continue;
|
---|
210 | }
|
---|
211 | var relativeTypingsPath = field.replace(/\.js$/, '.d.ts');
|
---|
212 | var typingsPath = fs.resolve(entryPointPath, relativeTypingsPath);
|
---|
213 | if (fs.exists(typingsPath)) {
|
---|
214 | return typingsPath;
|
---|
215 | }
|
---|
216 | }
|
---|
217 | }
|
---|
218 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
219 | finally {
|
---|
220 | try {
|
---|
221 | if (SUPPORTED_FORMAT_PROPERTIES_1_1 && !SUPPORTED_FORMAT_PROPERTIES_1_1.done && (_a = SUPPORTED_FORMAT_PROPERTIES_1.return)) _a.call(SUPPORTED_FORMAT_PROPERTIES_1);
|
---|
222 | }
|
---|
223 | finally { if (e_1) throw e_1.error; }
|
---|
224 | }
|
---|
225 | return null;
|
---|
226 | }
|
---|
227 | /**
|
---|
228 | * Find or infer the name and version of a package.
|
---|
229 | *
|
---|
230 | * - The name is computed based on the `name` property of the package's or the entry-point's
|
---|
231 | * `package.json` file (if available) or inferred from the package's path.
|
---|
232 | * - The version is read off of the `version` property of the package's `package.json` file (if
|
---|
233 | * available).
|
---|
234 | *
|
---|
235 | * @param fs The file-system to use for processing `packagePath`.
|
---|
236 | * @param packagePath the absolute path to the package.
|
---|
237 | * @param packagePackageJson the parsed `package.json` of the package (if available).
|
---|
238 | * @param entryPointPackageJson the parsed `package.json` of an entry-point (if available).
|
---|
239 | * @returns the computed name and version of the package.
|
---|
240 | */
|
---|
241 | function getPackageNameAndVersion(fs, packagePath, packagePackageJson, entryPointPackageJson) {
|
---|
242 | var _a;
|
---|
243 | var packageName;
|
---|
244 | if (packagePackageJson !== null) {
|
---|
245 | // We have a valid `package.json` for the package: Get the package name from that.
|
---|
246 | packageName = packagePackageJson.name;
|
---|
247 | }
|
---|
248 | else if (entryPointPackageJson !== null) {
|
---|
249 | // We have a valid `package.json` for the entry-point: Get the package name from that.
|
---|
250 | // This might be a secondary entry-point, so make sure we only keep the main package's name
|
---|
251 | // (e.g. only keep `@angular/common` from `@angular/common/http`).
|
---|
252 | packageName = /^(?:@[^/]+\/)?[^/]*/.exec(entryPointPackageJson.name)[0];
|
---|
253 | }
|
---|
254 | else {
|
---|
255 | // We don't have a valid `package.json`: Infer the package name from the package's path.
|
---|
256 | var lastSegment = fs.basename(packagePath);
|
---|
257 | var secondLastSegment = fs.basename(fs.dirname(packagePath));
|
---|
258 | packageName =
|
---|
259 | secondLastSegment.startsWith('@') ? secondLastSegment + "/" + lastSegment : lastSegment;
|
---|
260 | }
|
---|
261 | return {
|
---|
262 | packageName: packageName,
|
---|
263 | packageVersion: (_a = packagePackageJson === null || packagePackageJson === void 0 ? void 0 : packagePackageJson.version) !== null && _a !== void 0 ? _a : null,
|
---|
264 | };
|
---|
265 | }
|
---|
266 | });
|
---|
267 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry_point.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/entry_point.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 * as ts from 'typescript';\n\nimport {AbsoluteFsPath, PathManipulation, ReadonlyFileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {parseStatementForUmdModule} from '../host/umd_host';\nimport {resolveFileWithPostfixes} from '../utils';\n\nimport {NgccConfiguration, NgccEntryPointConfig} from './configuration';\n\n/**\n * The possible values for the format of an entry-point.\n */\nexport type EntryPointFormat = 'esm5'|'esm2015'|'umd'|'commonjs';\n\n/**\n * An object containing information about an entry-point, including paths\n * to each of the possible entry-point formats.\n */\nexport interface EntryPoint extends JsonObject {\n  /** The name of the entry-point (e.g. `@angular/core` or `@angular/common/http`). */\n  name: string;\n  /** The path to this entry point. */\n  path: AbsoluteFsPath;\n  /**\n   * The name of the package that contains this entry-point (e.g. `@angular/core` or\n   * `@angular/common`).\n   */\n  packageName: string;\n  /** The path to the package that contains this entry-point. */\n  packagePath: AbsoluteFsPath;\n  /** The parsed package.json file for this entry-point. */\n  packageJson: EntryPointPackageJson;\n  /** The path to a typings (.d.ts) file for this entry-point. */\n  typings: AbsoluteFsPath;\n  /** Is this EntryPoint compiled with the Angular View Engine compiler? */\n  compiledByAngular: boolean;\n  /** Should ngcc ignore missing dependencies and process this entrypoint anyway? */\n  ignoreMissingDependencies: boolean;\n  /** Should ngcc generate deep re-exports for this entrypoint? */\n  generateDeepReexports: boolean;\n}\n\nexport type JsonPrimitive = string|number|boolean|null;\nexport type JsonValue = JsonPrimitive|JsonArray|JsonObject|undefined;\nexport interface JsonArray extends Array<JsonValue> {}\nexport interface JsonObject {\n  [key: string]: JsonValue;\n}\n\nexport interface PackageJsonFormatPropertiesMap {\n  browser?: string;\n  fesm2015?: string;\n  fesm5?: string;\n  es2015?: string;  // if exists then it is actually FESM2015\n  esm2015?: string;\n  esm5?: string;\n  main?: string;     // UMD\n  module?: string;   // if exists then it is actually FESM5\n  types?: string;    // Synonymous to `typings` property - see https://bit.ly/2OgWp2H\n  typings?: string;  // TypeScript .d.ts files\n}\n\nexport type PackageJsonFormatProperties = keyof PackageJsonFormatPropertiesMap;\n\n/**\n * The properties that may be loaded from the `package.json` file.\n */\nexport interface EntryPointPackageJson extends JsonObject, PackageJsonFormatPropertiesMap {\n  name: string;\n  version?: string;\n  scripts?: Record<string, string>;\n  __processed_by_ivy_ngcc__?: Record<string, string>;\n}\n\nexport type EntryPointJsonProperty = Exclude<PackageJsonFormatProperties, 'types'|'typings'>;\n// We need to keep the elements of this const and the `EntryPointJsonProperty` type in sync.\nexport const SUPPORTED_FORMAT_PROPERTIES: EntryPointJsonProperty[] =\n    ['fesm2015', 'fesm5', 'es2015', 'esm2015', 'esm5', 'main', 'module', 'browser'];\n\n\n/**\n * The path does not represent an entry-point, i.e. there is no package.json at the path and there\n * is no config to force an entry-point.\n */\nexport const NO_ENTRY_POINT = 'no-entry-point';\n\n/**\n * The path represents an entry-point that is `ignored` by an ngcc config.\n */\nexport const IGNORED_ENTRY_POINT = 'ignored-entry-point';\n\n/**\n * The path has a package.json, but it is not a valid entry-point for ngcc processing.\n */\nexport const INCOMPATIBLE_ENTRY_POINT = 'incompatible-entry-point';\n\n/**\n * The result of calling `getEntryPointInfo()`.\n *\n * This will be an `EntryPoint` object if an Angular entry-point was identified;\n * Otherwise it will be a flag indicating one of:\n * * NO_ENTRY_POINT - the path is not an entry-point or ngcc is configured to ignore it\n * * INCOMPATIBLE_ENTRY_POINT - the path was a non-processable entry-point that should be searched\n * for sub-entry-points\n */\nexport type GetEntryPointResult =\n    EntryPoint|typeof IGNORED_ENTRY_POINT|typeof INCOMPATIBLE_ENTRY_POINT|typeof NO_ENTRY_POINT;\n\n\n/**\n * Try to create an entry-point from the given paths and properties.\n *\n * @param packagePath the absolute path to the containing npm package\n * @param entryPointPath the absolute path to the potential entry-point.\n * @returns\n * - An entry-point if it is valid and not ignored.\n * - `NO_ENTRY_POINT` when there is no package.json at the path and there is no config to force an\n *   entry-point,\n * - `IGNORED_ENTRY_POINT` when the entry-point is ignored by an ngcc config.\n * - `INCOMPATIBLE_ENTRY_POINT` when there is a package.json but it is not a valid Angular compiled\n *   entry-point.\n */\nexport function getEntryPointInfo(\n    fs: ReadonlyFileSystem, config: NgccConfiguration, logger: Logger, packagePath: AbsoluteFsPath,\n    entryPointPath: AbsoluteFsPath): GetEntryPointResult {\n  const packagePackageJsonPath = fs.resolve(packagePath, 'package.json');\n  const entryPointPackageJsonPath = fs.resolve(entryPointPath, 'package.json');\n  const loadedPackagePackageJson = loadPackageJson(fs, packagePackageJsonPath);\n  const loadedEntryPointPackageJson = (packagePackageJsonPath === entryPointPackageJsonPath) ?\n      loadedPackagePackageJson :\n      loadPackageJson(fs, entryPointPackageJsonPath);\n  const {packageName, packageVersion} = getPackageNameAndVersion(\n      fs, packagePath, loadedPackagePackageJson, loadedEntryPointPackageJson);\n\n  const packageConfig = config.getPackageConfig(packageName, packagePath, packageVersion);\n  const entryPointConfig = packageConfig.entryPoints.get(entryPointPath);\n  let entryPointPackageJson: EntryPointPackageJson;\n\n  if (entryPointConfig === undefined) {\n    if (!fs.exists(entryPointPackageJsonPath)) {\n      // No `package.json` and no config.\n      return NO_ENTRY_POINT;\n    } else if (loadedEntryPointPackageJson === null) {\n      // `package.json` exists but could not be parsed and there is no redeeming config.\n      logger.warn(`Failed to read entry point info from invalid 'package.json' file: ${\n          entryPointPackageJsonPath}`);\n\n      return INCOMPATIBLE_ENTRY_POINT;\n    } else {\n      entryPointPackageJson = loadedEntryPointPackageJson;\n    }\n  } else if (entryPointConfig.ignore === true) {\n    // Explicitly ignored entry-point.\n    return IGNORED_ENTRY_POINT;\n  } else {\n    entryPointPackageJson = mergeConfigAndPackageJson(\n        fs, loadedEntryPointPackageJson, entryPointConfig, packagePath, entryPointPath);\n  }\n\n  const typings = entryPointPackageJson.typings || entryPointPackageJson.types ||\n      guessTypingsFromPackageJson(fs, entryPointPath, entryPointPackageJson);\n  if (typeof typings !== 'string') {\n    // Missing the required `typings` property\n    return INCOMPATIBLE_ENTRY_POINT;\n  }\n\n  // An entry-point is assumed to be compiled by Angular if there is either:\n  // * a `metadata.json` file next to the typings entry-point\n  // * a custom config for this entry-point\n  const metadataPath =\n      fs.resolve(entryPointPath, typings.replace(/\\.d\\.ts$/, '') + '.metadata.json');\n  const compiledByAngular = entryPointConfig !== undefined || fs.exists(metadataPath);\n\n  const entryPointInfo: EntryPoint = {\n    name: entryPointPackageJson.name,\n    path: entryPointPath,\n    packageName,\n    packagePath,\n    packageJson: entryPointPackageJson,\n    typings: fs.resolve(entryPointPath, typings),\n    compiledByAngular,\n    ignoreMissingDependencies:\n        entryPointConfig !== undefined ? !!entryPointConfig.ignoreMissingDependencies : false,\n    generateDeepReexports:\n        entryPointConfig !== undefined ? !!entryPointConfig.generateDeepReexports : false,\n  };\n\n  return entryPointInfo;\n}\n\nexport function isEntryPoint(result: GetEntryPointResult): result is EntryPoint {\n  return result !== NO_ENTRY_POINT && result !== INCOMPATIBLE_ENTRY_POINT &&\n      result !== IGNORED_ENTRY_POINT;\n}\n\n/**\n * Convert a package.json property into an entry-point format.\n *\n * @param property The property to convert to a format.\n * @returns An entry-point format or `undefined` if none match the given property.\n */\nexport function getEntryPointFormat(\n    fs: ReadonlyFileSystem, entryPoint: EntryPoint,\n    property: EntryPointJsonProperty): EntryPointFormat|undefined {\n  switch (property) {\n    case 'fesm2015':\n      return 'esm2015';\n    case 'fesm5':\n      return 'esm5';\n    case 'es2015':\n      return 'esm2015';\n    case 'esm2015':\n      return 'esm2015';\n    case 'esm5':\n      return 'esm5';\n    case 'browser':\n      const browserFile = entryPoint.packageJson['browser'];\n      if (typeof browserFile !== 'string') {\n        return undefined;\n      }\n      return sniffModuleFormat(fs, fs.join(entryPoint.path, browserFile));\n    case 'main':\n      const mainFile = entryPoint.packageJson['main'];\n      if (mainFile === undefined) {\n        return undefined;\n      }\n      return sniffModuleFormat(fs, fs.join(entryPoint.path, mainFile));\n    case 'module':\n      const moduleFilePath = entryPoint.packageJson['module'];\n      // As of version 10, the `module` property in `package.json` should point to\n      // the ESM2015 format output as per Angular Package format specification. This\n      // means that the `module` property captures multiple formats, as old libraries\n      // built with the old APF can still be processed. We detect the format by checking\n      // the paths that should be used as per APF specification.\n      if (typeof moduleFilePath === 'string' && moduleFilePath.includes('esm2015')) {\n        return `esm2015`;\n      }\n      return 'esm5';\n    default:\n      return undefined;\n  }\n}\n\n/**\n * Parse the JSON from a `package.json` file.\n * @param packageJsonPath the absolute path to the `package.json` file.\n * @returns JSON from the `package.json` file if it is valid, `null` otherwise.\n */\nfunction loadPackageJson(\n    fs: ReadonlyFileSystem, packageJsonPath: AbsoluteFsPath): EntryPointPackageJson|null {\n  try {\n    return JSON.parse(fs.readFile(packageJsonPath)) as EntryPointPackageJson;\n  } catch {\n    return null;\n  }\n}\n\nfunction sniffModuleFormat(\n    fs: ReadonlyFileSystem, sourceFilePath: AbsoluteFsPath): EntryPointFormat|undefined {\n  const resolvedPath = resolveFileWithPostfixes(fs, sourceFilePath, ['', '.js', '/index.js']);\n  if (resolvedPath === null) {\n    return undefined;\n  }\n\n  const sourceFile =\n      ts.createSourceFile(sourceFilePath, fs.readFile(resolvedPath), ts.ScriptTarget.ES5);\n  if (sourceFile.statements.length === 0) {\n    return undefined;\n  }\n  if (ts.isExternalModule(sourceFile)) {\n    return 'esm5';\n  } else if (parseStatementForUmdModule(sourceFile.statements[0]) !== null) {\n    return 'umd';\n  } else {\n    return 'commonjs';\n  }\n}\n\nfunction mergeConfigAndPackageJson(\n    fs: PathManipulation, entryPointPackageJson: EntryPointPackageJson|null,\n    entryPointConfig: NgccEntryPointConfig, packagePath: AbsoluteFsPath,\n    entryPointPath: AbsoluteFsPath): EntryPointPackageJson {\n  if (entryPointPackageJson !== null) {\n    return {...entryPointPackageJson, ...entryPointConfig.override};\n  } else {\n    const name = `${fs.basename(packagePath)}/${fs.relative(packagePath, entryPointPath)}`;\n    return {name, ...entryPointConfig.override};\n  }\n}\n\nfunction guessTypingsFromPackageJson(\n    fs: ReadonlyFileSystem, entryPointPath: AbsoluteFsPath,\n    entryPointPackageJson: EntryPointPackageJson): AbsoluteFsPath|null {\n  for (const prop of SUPPORTED_FORMAT_PROPERTIES) {\n    const field = entryPointPackageJson[prop];\n    if (typeof field !== 'string') {\n      // Some crazy packages have things like arrays in these fields!\n      continue;\n    }\n    const relativeTypingsPath = field.replace(/\\.js$/, '.d.ts');\n    const typingsPath = fs.resolve(entryPointPath, relativeTypingsPath);\n    if (fs.exists(typingsPath)) {\n      return typingsPath;\n    }\n  }\n  return null;\n}\n\n/**\n * Find or infer the name and version of a package.\n *\n * - The name is computed based on the `name` property of the package's or the entry-point's\n *   `package.json` file (if available) or inferred from the package's path.\n * - The version is read off of the `version` property of the package's `package.json` file (if\n *   available).\n *\n * @param fs The file-system to use for processing `packagePath`.\n * @param packagePath the absolute path to the package.\n * @param packagePackageJson the parsed `package.json` of the package (if available).\n * @param entryPointPackageJson the parsed `package.json` of an entry-point (if available).\n * @returns the computed name and version of the package.\n */\nfunction getPackageNameAndVersion(\n    fs: PathManipulation, packagePath: AbsoluteFsPath,\n    packagePackageJson: EntryPointPackageJson|null,\n    entryPointPackageJson: EntryPointPackageJson|\n    null): {packageName: string, packageVersion: string|null} {\n  let packageName: string;\n\n  if (packagePackageJson !== null) {\n    // We have a valid `package.json` for the package: Get the package name from that.\n    packageName = packagePackageJson.name;\n  } else if (entryPointPackageJson !== null) {\n    // We have a valid `package.json` for the entry-point: Get the package name from that.\n    // This might be a secondary entry-point, so make sure we only keep the main package's name\n    // (e.g. only keep `@angular/common` from `@angular/common/http`).\n    packageName = /^(?:@[^/]+\\/)?[^/]*/.exec(entryPointPackageJson.name)![0];\n  } else {\n    // We don't have a valid `package.json`: Infer the package name from the package's path.\n    const lastSegment = fs.basename(packagePath);\n    const secondLastSegment = fs.basename(fs.dirname(packagePath));\n\n    packageName =\n        secondLastSegment.startsWith('@') ? `${secondLastSegment}/${lastSegment}` : lastSegment;\n  }\n\n  return {\n    packageName,\n    packageVersion: packagePackageJson?.version ?? null,\n  };\n}\n"]} |
---|