source: trip-planner-front/node_modules/@angular/cdk/schematics/ng-update/devkit-migration-rule.mjs

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

initial commit

  • Property mode set to 100644
File size: 20.9 KB
Line 
1"use strict";
2/**
3 * @license
4 * Copyright Google LLC All Rights Reserved.
5 *
6 * Use of this source code is governed by an MIT-style license that can be
7 * found in the LICENSE file at https://angular.io/license
8 */
9var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
10 function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
11 return new (P || (P = Promise))(function (resolve, reject) {
12 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
13 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
14 function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
15 step((generator = generator.apply(thisArg, _arguments || [])).next());
16 });
17};
18Object.defineProperty(exports, "__esModule", { value: true });
19exports.isDevkitMigration = exports.createMigrationSchematicRule = exports.cdkMigrations = void 0;
20const tasks_1 = require("@angular-devkit/schematics/tasks");
21const update_tool_1 = require("../update-tool");
22const project_tsconfig_paths_1 = require("../utils/project-tsconfig-paths");
23const devkit_file_system_1 = require("./devkit-file-system");
24const devkit_migration_1 = require("./devkit-migration");
25const find_stylesheets_1 = require("./find-stylesheets");
26const attribute_selectors_1 = require("./migrations/attribute-selectors");
27const class_inheritance_1 = require("./migrations/class-inheritance");
28const class_names_1 = require("./migrations/class-names");
29const constructor_signature_1 = require("./migrations/constructor-signature");
30const css_selectors_1 = require("./migrations/css-selectors");
31const element_selectors_1 = require("./migrations/element-selectors");
32const input_names_1 = require("./migrations/input-names");
33const method_call_arguments_1 = require("./migrations/method-call-arguments");
34const misc_template_1 = require("./migrations/misc-template");
35const output_names_1 = require("./migrations/output-names");
36const property_names_1 = require("./migrations/property-names");
37/** List of migrations which run for the CDK update. */
38exports.cdkMigrations = [
39 attribute_selectors_1.AttributeSelectorsMigration,
40 class_inheritance_1.ClassInheritanceMigration,
41 class_names_1.ClassNamesMigration,
42 constructor_signature_1.ConstructorSignatureMigration,
43 css_selectors_1.CssSelectorsMigration,
44 element_selectors_1.ElementSelectorsMigration,
45 input_names_1.InputNamesMigration,
46 method_call_arguments_1.MethodCallArgumentsMigration,
47 misc_template_1.MiscTemplateMigration,
48 output_names_1.OutputNamesMigration,
49 property_names_1.PropertyNamesMigration,
50];
51/**
52 * Creates a Angular schematic rule that runs the upgrade for the
53 * specified target version.
54 */
55function createMigrationSchematicRule(targetVersion, extraMigrations, upgradeData, onMigrationCompleteFn) {
56 return (tree, context) => __awaiter(this, void 0, void 0, function* () {
57 const logger = context.logger;
58 const workspace = yield project_tsconfig_paths_1.getWorkspaceConfigGracefully(tree);
59 if (workspace === null) {
60 logger.error('Could not find workspace configuration file.');
61 return;
62 }
63 // Keep track of all project source files which have been checked/migrated. This is
64 // necessary because multiple TypeScript projects can contain the same source file and
65 // we don't want to check these again, as this would result in duplicated failure messages.
66 const analyzedFiles = new Set();
67 const fileSystem = new devkit_file_system_1.DevkitFileSystem(tree);
68 const projectNames = workspace.projects.keys();
69 const migrations = [...exports.cdkMigrations, ...extraMigrations];
70 let hasFailures = false;
71 for (const projectName of projectNames) {
72 const project = workspace.projects.get(projectName);
73 const buildTsconfigPath = project_tsconfig_paths_1.getTargetTsconfigPath(project, 'build');
74 const testTsconfigPath = project_tsconfig_paths_1.getTargetTsconfigPath(project, 'test');
75 if (!buildTsconfigPath && !testTsconfigPath) {
76 logger.warn(`Could not find TypeScript project for project: ${projectName}`);
77 continue;
78 }
79 // In some applications, developers will have global stylesheets which are not
80 // specified in any Angular component. Therefore we glob up all CSS and SCSS files
81 // in the project and migrate them if needed.
82 // TODO: rework this to collect global stylesheets from the workspace config. COMP-280.
83 const additionalStylesheetPaths = find_stylesheets_1.findStylesheetFiles(tree, project.root);
84 if (buildTsconfigPath !== null) {
85 runMigrations(project, projectName, buildTsconfigPath, additionalStylesheetPaths, false);
86 }
87 if (testTsconfigPath !== null) {
88 runMigrations(project, projectName, testTsconfigPath, additionalStylesheetPaths, true);
89 }
90 }
91 let runPackageManager = false;
92 // Run the global post migration static members for all
93 // registered devkit migrations.
94 migrations.forEach(m => {
95 const actionResult = isDevkitMigration(m) && m.globalPostMigration !== undefined ?
96 m.globalPostMigration(tree, context) : null;
97 if (actionResult) {
98 runPackageManager = runPackageManager || actionResult.runPackageManager;
99 }
100 });
101 // If a migration requested the package manager to run, we run it as an
102 // asynchronous post migration task. We cannot run it synchronously,
103 // as file changes from the current migration task are not applied to
104 // the file system yet.
105 if (runPackageManager) {
106 context.addTask(new tasks_1.NodePackageInstallTask({ quiet: false }));
107 }
108 if (onMigrationCompleteFn) {
109 onMigrationCompleteFn(context, targetVersion, hasFailures);
110 }
111 /** Runs the migrations for the specified workspace project. */
112 function runMigrations(project, projectName, tsconfigPath, additionalStylesheetPaths, isTestTarget) {
113 const program = update_tool_1.UpdateProject.createProgramFromTsconfig(tsconfigPath, fileSystem);
114 const updateContext = {
115 isTestTarget,
116 projectName,
117 project,
118 tree,
119 };
120 const updateProject = new update_tool_1.UpdateProject(updateContext, program, fileSystem, analyzedFiles, context.logger);
121 const result = updateProject.migrate(migrations, targetVersion, upgradeData, additionalStylesheetPaths);
122 // Commit all recorded edits in the update recorder. We apply the edits after all
123 // migrations ran because otherwise offsets in the TypeScript program would be
124 // shifted and individual migrations could no longer update the same source file.
125 fileSystem.commitEdits();
126 hasFailures = hasFailures || result.hasFailures;
127 }
128 });
129}
130exports.createMigrationSchematicRule = createMigrationSchematicRule;
131/** Whether the given migration type refers to a devkit migration */
132function isDevkitMigration(value) {
133 return devkit_migration_1.DevkitMigration.isPrototypeOf(value);
134}
135exports.isDevkitMigration = isDevkitMigration;
136//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devkit-migration-rule.js","sourceRoot":"","sources":["../../../../../../../src/cdk/schematics/ng-update/devkit-migration-rule.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, Tree} from '@angular-devkit/schematics';\nimport {NodePackageInstallTask} from '@angular-devkit/schematics/tasks';\nimport {ProjectDefinition} from '@angular-devkit/core/src/workspace';\n\nimport {UpdateProject} from '../update-tool';\nimport {WorkspacePath} from '../update-tool/file-system';\nimport {MigrationCtor} from '../update-tool/migration';\nimport {TargetVersion} from '../update-tool/target-version';\nimport {getTargetTsconfigPath, getWorkspaceConfigGracefully} from '../utils/project-tsconfig-paths';\n\nimport {DevkitFileSystem} from './devkit-file-system';\nimport {DevkitContext, DevkitMigration, DevkitMigrationCtor} from './devkit-migration';\nimport {findStylesheetFiles} from './find-stylesheets';\nimport {AttributeSelectorsMigration} from './migrations/attribute-selectors';\nimport {ClassInheritanceMigration} from './migrations/class-inheritance';\nimport {ClassNamesMigration} from './migrations/class-names';\nimport {ConstructorSignatureMigration} from './migrations/constructor-signature';\nimport {CssSelectorsMigration} from './migrations/css-selectors';\nimport {ElementSelectorsMigration} from './migrations/element-selectors';\nimport {InputNamesMigration} from './migrations/input-names';\nimport {MethodCallArgumentsMigration} from './migrations/method-call-arguments';\nimport {MiscTemplateMigration} from './migrations/misc-template';\nimport {OutputNamesMigration} from './migrations/output-names';\nimport {PropertyNamesMigration} from './migrations/property-names';\nimport {UpgradeData} from './upgrade-data';\n\n\n/** List of migrations which run for the CDK update. */\nexport const cdkMigrations: MigrationCtor<UpgradeData>[] = [\n  AttributeSelectorsMigration,\n  ClassInheritanceMigration,\n  ClassNamesMigration,\n  ConstructorSignatureMigration,\n  CssSelectorsMigration,\n  ElementSelectorsMigration,\n  InputNamesMigration,\n  MethodCallArgumentsMigration,\n  MiscTemplateMigration,\n  OutputNamesMigration,\n  PropertyNamesMigration,\n];\n\nexport type NullableDevkitMigration = MigrationCtor<UpgradeData|null, DevkitContext>;\n\ntype PostMigrationFn =\n    (context: SchematicContext, targetVersion: TargetVersion, hasFailure: boolean) => void;\n\n/**\n * Creates a Angular schematic rule that runs the upgrade for the\n * specified target version.\n */\nexport function createMigrationSchematicRule(\n    targetVersion: TargetVersion, extraMigrations: NullableDevkitMigration[],\n    upgradeData: UpgradeData, onMigrationCompleteFn?: PostMigrationFn): Rule {\n  return async (tree: Tree, context: SchematicContext) => {\n    const logger = context.logger;\n    const workspace = await getWorkspaceConfigGracefully(tree);\n\n    if (workspace === null) {\n      logger.error('Could not find workspace configuration file.');\n      return;\n    }\n\n    // Keep track of all project source files which have been checked/migrated. This is\n    // necessary because multiple TypeScript projects can contain the same source file and\n    // we don't want to check these again, as this would result in duplicated failure messages.\n    const analyzedFiles = new Set<WorkspacePath>();\n    const fileSystem = new DevkitFileSystem(tree);\n    const projectNames = workspace.projects.keys();\n    const migrations = [...cdkMigrations, ...extraMigrations] as NullableDevkitMigration[];\n    let hasFailures = false;\n\n    for (const projectName of projectNames) {\n      const project = workspace.projects.get(projectName)!;\n      const buildTsconfigPath = getTargetTsconfigPath(project, 'build');\n      const testTsconfigPath = getTargetTsconfigPath(project, 'test');\n\n      if (!buildTsconfigPath && !testTsconfigPath) {\n        logger.warn(`Could not find TypeScript project for project: ${projectName}`);\n        continue;\n      }\n\n      // In some applications, developers will have global stylesheets which are not\n      // specified in any Angular component. Therefore we glob up all CSS and SCSS files\n      // in the project and migrate them if needed.\n      // TODO: rework this to collect global stylesheets from the workspace config. COMP-280.\n      const additionalStylesheetPaths = findStylesheetFiles(tree, project.root);\n\n      if (buildTsconfigPath !== null) {\n        runMigrations(project, projectName, buildTsconfigPath, additionalStylesheetPaths, false);\n      }\n      if (testTsconfigPath !== null) {\n        runMigrations(project, projectName, testTsconfigPath, additionalStylesheetPaths, true);\n      }\n    }\n\n    let runPackageManager = false;\n    // Run the global post migration static members for all\n    // registered devkit migrations.\n    migrations.forEach(m => {\n      const actionResult = isDevkitMigration(m) && m.globalPostMigration !== undefined ?\n          m.globalPostMigration(tree, context) : null;\n      if (actionResult) {\n        runPackageManager = runPackageManager || actionResult.runPackageManager;\n      }\n    });\n\n    // If a migration requested the package manager to run, we run it as an\n    // asynchronous post migration task. We cannot run it synchronously,\n    // as file changes from the current migration task are not applied to\n    // the file system yet.\n    if (runPackageManager) {\n      context.addTask(new NodePackageInstallTask({quiet: false}));\n    }\n\n    if (onMigrationCompleteFn) {\n      onMigrationCompleteFn(context, targetVersion, hasFailures);\n    }\n\n    /** Runs the migrations for the specified workspace project. */\n    function runMigrations(project: ProjectDefinition, projectName: string,\n                           tsconfigPath: WorkspacePath, additionalStylesheetPaths: string[],\n                           isTestTarget: boolean) {\n      const program = UpdateProject.createProgramFromTsconfig(tsconfigPath, fileSystem);\n      const updateContext: DevkitContext = {\n        isTestTarget,\n        projectName,\n        project,\n        tree,\n      };\n\n      const updateProject = new UpdateProject(\n        updateContext,\n        program,\n        fileSystem,\n        analyzedFiles,\n        context.logger,\n      );\n\n      const result =\n        updateProject.migrate(migrations, targetVersion, upgradeData, additionalStylesheetPaths);\n\n      // Commit all recorded edits in the update recorder. We apply the edits after all\n      // migrations ran because otherwise offsets in the TypeScript program would be\n      // shifted and individual migrations could no longer update the same source file.\n      fileSystem.commitEdits();\n\n      hasFailures = hasFailures || result.hasFailures;\n    }\n  };\n}\n\n/** Whether the given migration type refers to a devkit migration */\nexport function isDevkitMigration(value: MigrationCtor<any, any>)\n    : value is DevkitMigrationCtor<any> {\n  return DevkitMigration.isPrototypeOf(value);\n}\n"]}
Note: See TracBrowser for help on using the repository browser.