146 lines
18 KiB
JavaScript
146 lines
18 KiB
JavaScript
"use strict";
|
|
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
}
|
|
Object.defineProperty(o, k2, desc);
|
|
}) : (function(o, m, k, k2) {
|
|
if (k2 === undefined) k2 = k;
|
|
o[k2] = m[k];
|
|
}));
|
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
}) : function(o, v) {
|
|
o["default"] = v;
|
|
});
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
if (mod && mod.__esModule) return mod;
|
|
var result = {};
|
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
__setModuleDefault(result, mod);
|
|
return result;
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.addDependency = exports.ExistingBehavior = exports.InstallBehavior = exports.DependencyType = void 0;
|
|
const tasks_1 = require("@angular-devkit/schematics/tasks");
|
|
const path = __importStar(require("path"));
|
|
const installTasks = new WeakMap();
|
|
/**
|
|
* An enum used to specify the type of a dependency found within a package manifest
|
|
* file (`package.json`).
|
|
*/
|
|
var DependencyType;
|
|
(function (DependencyType) {
|
|
DependencyType["Default"] = "dependencies";
|
|
DependencyType["Dev"] = "devDependencies";
|
|
DependencyType["Peer"] = "peerDependencies";
|
|
})(DependencyType || (exports.DependencyType = DependencyType = {}));
|
|
/**
|
|
* An enum used to specify the dependency installation behavior for the {@link addDependency}
|
|
* schematics rule. The installation behavior affects if and when {@link NodePackageInstallTask}
|
|
* will be scheduled when using the rule.
|
|
*/
|
|
var InstallBehavior;
|
|
(function (InstallBehavior) {
|
|
/**
|
|
* No installation will occur as a result of the rule when specified.
|
|
*
|
|
* NOTE: This does not prevent other rules from scheduling a {@link NodePackageInstallTask}
|
|
* which may install the dependency.
|
|
*/
|
|
InstallBehavior[InstallBehavior["None"] = 0] = "None";
|
|
/**
|
|
* Automatically determine the need to schedule a {@link NodePackageInstallTask} based on
|
|
* previous usage of the {@link addDependency} within the schematic.
|
|
*/
|
|
InstallBehavior[InstallBehavior["Auto"] = 1] = "Auto";
|
|
/**
|
|
* Always schedule a {@link NodePackageInstallTask} when the rule is executed.
|
|
*/
|
|
InstallBehavior[InstallBehavior["Always"] = 2] = "Always";
|
|
})(InstallBehavior || (exports.InstallBehavior = InstallBehavior = {}));
|
|
/**
|
|
* An enum used to specify the existing dependency behavior for the {@link addDependency}
|
|
* schematics rule. The existing behavior affects whether the named dependency will be added
|
|
* to the `package.json` when the dependency is already present with a differing specifier.
|
|
*/
|
|
var ExistingBehavior;
|
|
(function (ExistingBehavior) {
|
|
/**
|
|
* The dependency will not be added or otherwise changed if it already exists.
|
|
*/
|
|
ExistingBehavior[ExistingBehavior["Skip"] = 0] = "Skip";
|
|
/**
|
|
* The dependency's existing specifier will be replaced with the specifier provided in the
|
|
* {@link addDependency} call. A warning will also be shown during schematic execution to
|
|
* notify the user of the replacement.
|
|
*/
|
|
ExistingBehavior[ExistingBehavior["Replace"] = 1] = "Replace";
|
|
})(ExistingBehavior || (exports.ExistingBehavior = ExistingBehavior = {}));
|
|
/**
|
|
* Adds a package as a dependency to a `package.json`. By default the `package.json` located
|
|
* at the schematic's root will be used. The `manifestPath` option can be used to explicitly specify
|
|
* a `package.json` in different location. The type of the dependency can also be specified instead
|
|
* of the default of the `dependencies` section by using the `type` option for either `devDependencies`
|
|
* or `peerDependencies`.
|
|
*
|
|
* When using this rule, {@link NodePackageInstallTask} does not need to be included directly by
|
|
* a schematic. A package manager install task will be automatically scheduled as needed.
|
|
*
|
|
* @param name The name of the package to add.
|
|
* @param specifier The package specifier for the package to add. Typically a SemVer range.
|
|
* @param options An optional object that can contain the `type` of the dependency
|
|
* and/or a path (`packageJsonPath`) of a manifest file (`package.json`) to modify.
|
|
* @returns A Schematics {@link Rule}
|
|
*/
|
|
function addDependency(name, specifier, options = {}) {
|
|
const { type = DependencyType.Default, packageJsonPath = '/package.json', install = InstallBehavior.Auto, existing = ExistingBehavior.Replace, } = options;
|
|
return (tree, context) => {
|
|
const manifest = tree.readJson(packageJsonPath);
|
|
const dependencySection = manifest[type];
|
|
if (!dependencySection) {
|
|
// Section is not present. The dependency can be added to a new object literal for the section.
|
|
manifest[type] = { [name]: specifier };
|
|
}
|
|
else {
|
|
const existingSpecifier = dependencySection[name];
|
|
if (existingSpecifier === specifier) {
|
|
// Already present with same specifier
|
|
return;
|
|
}
|
|
if (existingSpecifier) {
|
|
// Already present but different specifier
|
|
if (existing === ExistingBehavior.Skip) {
|
|
return;
|
|
}
|
|
// ExistingBehavior.Replace is the only other behavior currently
|
|
context.logger.warn(`Package dependency "${name}" already exists with a different specifier. ` +
|
|
`"${existingSpecifier}" will be replaced with "${specifier}".`);
|
|
}
|
|
// Add new dependency in alphabetical order
|
|
const entries = Object.entries(dependencySection);
|
|
entries.push([name, specifier]);
|
|
entries.sort((a, b) => a[0].localeCompare(b[0]));
|
|
manifest[type] = Object.fromEntries(entries);
|
|
}
|
|
tree.overwrite(packageJsonPath, JSON.stringify(manifest, null, 2));
|
|
const installPaths = installTasks.get(context) ?? new Set();
|
|
if (install === InstallBehavior.Always ||
|
|
(install === InstallBehavior.Auto && !installPaths.has(packageJsonPath))) {
|
|
context.addTask(new tasks_1.NodePackageInstallTask({ workingDirectory: path.dirname(packageJsonPath) }));
|
|
installPaths.add(packageJsonPath);
|
|
installTasks.set(context, installPaths);
|
|
}
|
|
};
|
|
}
|
|
exports.addDependency = addDependency;
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency.js","sourceRoot":"","sources":["../../../../../../../packages/schematics/angular/utility/dependency.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\nimport { Rule, SchematicContext } from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport * as path from 'path';\n\nconst installTasks = new WeakMap<SchematicContext, Set<string>>();\n\ninterface MinimalPackageManifest {\n  dependencies?: Record<string, string>;\n  devDependencies?: Record<string, string>;\n  peerDependencies?: Record<string, string>;\n}\n\n/**\n * An enum used to specify the type of a dependency found within a package manifest\n * file (`package.json`).\n */\nexport enum DependencyType {\n  Default = 'dependencies',\n  Dev = 'devDependencies',\n  Peer = 'peerDependencies',\n}\n\n/**\n * An enum used to specify the dependency installation behavior for the {@link addDependency}\n * schematics rule. The installation behavior affects if and when {@link NodePackageInstallTask}\n * will be scheduled when using the rule.\n */\nexport enum InstallBehavior {\n  /**\n   * No installation will occur as a result of the rule when specified.\n   *\n   * NOTE: This does not prevent other rules from scheduling a {@link NodePackageInstallTask}\n   * which may install the dependency.\n   */\n  None,\n  /**\n   * Automatically determine the need to schedule a {@link NodePackageInstallTask} based on\n   * previous usage of the {@link addDependency} within the schematic.\n   */\n  Auto,\n  /**\n   * Always schedule a {@link NodePackageInstallTask} when the rule is executed.\n   */\n  Always,\n}\n\n/**\n * An enum used to specify the existing dependency behavior for the {@link addDependency}\n * schematics rule. The existing behavior affects whether the named dependency will be added\n * to the `package.json` when the dependency is already present with a differing specifier.\n */\nexport enum ExistingBehavior {\n  /**\n   * The dependency will not be added or otherwise changed if it already exists.\n   */\n  Skip,\n  /**\n   * The dependency's existing specifier will be replaced with the specifier provided in the\n   * {@link addDependency} call. A warning will also be shown during schematic execution to\n   * notify the user of the replacement.\n   */\n  Replace,\n}\n\n/**\n * Adds a package as a dependency to a `package.json`. By default the `package.json` located\n * at the schematic's root will be used. The `manifestPath` option can be used to explicitly specify\n * a `package.json` in different location. The type of the dependency can also be specified instead\n * of the default of the `dependencies` section by using the `type` option for either `devDependencies`\n * or `peerDependencies`.\n *\n * When using this rule, {@link NodePackageInstallTask} does not need to be included directly by\n * a schematic. A package manager install task will be automatically scheduled as needed.\n *\n * @param name The name of the package to add.\n * @param specifier The package specifier for the package to add. Typically a SemVer range.\n * @param options An optional object that can contain the `type` of the dependency\n * and/or a path (`packageJsonPath`) of a manifest file (`package.json`) to modify.\n * @returns A Schematics {@link Rule}\n */\nexport function addDependency(\n  name: string,\n  specifier: string,\n  options: {\n    /**\n     * The type of the dependency determines the section of the `package.json` to which the\n     * dependency will be added. Defaults to {@link DependencyType.Default} (`dependencies`).\n     */\n    type?: DependencyType;\n    /**\n     * The path of the package manifest file (`package.json`) that will be modified.\n     * Defaults to `/package.json`.\n     */\n    packageJsonPath?: string;\n    /**\n     * The dependency installation behavior to use to determine whether a\n     * {@link NodePackageInstallTask} should be scheduled after adding the dependency.\n     * Defaults to {@link InstallBehavior.Auto}.\n     */\n    install?: InstallBehavior;\n    /**\n     * The behavior to use when the dependency already exists within the `package.json`.\n     * Defaults to {@link ExistingBehavior.Replace}.\n     */\n    existing?: ExistingBehavior;\n  } = {},\n): Rule {\n  const {\n    type = DependencyType.Default,\n    packageJsonPath = '/package.json',\n    install = InstallBehavior.Auto,\n    existing = ExistingBehavior.Replace,\n  } = options;\n\n  return (tree, context) => {\n    const manifest = tree.readJson(packageJsonPath) as MinimalPackageManifest;\n    const dependencySection = manifest[type];\n\n    if (!dependencySection) {\n      // Section is not present. The dependency can be added to a new object literal for the section.\n      manifest[type] = { [name]: specifier };\n    } else {\n      const existingSpecifier = dependencySection[name];\n\n      if (existingSpecifier === specifier) {\n        // Already present with same specifier\n        return;\n      }\n\n      if (existingSpecifier) {\n        // Already present but different specifier\n\n        if (existing === ExistingBehavior.Skip) {\n          return;\n        }\n\n        // ExistingBehavior.Replace is the only other behavior currently\n        context.logger.warn(\n          `Package dependency \"${name}\" already exists with a different specifier. ` +\n            `\"${existingSpecifier}\" will be replaced with \"${specifier}\".`,\n        );\n      }\n\n      // Add new dependency in alphabetical order\n      const entries = Object.entries(dependencySection);\n      entries.push([name, specifier]);\n      entries.sort((a, b) => a[0].localeCompare(b[0]));\n      manifest[type] = Object.fromEntries(entries);\n    }\n\n    tree.overwrite(packageJsonPath, JSON.stringify(manifest, null, 2));\n\n    const installPaths = installTasks.get(context) ?? new Set<string>();\n    if (\n      install === InstallBehavior.Always ||\n      (install === InstallBehavior.Auto && !installPaths.has(packageJsonPath))\n    ) {\n      context.addTask(\n        new NodePackageInstallTask({ workingDirectory: path.dirname(packageJsonPath) }),\n      );\n      installPaths.add(packageJsonPath);\n      installTasks.set(context, installPaths);\n    }\n  };\n}\n"]}
|