(function (factory) { if (typeof module === "object" && typeof module.exports === "object") { var v = factory(require, exports); if (v !== undefined) module.exports = v; } else if (typeof define === "function" && define.amd) { define("@angular/compiler-cli/ngcc/src/packages/build_marker", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.markAsProcessed = exports.hasBeenProcessed = exports.cleanPackageJson = exports.needsCleaning = exports.NGCC_VERSION = void 0; var tslib_1 = require("tslib"); var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer"); exports.NGCC_VERSION = '12.2.9'; /** * Returns true if there is a format in this entry-point that was compiled with an outdated version * of ngcc. * * @param packageJson The parsed contents of the package.json for the entry-point */ function needsCleaning(packageJson) { return Object.values(packageJson.__processed_by_ivy_ngcc__ || {}) .some(function (value) { return value !== exports.NGCC_VERSION; }); } exports.needsCleaning = needsCleaning; /** * Clean any build marker artifacts from the given `packageJson` object. * @param packageJson The parsed contents of the package.json to modify * @returns true if the package was modified during cleaning */ function cleanPackageJson(packageJson) { var e_1, _a; if (packageJson.__processed_by_ivy_ngcc__ !== undefined) { // Remove the actual marker delete packageJson.__processed_by_ivy_ngcc__; try { // Remove new format properties that have been added by ngcc for (var _b = tslib_1.__values(Object.keys(packageJson)), _c = _b.next(); !_c.done; _c = _b.next()) { var prop = _c.value; if (prop.endsWith(new_entry_point_file_writer_1.NGCC_PROPERTY_EXTENSION)) { delete packageJson[prop]; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } // Also remove the prebulish script if we modified it var scripts = packageJson.scripts; if (scripts !== undefined && scripts.prepublishOnly) { delete scripts.prepublishOnly; if (scripts.prepublishOnly__ivy_ngcc_bak !== undefined) { scripts.prepublishOnly = scripts.prepublishOnly__ivy_ngcc_bak; delete scripts.prepublishOnly__ivy_ngcc_bak; } } return true; } return false; } exports.cleanPackageJson = cleanPackageJson; /** * Check whether ngcc has already processed a given entry-point format. * * @param packageJson The parsed contents of the package.json file for the entry-point. * @param format The entry-point format property in the package.json to check. * @returns true if the `format` in the entry-point has already been processed by this ngcc version, * false otherwise. */ function hasBeenProcessed(packageJson, format) { return packageJson.__processed_by_ivy_ngcc__ !== undefined && packageJson.__processed_by_ivy_ngcc__[format] === exports.NGCC_VERSION; } exports.hasBeenProcessed = hasBeenProcessed; /** * Write a build marker for the given entry-point and format properties, to indicate that they have * been compiled by this version of ngcc. * * @param pkgJsonUpdater The writer to use for updating `package.json`. * @param packageJson The parsed contents of the `package.json` file for the entry-point. * @param packageJsonPath The absolute path to the `package.json` file. * @param properties The properties in the `package.json` of the formats for which we are writing * the marker. */ function markAsProcessed(pkgJsonUpdater, packageJson, packageJsonPath, formatProperties) { var e_2, _a; var update = pkgJsonUpdater.createUpdate(); try { // Update the format properties to mark them as processed. for (var formatProperties_1 = tslib_1.__values(formatProperties), formatProperties_1_1 = formatProperties_1.next(); !formatProperties_1_1.done; formatProperties_1_1 = formatProperties_1.next()) { var prop = formatProperties_1_1.value; update.addChange(['__processed_by_ivy_ngcc__', prop], exports.NGCC_VERSION, 'alphabetic'); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (formatProperties_1_1 && !formatProperties_1_1.done && (_a = formatProperties_1.return)) _a.call(formatProperties_1); } finally { if (e_2) throw e_2.error; } } // Update the `prepublishOnly` script (keeping a backup, if necessary) to prevent `ngcc`'d // packages from getting accidentally published. var oldPrepublishOnly = packageJson.scripts && packageJson.scripts.prepublishOnly; var newPrepublishOnly = 'node --eval \"console.error(\'' + 'ERROR: Trying to publish a package that has been compiled by NGCC. This is not allowed.\\n' + 'Please delete and rebuild the package, without compiling with NGCC, before attempting to publish.\\n' + 'Note that NGCC may have been run by importing this package into another project that is being built with Ivy enabled.\\n' + '\')\" ' + '&& exit 1'; if (oldPrepublishOnly && (oldPrepublishOnly !== newPrepublishOnly)) { update.addChange(['scripts', 'prepublishOnly__ivy_ngcc_bak'], oldPrepublishOnly); } update.addChange(['scripts', 'prepublishOnly'], newPrepublishOnly); update.writeChanges(packageJsonPath, packageJson); } exports.markAsProcessed = markAsProcessed; }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build_marker.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/build_marker.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAQA,kHAA+E;IAIlE,QAAA,YAAY,GAAG,mBAAmB,CAAC;IAEhD;;;;;OAKG;IACH,SAAgB,aAAa,CAAC,WAAkC;QAC9D,OAAO,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,yBAAyB,IAAI,EAAE,CAAC;aAC5D,IAAI,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,KAAK,oBAAY,EAAtB,CAAsB,CAAC,CAAC;IAC7C,CAAC;IAHD,sCAGC;IAED;;;;OAIG;IACH,SAAgB,gBAAgB,CAAC,WAAkC;;QACjE,IAAI,WAAW,CAAC,yBAAyB,KAAK,SAAS,EAAE;YACvD,2BAA2B;YAC3B,OAAO,WAAW,CAAC,yBAAyB,CAAC;;gBAC7C,4DAA4D;gBAC5D,KAAmB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA,gBAAA,4BAAE;oBAAxC,IAAM,IAAI,WAAA;oBACb,IAAI,IAAI,CAAC,QAAQ,CAAC,qDAAuB,CAAC,EAAE;wBAC1C,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC;qBAC1B;iBACF;;;;;;;;;YAED,qDAAqD;YACrD,IAAM,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC;YACpC,IAAI,OAAO,KAAK,SAAS,IAAI,OAAO,CAAC,cAAc,EAAE;gBACnD,OAAO,OAAO,CAAC,cAAc,CAAC;gBAC9B,IAAI,OAAO,CAAC,4BAA4B,KAAK,SAAS,EAAE;oBACtD,OAAO,CAAC,cAAc,GAAG,OAAO,CAAC,4BAA4B,CAAC;oBAC9D,OAAO,OAAO,CAAC,4BAA4B,CAAC;iBAC7C;aACF;YACD,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAvBD,4CAuBC;IAED;;;;;;;OAOG;IACH,SAAgB,gBAAgB,CAC5B,WAAkC,EAAE,MAAmC;QACzE,OAAO,WAAW,CAAC,yBAAyB,KAAK,SAAS;YACtD,WAAW,CAAC,yBAAyB,CAAC,MAAM,CAAC,KAAK,oBAAY,CAAC;IACrE,CAAC;IAJD,4CAIC;IAED;;;;;;;;;OASG;IACH,SAAgB,eAAe,CAC3B,cAAkC,EAAE,WAAkC,EACtE,eAA+B,EAAE,gBAA+C;;QAClF,IAAM,MAAM,GAAG,cAAc,CAAC,YAAY,EAAE,CAAC;;YAE7C,0DAA0D;YAC1D,KAAmB,IAAA,qBAAA,iBAAA,gBAAgB,CAAA,kDAAA,gFAAE;gBAAhC,IAAM,IAAI,6BAAA;gBACb,MAAM,CAAC,SAAS,CAAC,CAAC,2BAA2B,EAAE,IAAI,CAAC,EAAE,oBAAY,EAAE,YAAY,CAAC,CAAC;aACnF;;;;;;;;;QAED,0FAA0F;QAC1F,gDAAgD;QAChD,IAAM,iBAAiB,GAAG,WAAW,CAAC,OAAO,IAAI,WAAW,CAAC,OAAO,CAAC,cAAc,CAAC;QACpF,IAAM,iBAAiB,GAAG,gCAAgC;YACtD,4FAA4F;YAC5F,sGAAsG;YACtG,0HAA0H;YAC1H,QAAQ;YACR,WAAW,CAAC;QAEhB,IAAI,iBAAiB,IAAI,CAAC,iBAAiB,KAAK,iBAAiB,CAAC,EAAE;YAClE,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,8BAA8B,CAAC,EAAE,iBAAiB,CAAC,CAAC;SAClF;QAED,MAAM,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,gBAAgB,CAAC,EAAE,iBAAiB,CAAC,CAAC;QAEnE,MAAM,CAAC,YAAY,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;IACpD,CAAC;IA3BD,0CA2BC","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 {AbsoluteFsPath} from '../../../src/ngtsc/file_system';\nimport {NGCC_PROPERTY_EXTENSION} from '../writing/new_entry_point_file_writer';\nimport {PackageJsonUpdater} from '../writing/package_json_updater';\nimport {EntryPointPackageJson, PackageJsonFormatProperties} from './entry_point';\n\nexport const NGCC_VERSION = '0.0.0-PLACEHOLDER';\n\n/**\n * Returns true if there is a format in this entry-point that was compiled with an outdated version\n * of ngcc.\n *\n * @param packageJson The parsed contents of the package.json for the entry-point\n */\nexport function needsCleaning(packageJson: EntryPointPackageJson): boolean {\n  return Object.values(packageJson.__processed_by_ivy_ngcc__ || {})\n      .some(value => value !== NGCC_VERSION);\n}\n\n/**\n * Clean any build marker artifacts from the given `packageJson` object.\n * @param packageJson The parsed contents of the package.json to modify\n * @returns true if the package was modified during cleaning\n */\nexport function cleanPackageJson(packageJson: EntryPointPackageJson): boolean {\n  if (packageJson.__processed_by_ivy_ngcc__ !== undefined) {\n    // Remove the actual marker\n    delete packageJson.__processed_by_ivy_ngcc__;\n    // Remove new format properties that have been added by ngcc\n    for (const prop of Object.keys(packageJson)) {\n      if (prop.endsWith(NGCC_PROPERTY_EXTENSION)) {\n        delete packageJson[prop];\n      }\n    }\n\n    // Also remove the prebulish script if we modified it\n    const scripts = packageJson.scripts;\n    if (scripts !== undefined && scripts.prepublishOnly) {\n      delete scripts.prepublishOnly;\n      if (scripts.prepublishOnly__ivy_ngcc_bak !== undefined) {\n        scripts.prepublishOnly = scripts.prepublishOnly__ivy_ngcc_bak;\n        delete scripts.prepublishOnly__ivy_ngcc_bak;\n      }\n    }\n    return true;\n  }\n  return false;\n}\n\n/**\n * Check whether ngcc has already processed a given entry-point format.\n *\n * @param packageJson The parsed contents of the package.json file for the entry-point.\n * @param format The entry-point format property in the package.json to check.\n * @returns true if the `format` in the entry-point has already been processed by this ngcc version,\n * false otherwise.\n */\nexport function hasBeenProcessed(\n    packageJson: EntryPointPackageJson, format: PackageJsonFormatProperties): boolean {\n  return packageJson.__processed_by_ivy_ngcc__ !== undefined &&\n      packageJson.__processed_by_ivy_ngcc__[format] === NGCC_VERSION;\n}\n\n/**\n * Write a build marker for the given entry-point and format properties, to indicate that they have\n * been compiled by this version of ngcc.\n *\n * @param pkgJsonUpdater The writer to use for updating `package.json`.\n * @param packageJson The parsed contents of the `package.json` file for the entry-point.\n * @param packageJsonPath The absolute path to the `package.json` file.\n * @param properties The properties in the `package.json` of the formats for which we are writing\n *                   the marker.\n */\nexport function markAsProcessed(\n    pkgJsonUpdater: PackageJsonUpdater, packageJson: EntryPointPackageJson,\n    packageJsonPath: AbsoluteFsPath, formatProperties: PackageJsonFormatProperties[]): void {\n  const update = pkgJsonUpdater.createUpdate();\n\n  // Update the format properties to mark them as processed.\n  for (const prop of formatProperties) {\n    update.addChange(['__processed_by_ivy_ngcc__', prop], NGCC_VERSION, 'alphabetic');\n  }\n\n  // Update the `prepublishOnly` script (keeping a backup, if necessary) to prevent `ngcc`'d\n  // packages from getting accidentally published.\n  const oldPrepublishOnly = packageJson.scripts && packageJson.scripts.prepublishOnly;\n  const newPrepublishOnly = 'node --eval \\\"console.error(\\'' +\n      'ERROR: Trying to publish a package that has been compiled by NGCC. This is not allowed.\\\\n' +\n      'Please delete and rebuild the package, without compiling with NGCC, before attempting to publish.\\\\n' +\n      'Note that NGCC may have been run by importing this package into another project that is being built with Ivy enabled.\\\\n' +\n      '\\')\\\" ' +\n      '&& exit 1';\n\n  if (oldPrepublishOnly && (oldPrepublishOnly !== newPrepublishOnly)) {\n    update.addChange(['scripts', 'prepublishOnly__ivy_ngcc_bak'], oldPrepublishOnly);\n  }\n\n  update.addChange(['scripts', 'prepublishOnly'], newPrepublishOnly);\n\n  update.writeChanges(packageJsonPath, packageJson);\n}\n"]}