mirror of
https://github.com/angular/angular-cli.git
synced 2025-05-17 19:13:34 +08:00
This change provides more fine-grained warnings during the `update-module-and-target-compiler-options` migration for V10.0 in the event a TypeScript configuration file could not be updated. The `JSONFile` utility class was also augmented to directly throw when created to ensure that the `content` property is always initialized.
56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google Inc. 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
|
|
*/
|
|
import { JsonValue } from '@angular-devkit/core';
|
|
import { Rule } from '@angular-devkit/schematics';
|
|
import { getPackageJsonDependency } from '../../utility/dependencies';
|
|
import { JSONFile } from '../../utility/json-file';
|
|
|
|
const TSLINT_CONFIG_PATH = '/tslint.json';
|
|
const RULES_TO_ADD: Record<string, JsonValue> = {
|
|
deprecation: {
|
|
severity: 'warning',
|
|
},
|
|
};
|
|
|
|
export default function (): Rule {
|
|
return (tree, context) => {
|
|
const logger = context.logger;
|
|
|
|
// Update tslint dependency
|
|
const current = getPackageJsonDependency(tree, 'tslint');
|
|
|
|
if (!current) {
|
|
logger.info('Skipping: "tslint" in not a dependency of this workspace.');
|
|
|
|
return;
|
|
}
|
|
|
|
// Update tslint config.
|
|
let json;
|
|
try {
|
|
json = new JSONFile(tree, TSLINT_CONFIG_PATH);
|
|
} catch {
|
|
const config = ['tslint.js', 'tslint.yaml'].find(c => tree.exists(c));
|
|
if (config) {
|
|
logger.warn(`Expected a JSON configuration file but found "${config}".`);
|
|
} else {
|
|
logger.warn('Cannot find "tslint.json" configuration file.');
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
for (const [name, value] of Object.entries(RULES_TO_ADD)) {
|
|
const ruleName = ['rules', name];
|
|
if (json.get(ruleName) === undefined) {
|
|
json.modify(ruleName, value);
|
|
}
|
|
}
|
|
};
|
|
}
|