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/packages/bazel/src/api-extractor/index", ["require", "exports", "tslib", "@bazel/typescript", "@microsoft/api-extractor", "fs", "path"], factory);
|
15 | }
|
16 | })(function (require, exports) {
|
17 | ;
|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
19 | exports.runMain = void 0;
|
20 | var tslib_1 = require("tslib");
|
21 | /// <reference types="node"/>
|
22 | /// <reference lib="es2017"/>
|
23 | var typescript_1 = require("@bazel/typescript");
|
24 | var api_extractor_1 = require("@microsoft/api-extractor");
|
25 | var fs = require("fs");
|
26 | var path = require("path");
|
27 | var DEBUG = false;
|
28 | function runMain(tsConfig, entryPoint, dtsBundleOut, apiReviewFolder, acceptApiUpdates) {
|
29 | var e_1, _a;
|
30 | if (acceptApiUpdates === void 0) { acceptApiUpdates = false; }
|
31 | var _b = tslib_1.__read(typescript_1.parseTsconfig(tsConfig), 2), parsedConfig = _b[0], errors = _b[1];
|
32 | if (errors && errors.length) {
|
33 | console.error(typescript_1.format('', errors));
|
34 | return 1;
|
35 | }
|
36 | var pkgJson = path.resolve(path.dirname(entryPoint), 'package.json');
|
37 | if (!fs.existsSync(pkgJson)) {
|
38 | fs.writeFileSync(pkgJson, JSON.stringify({
|
39 | 'name': 'GENERATED-BY-BAZEL',
|
40 | 'version': '0.0.0',
|
41 | 'description': 'This is a dummy package.json as API Extractor always requires one.',
|
42 | }));
|
43 | }
|
44 | // API extractor doesn't always support the version of TypeScript used in the repo
|
45 | // example: at the moment it is not compatable with 3.2
|
46 | // to use the internal TypeScript we shall not create a program but rather pass a parsed tsConfig.
|
47 | var parsedTsConfig = parsedConfig.config;
|
48 | var compilerOptions = parsedTsConfig.compilerOptions;
|
49 | try {
|
50 | for (var _c = tslib_1.__values(Object.entries(compilerOptions.paths)), _d = _c.next(); !_d.done; _d = _c.next()) {
|
51 | var _e = tslib_1.__read(_d.value, 2), key = _e[0], values = _e[1];
|
52 | if (key === '*') {
|
53 | continue;
|
54 | }
|
55 | // we shall not pass ts files as this will need to be parsed, and for example rxjs,
|
56 | // cannot be compiled with our tsconfig, as ours is more strict
|
57 | // hence amend the paths to point always to the '.d.ts' files.
|
58 | compilerOptions.paths[key] = values.map(function (path) {
|
59 | var pathSuffix = /(\*|index)$/.test(path) ? '.d.ts' : '/index.d.ts';
|
60 | return path + pathSuffix;
|
61 | });
|
62 | }
|
63 | }
|
64 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
65 | finally {
|
66 | try {
|
67 | if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
|
68 | }
|
69 | finally { if (e_1) throw e_1.error; }
|
70 | }
|
71 | var extractorOptions = {
|
72 | localBuild: acceptApiUpdates,
|
73 | };
|
74 | var configObject = {
|
75 | compiler: {
|
76 | overrideTsconfig: parsedTsConfig,
|
77 | },
|
78 | projectFolder: path.resolve(path.dirname(tsConfig)),
|
79 | mainEntryPointFilePath: path.resolve(entryPoint),
|
80 | apiReport: {
|
81 | enabled: !!apiReviewFolder,
|
82 | // TODO(alan-agius4): remove this folder name when the below issue is solved upstream
|
83 | // See: https://github.com/microsoft/web-build-tools/issues/1470
|
84 | reportFileName: apiReviewFolder && path.resolve(apiReviewFolder) || 'invalid',
|
85 | },
|
86 | docModel: {
|
87 | enabled: false,
|
88 | },
|
89 | dtsRollup: {
|
90 | enabled: !!dtsBundleOut,
|
91 | untrimmedFilePath: dtsBundleOut && path.resolve(dtsBundleOut),
|
92 | },
|
93 | tsdocMetadata: {
|
94 | enabled: false,
|
95 | }
|
96 | };
|
97 | var options = {
|
98 | configObject: configObject,
|
99 | packageJson: undefined,
|
100 | packageJsonFullPath: pkgJson,
|
101 | configObjectFullPath: undefined,
|
102 | };
|
103 | var extractorConfig = api_extractor_1.ExtractorConfig.prepare(options);
|
104 | var succeeded = api_extractor_1.Extractor.invoke(extractorConfig, extractorOptions).succeeded;
|
105 | // API extractor errors are emitted by it's logger.
|
106 | return succeeded ? 0 : 1;
|
107 | }
|
108 | exports.runMain = runMain;
|
109 | // Entry point
|
110 | if (require.main === module) {
|
111 | if (DEBUG) {
|
112 | console.error("\napi-extractor: running with\n cwd: " + process.cwd() + "\n argv:\n " + process.argv.join('\n ') + "\n ");
|
113 | }
|
114 | var _a = tslib_1.__read(process.argv.slice(2), 3), tsConfig = _a[0], entryPoint = _a[1], dtsBundleOut = _a[2];
|
115 | var entryPoints = entryPoint.split(',');
|
116 | var dtsBundleOuts = dtsBundleOut.split(',');
|
117 | if (entryPoints.length !== entryPoints.length) {
|
118 | throw new Error("Entry points count (" + entryPoints.length + ") does not match Bundle out count (" + dtsBundleOuts.length + ")");
|
119 | }
|
120 | for (var i = 0; i < entryPoints.length; i++) {
|
121 | process.exitCode = runMain(tsConfig, entryPoints[i], dtsBundleOuts[i]);
|
122 | if (process.exitCode !== 0) {
|
123 | break;
|
124 | }
|
125 | }
|
126 | }
|
127 | });
|
128 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/bazel/src/api-extractor/index.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\n/// <reference types=\"node\"/>\n/// <reference lib=\"es2017\"/>\n\nimport {format, parseTsconfig} from '@bazel/typescript';\nimport {Extractor, ExtractorConfig, IConfigFile, IExtractorConfigPrepareOptions, IExtractorInvokeOptions} from '@microsoft/api-extractor';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nconst DEBUG = false;\n\nexport function runMain(\n    tsConfig: string, entryPoint: string, dtsBundleOut?: string, apiReviewFolder?: string,\n    acceptApiUpdates = false): 1|0 {\n  const [parsedConfig, errors] = parseTsconfig(tsConfig);\n  if (errors && errors.length) {\n    console.error(format('', errors));\n\n    return 1;\n  }\n\n  const pkgJson = path.resolve(path.dirname(entryPoint), 'package.json');\n  if (!fs.existsSync(pkgJson)) {\n    fs.writeFileSync(pkgJson, JSON.stringify({\n      'name': 'GENERATED-BY-BAZEL',\n      'version': '0.0.0',\n      'description': 'This is a dummy package.json as API Extractor always requires one.',\n    }));\n  }\n\n  // API extractor doesn't always support the version of TypeScript used in the repo\n  // example: at the moment it is not compatable with 3.2\n  // to use the internal TypeScript we shall not create a program but rather pass a parsed tsConfig.\n  const parsedTsConfig = parsedConfig!.config as any;\n  const compilerOptions = parsedTsConfig.compilerOptions;\n  for (const [key, values] of Object.entries<string[]>(compilerOptions.paths)) {\n    if (key === '*') {\n      continue;\n    }\n\n    // we shall not pass ts files as this will need to be parsed, and for example rxjs,\n    // cannot be compiled with our tsconfig, as ours is more strict\n    // hence amend the paths to point always to the '.d.ts' files.\n    compilerOptions.paths[key] = values.map(path => {\n      const pathSuffix = /(\\*|index)$/.test(path) ? '.d.ts' : '/index.d.ts';\n\n      return path + pathSuffix;\n    });\n  }\n\n  const extractorOptions: IExtractorInvokeOptions = {\n    localBuild: acceptApiUpdates,\n  };\n\n  const configObject: IConfigFile = {\n    compiler: {\n      overrideTsconfig: parsedTsConfig,\n    },\n    projectFolder: path.resolve(path.dirname(tsConfig)),\n    mainEntryPointFilePath: path.resolve(entryPoint),\n    apiReport: {\n      enabled: !!apiReviewFolder,\n      // TODO(alan-agius4): remove this folder name when the below issue is solved upstream\n      // See: https://github.com/microsoft/web-build-tools/issues/1470\n      reportFileName: apiReviewFolder && path.resolve(apiReviewFolder) || 'invalid',\n    },\n    docModel: {\n      enabled: false,\n    },\n    dtsRollup: {\n      enabled: !!dtsBundleOut,\n      untrimmedFilePath: dtsBundleOut && path.resolve(dtsBundleOut),\n    },\n    tsdocMetadata: {\n      enabled: false,\n    }\n  };\n\n  const options: IExtractorConfigPrepareOptions = {\n    configObject,\n    packageJson: undefined,\n    packageJsonFullPath: pkgJson,\n    configObjectFullPath: undefined,\n  };\n\n  const extractorConfig = ExtractorConfig.prepare(options);\n  const {succeeded} = Extractor.invoke(extractorConfig, extractorOptions);\n\n  // API extractor errors are emitted by it's logger.\n  return succeeded ? 0 : 1;\n}\n\n// Entry point\nif (require.main === module) {\n  if (DEBUG) {\n    console.error(`\napi-extractor: running with\n  cwd: ${process.cwd()}\n  argv:\n    ${process.argv.join('\\n    ')}\n  `);\n  }\n\n  const [tsConfig, entryPoint, dtsBundleOut] = process.argv.slice(2);\n  const entryPoints = entryPoint.split(',');\n  const dtsBundleOuts = dtsBundleOut.split(',');\n\n  if (entryPoints.length !== entryPoints.length) {\n    throw new Error(`Entry points count (${entryPoints.length}) does not match Bundle out count (${\n        dtsBundleOuts.length})`);\n  }\n\n  for (let i = 0; i < entryPoints.length; i++) {\n    process.exitCode = runMain(tsConfig, entryPoints[i], dtsBundleOuts[i]);\n\n    if (process.exitCode !== 0) {\n      break;\n    }\n  }\n}\n"]} |
\ | No newline at end of file |