123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- "use strict";
- function isNamedLikeSetup(name) {
- return /^(init|setup)$/i.test(name);
- }
- module.exports = {
- meta: {
- type: "suggestion",
- fixable: "code",
- },
- create(context) {
- return {
- "Program > ExpressionStatement > CallExpression": function(node) {
- let callee = node.callee;
- if (callee.type === "Identifier" && callee.name === "add_task") {
- let arg = node.arguments[0];
- if (
- arg.type !== "FunctionExpression" ||
- !arg.id ||
- !isNamedLikeSetup(arg.id.name)
- ) {
- return;
- }
- context.report({
- node,
- message:
- "Do not use add_task() for setup, use add_setup() instead.",
- fix: fixer => {
- let range = [node.callee.range[0], arg.id.range[1]];
- let asyncOrNot = arg.async ? "async " : "";
- return fixer.replaceTextRange(
- range,
- `add_setup(${asyncOrNot}function`
- );
- },
- });
- }
- },
- };
- },
- };
|