mirror of
https://github.com/Microsoft/vscode
synced 2024-11-05 18:29:38 +00:00
5e92794be6
Resubmission of #157532 with the following changes: - Use `eslint-plugin-local` instead of `yarn` link to run our plugins - Move our plugins to a top level `.eslintplugin` dir (as required by `eslint-plugin-local`) - Update all names to `local/`
45 lines
1.4 KiB
TypeScript
45 lines
1.4 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as eslint from 'eslint';
|
|
import { TSESTree } from '@typescript-eslint/experimental-utils';
|
|
|
|
export = new class ApiProviderNaming implements eslint.Rule.RuleModule {
|
|
|
|
readonly meta: eslint.Rule.RuleMetaData = {
|
|
messages: {
|
|
naming: 'A provider should only have functions like provideXYZ or resolveXYZ',
|
|
}
|
|
};
|
|
|
|
private static _providerFunctionNames = /^(provide|resolve|prepare).+/;
|
|
|
|
create(context: eslint.Rule.RuleContext): eslint.Rule.RuleListener {
|
|
|
|
const config = <{ allowed: string[] }>context.options[0];
|
|
const allowed = new Set(config.allowed);
|
|
|
|
return {
|
|
['TSInterfaceDeclaration[id.name=/.+Provider/] TSMethodSignature']: (node: any) => {
|
|
|
|
|
|
const interfaceName = (<TSESTree.TSInterfaceDeclaration>(<TSESTree.Identifier>node).parent?.parent).id.name;
|
|
if (allowed.has(interfaceName)) {
|
|
// allowed
|
|
return;
|
|
}
|
|
|
|
const methodName = (<any>(<TSESTree.TSMethodSignatureNonComputedName>node).key).name;
|
|
|
|
if (!ApiProviderNaming._providerFunctionNames.test(methodName)) {
|
|
context.report({
|
|
node,
|
|
messageId: 'naming'
|
|
});
|
|
}
|
|
}
|
|
};
|
|
}
|
|
};
|