source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/packages/entry_point.js@ e29cc2e

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

initial commit

  • Property mode set to 100644
File size: 39.9 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/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"]}
Note: See TracBrowser for help on using the repository browser.